mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-04 09:26:05 +00:00 
			
		
		
		
	Window attachment, malloc debugging, fix a segfault with no sessions.
This commit is contained in:
		
							
								
								
									
										4
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								CHANGES
									
									
									
									
									
								
							@@ -1,5 +1,7 @@
 | 
				
			|||||||
04 October 2007
 | 
					04 October 2007
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					* (nicm) attach-session (can't believe I forgot it until now!) and list-windows
 | 
				
			||||||
 | 
					  commands.
 | 
				
			||||||
* (nicm) rename-window and select-window commands.
 | 
					* (nicm) rename-window and select-window commands.
 | 
				
			||||||
* (nicm) set-option command (alias set): "tmux set-option prefix ^A".
 | 
					* (nicm) set-option command (alias set): "tmux set-option prefix ^A".
 | 
				
			||||||
* (nicm) Key binding and unbinding is back.
 | 
					* (nicm) Key binding and unbinding is back.
 | 
				
			||||||
@@ -110,5 +112,5 @@
 | 
				
			|||||||
  (including mutt, emacs). No status bar yet and no key remapping or other
 | 
					  (including mutt, emacs). No status bar yet and no key remapping or other
 | 
				
			||||||
  customisation.
 | 
					  customisation.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$Id: CHANGES,v 1.30 2007-10-04 10:54:20 nicm Exp $
 | 
					$Id: CHANGES,v 1.31 2007-10-04 11:52:02 nicm Exp $
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								Makefile
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
# $Id: Makefile,v 1.21 2007-10-04 11:23:17 nicm Exp $
 | 
					# $Id: Makefile,v 1.22 2007-10-04 11:52:02 nicm Exp $
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.SUFFIXES: .c .o .y .h
 | 
					.SUFFIXES: .c .o .y .h
 | 
				
			||||||
.PHONY: clean
 | 
					.PHONY: clean
 | 
				
			||||||
@@ -22,7 +22,7 @@ SRCS= tmux.c server.c server-msg.c server-fn.c buffer.c buffer-poll.c status.c \
 | 
				
			|||||||
      cmd-list-sessions.c cmd-new-window.c cmd-next-window.c cmd-bind-key.c \
 | 
					      cmd-list-sessions.c cmd-new-window.c cmd-next-window.c cmd-bind-key.c \
 | 
				
			||||||
      cmd-unbind-key.c cmd-previous-window.c cmd-last-window.c cmd-list-keys.c \
 | 
					      cmd-unbind-key.c cmd-previous-window.c cmd-last-window.c cmd-list-keys.c \
 | 
				
			||||||
      cmd-set-option.c cmd-rename-window.c cmd-select-window.c \
 | 
					      cmd-set-option.c cmd-rename-window.c cmd-select-window.c \
 | 
				
			||||||
      cmd-list-windows.c
 | 
					      cmd-list-windows.c cmd-attach-session.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
YACC= yacc -d
 | 
					YACC= yacc -d
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										16
									
								
								client-msg.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								client-msg.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: client-msg.c,v 1.6 2007-10-03 21:31:07 nicm Exp $ */
 | 
					/* $Id: client-msg.c,v 1.7 2007-10-04 11:52:02 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -27,6 +27,7 @@
 | 
				
			|||||||
int	client_msg_fn_data(struct hdr *, struct client_ctx *, char **);
 | 
					int	client_msg_fn_data(struct hdr *, struct client_ctx *, char **);
 | 
				
			||||||
int	client_msg_fn_detach(struct hdr *, struct client_ctx *, char **);
 | 
					int	client_msg_fn_detach(struct hdr *, struct client_ctx *, char **);
 | 
				
			||||||
int	client_msg_fn_error(struct hdr *, struct client_ctx *, char **);
 | 
					int	client_msg_fn_error(struct hdr *, struct client_ctx *, char **);
 | 
				
			||||||
 | 
					int	client_msg_fn_exit(struct hdr *, struct client_ctx *, char **);
 | 
				
			||||||
int	client_msg_fn_okay(struct hdr *, struct client_ctx *, char **);
 | 
					int	client_msg_fn_okay(struct hdr *, struct client_ctx *, char **);
 | 
				
			||||||
int	client_msg_fn_pause(struct hdr *, struct client_ctx *, char **);
 | 
					int	client_msg_fn_pause(struct hdr *, struct client_ctx *, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -39,6 +40,7 @@ struct client_msg client_msg_table[] = {
 | 
				
			|||||||
	{ MSG_DATA, client_msg_fn_data },
 | 
						{ MSG_DATA, client_msg_fn_data },
 | 
				
			||||||
	{ MSG_DETACH, client_msg_fn_detach },
 | 
						{ MSG_DETACH, client_msg_fn_detach },
 | 
				
			||||||
	{ MSG_ERROR, client_msg_fn_error },
 | 
						{ MSG_ERROR, client_msg_fn_error },
 | 
				
			||||||
 | 
						{ MSG_EXIT, client_msg_fn_exit },
 | 
				
			||||||
	{ MSG_PAUSE, client_msg_fn_pause },
 | 
						{ MSG_PAUSE, client_msg_fn_pause },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
#define NCLIENTMSG (sizeof client_msg_table / sizeof client_msg_table[0])
 | 
					#define NCLIENTMSG (sizeof client_msg_table / sizeof client_msg_table[0])
 | 
				
			||||||
@@ -102,6 +104,18 @@ client_msg_fn_error(struct hdr *hdr, struct client_ctx *cctx, char **error)
 | 
				
			|||||||
	return (-1);
 | 
						return (-1);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int
 | 
				
			||||||
 | 
					client_msg_fn_exit(
 | 
				
			||||||
 | 
					    struct hdr *hdr, unused struct client_ctx *cctx, char **error)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (hdr->size != 0)
 | 
				
			||||||
 | 
							fatalx("bad MSG_EXIT size");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						*error = xstrdup("");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return (-1);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int
 | 
					int
 | 
				
			||||||
client_msg_fn_detach(
 | 
					client_msg_fn_detach(
 | 
				
			||||||
    struct hdr *hdr, unused struct client_ctx *cctx, char **error)
 | 
					    struct hdr *hdr, unused struct client_ctx *cctx, char **error)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								client.c
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								client.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: client.c,v 1.11 2007-10-03 21:31:07 nicm Exp $ */
 | 
					/* $Id: client.c,v 1.12 2007-10-04 11:52:02 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -174,6 +174,10 @@ client_main(struct client_ctx *cctx)
 | 
				
			|||||||
	local_done();
 | 
						local_done();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (error != NULL) {
 | 
						if (error != NULL) {
 | 
				
			||||||
 | 
							if (*error == '\0') {
 | 
				
			||||||
 | 
								printf("[exited]\n", error);
 | 
				
			||||||
 | 
								return (0);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
		printf("[error: %s]\n", error);
 | 
							printf("[error: %s]\n", error);
 | 
				
			||||||
		return (1);
 | 
							return (1);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										59
									
								
								cmd-attach-session.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								cmd-attach-session.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,59 @@
 | 
				
			|||||||
 | 
					/* $Id: cmd-attach-session.c,v 1.1 2007-10-04 11:52:03 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Permission to use, copy, modify, and distribute this software for any
 | 
				
			||||||
 | 
					 * purpose with or without fee is hereby granted, provided that the above
 | 
				
			||||||
 | 
					 * copyright notice and this permission notice appear in all copies.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 | 
				
			||||||
 | 
					 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 | 
				
			||||||
 | 
					 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 | 
				
			||||||
 | 
					 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 | 
				
			||||||
 | 
					 * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
 | 
				
			||||||
 | 
					 * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
 | 
				
			||||||
 | 
					 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <sys/types.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <getopt.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "tmux.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Attach existing session to the current terminal.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void	cmd_attach_session_exec(void *, struct cmd_ctx *);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const struct cmd_entry cmd_attach_session_entry = {
 | 
				
			||||||
 | 
						CMD_ATTACHSESSION, "attach-session", "attach", 0,
 | 
				
			||||||
 | 
						NULL,
 | 
				
			||||||
 | 
						NULL,
 | 
				
			||||||
 | 
						cmd_attach_session_exec, 
 | 
				
			||||||
 | 
						NULL,
 | 
				
			||||||
 | 
						NULL,
 | 
				
			||||||
 | 
						NULL
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void
 | 
				
			||||||
 | 
					cmd_attach_session_exec(unused void *ptr, struct cmd_ctx *ctx)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct client	*c = ctx->client;
 | 
				
			||||||
 | 
						struct session	*s = ctx->session;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (ctx->flags & CMD_KEY)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!(c->flags & CLIENT_TERMINAL)) {
 | 
				
			||||||
 | 
							ctx->error(ctx, "not a terminal");
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						c->session = s;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						server_write_client(c, MSG_READY, NULL, 0);
 | 
				
			||||||
 | 
						server_redraw_client(c);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										3
									
								
								cmd.c
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								cmd.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: cmd.c,v 1.11 2007-10-04 11:23:17 nicm Exp $ */
 | 
					/* $Id: cmd.c,v 1.12 2007-10-04 11:52:03 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -24,6 +24,7 @@
 | 
				
			|||||||
#include "tmux.h"
 | 
					#include "tmux.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const struct cmd_entry *cmd_table[] = {
 | 
					const struct cmd_entry *cmd_table[] = {
 | 
				
			||||||
 | 
						&cmd_attach_session_entry,
 | 
				
			||||||
	&cmd_bind_key_entry,
 | 
						&cmd_bind_key_entry,
 | 
				
			||||||
	&cmd_detach_session_entry,
 | 
						&cmd_detach_session_entry,
 | 
				
			||||||
	&cmd_last_window_entry,
 | 
						&cmd_last_window_entry,
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										14
									
								
								server-msg.c
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								server-msg.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: server-msg.c,v 1.22 2007-10-04 00:02:10 nicm Exp $ */
 | 
					/* $Id: server-msg.c,v 1.23 2007-10-04 11:52:03 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -118,6 +118,12 @@ server_msg_fn_command(struct hdr *hdr, struct client *c)
 | 
				
			|||||||
	log_debug("got command %u %s from client %d",
 | 
						log_debug("got command %u %s from client %d",
 | 
				
			||||||
	    cmd->entry->type, cmd->entry->name, c->fd);
 | 
						    cmd->entry->type, cmd->entry->name, c->fd);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ctx.error = server_msg_fn_command_error;
 | 
				
			||||||
 | 
						ctx.print = server_msg_fn_command_print;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ctx.client = c;
 | 
				
			||||||
 | 
						ctx.flags = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (cmd->entry->flags & CMD_NOSESSION)
 | 
						if (cmd->entry->flags & CMD_NOSESSION)
 | 
				
			||||||
		ctx.session = NULL;
 | 
							ctx.session = NULL;
 | 
				
			||||||
	else {
 | 
						else {
 | 
				
			||||||
@@ -129,12 +135,6 @@ server_msg_fn_command(struct hdr *hdr, struct client *c)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}		
 | 
						}		
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ctx.error = server_msg_fn_command_error;
 | 
					 | 
				
			||||||
	ctx.print = server_msg_fn_command_print;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	ctx.client = c;
 | 
					 | 
				
			||||||
	ctx.flags = 0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	cmd_exec(cmd, &ctx);
 | 
						cmd_exec(cmd, &ctx);
 | 
				
			||||||
	cmd_free(cmd);
 | 
						cmd_free(cmd);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										16
									
								
								server.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								server.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: server.c,v 1.22 2007-10-04 00:02:10 nicm Exp $ */
 | 
					/* $Id: server.c,v 1.23 2007-10-04 11:52:03 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -62,7 +62,7 @@ server_start(char *path)
 | 
				
			|||||||
	size_t			sz;
 | 
						size_t			sz;
 | 
				
			||||||
	pid_t			pid;
 | 
						pid_t			pid;
 | 
				
			||||||
	mode_t			mask;
 | 
						mode_t			mask;
 | 
				
			||||||
	int		   	fd, mode;
 | 
						int		   	n, fd, mode;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	switch (pid = fork()) {
 | 
						switch (pid = fork()) {
 | 
				
			||||||
	case -1:
 | 
						case -1:
 | 
				
			||||||
@@ -74,6 +74,8 @@ server_start(char *path)
 | 
				
			|||||||
		return (0);
 | 
							return (0);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						xmalloc_clear();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	logfile("server");
 | 
						logfile("server");
 | 
				
			||||||
	setproctitle("server (%s)", path);
 | 
						setproctitle("server (%s)", path);
 | 
				
			||||||
	log_debug("server started, pid %ld", (long) getpid());
 | 
						log_debug("server started, pid %ld", (long) getpid());
 | 
				
			||||||
@@ -103,15 +105,15 @@ server_start(char *path)
 | 
				
			|||||||
	if (fcntl(fd, F_SETFL, mode|O_NONBLOCK) == -1)
 | 
						if (fcntl(fd, F_SETFL, mode|O_NONBLOCK) == -1)
 | 
				
			||||||
		fatal("fcntl failed");
 | 
							fatal("fcntl failed");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/*
 | 
					 | 
				
			||||||
	 * Detach into the background. This means the PID changes which will
 | 
					 | 
				
			||||||
	 * have to be fixed in some way at some point... XXX
 | 
					 | 
				
			||||||
	 */
 | 
					 | 
				
			||||||
	if (daemon(1, 1) != 0)
 | 
						if (daemon(1, 1) != 0)
 | 
				
			||||||
		fatal("daemon failed");
 | 
							fatal("daemon failed");
 | 
				
			||||||
	log_debug("server daemonised, pid now %ld", (long) getpid());
 | 
						log_debug("server daemonised, pid now %ld", (long) getpid());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	exit(server_main(path, fd));
 | 
						n = server_main(path, fd);
 | 
				
			||||||
 | 
					#ifdef DEBUG
 | 
				
			||||||
 | 
						xmalloc_report(getpid(), "server");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						exit(n);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Main server loop. */
 | 
					/* Main server loop. */
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										20
									
								
								tmux.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								tmux.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: tmux.c,v 1.28 2007-10-04 11:23:17 nicm Exp $ */
 | 
					/* $Id: tmux.c,v 1.29 2007-10-04 11:52:03 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -167,7 +167,7 @@ main(int argc, char **argv)
 | 
				
			|||||||
	struct hdr	 	 hdr;
 | 
						struct hdr	 	 hdr;
 | 
				
			||||||
	const char		*shell;
 | 
						const char		*shell;
 | 
				
			||||||
	char			*path, *cause, name[MAXNAMELEN];
 | 
						char			*path, *cause, name[MAXNAMELEN];
 | 
				
			||||||
	int	 		 opt;
 | 
						int	 		 n, opt;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	*name = '\0';
 | 
						*name = '\0';
 | 
				
			||||||
	path = NULL;
 | 
						path = NULL;
 | 
				
			||||||
@@ -245,7 +245,8 @@ main(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		switch (hdr.type) {
 | 
							switch (hdr.type) {
 | 
				
			||||||
		case MSG_EXIT:
 | 
							case MSG_EXIT:
 | 
				
			||||||
			exit(0);
 | 
								n = 0;
 | 
				
			||||||
 | 
								goto out;
 | 
				
			||||||
		case MSG_PRINT:
 | 
							case MSG_PRINT:
 | 
				
			||||||
			if (hdr.size > INT_MAX - 1)
 | 
								if (hdr.size > INT_MAX - 1)
 | 
				
			||||||
				fatalx("bad MSG_PRINT size");
 | 
									fatalx("bad MSG_PRINT size");
 | 
				
			||||||
@@ -259,14 +260,21 @@ main(int argc, char **argv)
 | 
				
			|||||||
			log_warnx("%.*s",
 | 
								log_warnx("%.*s",
 | 
				
			||||||
			    (int) hdr.size, BUFFER_OUT(cctx.srv_in));	
 | 
								    (int) hdr.size, BUFFER_OUT(cctx.srv_in));	
 | 
				
			||||||
			buffer_remove(cctx.srv_in, hdr.size);
 | 
								buffer_remove(cctx.srv_in, hdr.size);
 | 
				
			||||||
			exit(1);
 | 
								n = 1;
 | 
				
			||||||
 | 
								goto out;
 | 
				
			||||||
		case MSG_READY:
 | 
							case MSG_READY:
 | 
				
			||||||
			exit(client_main(&cctx));
 | 
								n = client_main(&cctx);
 | 
				
			||||||
 | 
								goto out;
 | 
				
			||||||
		default:
 | 
							default:
 | 
				
			||||||
			fatalx("unexpected command");
 | 
								fatalx("unexpected command");
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	/* NOTREACHED */
 | 
					
 | 
				
			||||||
 | 
					out:
 | 
				
			||||||
 | 
					#ifdef DEBUG
 | 
				
			||||||
 | 
						xmalloc_report(getpid(), "client");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						return (n);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
usage:
 | 
					usage:
 | 
				
			||||||
	usage(&cause, NULL);
 | 
						usage(&cause, NULL);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								tmux.h
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								tmux.h
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: tmux.h,v 1.46 2007-10-04 11:23:17 nicm Exp $ */
 | 
					/* $Id: tmux.h,v 1.47 2007-10-04 11:52:03 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -457,6 +457,7 @@ struct client_ctx {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* Key/command line command. */
 | 
					/* Key/command line command. */
 | 
				
			||||||
enum cmd_type {
 | 
					enum cmd_type {
 | 
				
			||||||
 | 
						CMD_ATTACHSESSION,
 | 
				
			||||||
	CMD_BINDKEY,
 | 
						CMD_BINDKEY,
 | 
				
			||||||
	CMD_DETACHSESSION,
 | 
						CMD_DETACHSESSION,
 | 
				
			||||||
	CMD_LASTWINDOW,
 | 
						CMD_LASTWINDOW,
 | 
				
			||||||
@@ -533,6 +534,7 @@ struct cmd	*cmd_recv(struct buffer *);
 | 
				
			|||||||
void		 cmd_free(struct cmd *);
 | 
					void		 cmd_free(struct cmd *);
 | 
				
			||||||
void		 cmd_send_string(struct buffer *, const char *);
 | 
					void		 cmd_send_string(struct buffer *, const char *);
 | 
				
			||||||
char		*cmd_recv_string(struct buffer *);
 | 
					char		*cmd_recv_string(struct buffer *);
 | 
				
			||||||
 | 
					extern const struct cmd_entry cmd_attach_session_entry;
 | 
				
			||||||
extern const struct cmd_entry cmd_bind_key_entry;
 | 
					extern const struct cmd_entry cmd_bind_key_entry;
 | 
				
			||||||
extern const struct cmd_entry cmd_detach_session_entry;
 | 
					extern const struct cmd_entry cmd_detach_session_entry;
 | 
				
			||||||
extern const struct cmd_entry cmd_last_window_entry;
 | 
					extern const struct cmd_entry cmd_last_window_entry;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: xmalloc-debug.c,v 1.1 2007-07-25 23:13:18 nicm Exp $ */
 | 
					/* $Id: xmalloc-debug.c,v 1.2 2007-10-04 11:52:03 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -51,7 +51,7 @@ u_int	xmalloc_mallocs;
 | 
				
			|||||||
u_int	xmalloc_reallocs;
 | 
					u_int	xmalloc_reallocs;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Print function. */
 | 
					/* Print function. */
 | 
				
			||||||
#define XMALLOC_PRINT log_debug3
 | 
					#define XMALLOC_PRINT log_debug
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Bytes of unallocated blocks and number of allocated blocks to show. */
 | 
					/* Bytes of unallocated blocks and number of allocated blocks to show. */
 | 
				
			||||||
#define XMALLOC_BYTES 8
 | 
					#define XMALLOC_BYTES 8
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user