From 2c9bdd9e326723fb392aed4d8df12cba7ef34f1f Mon Sep 17 00:00:00 2001 From: nicm Date: Sat, 22 Apr 2017 06:13:30 +0000 Subject: [PATCH 1/3] Memory leaks, from David CARLIER. --- cmd-load-buffer.c | 1 + cmd-save-buffer.c | 1 + cmd-set-option.c | 28 +++++++++++++++++----------- options.c | 2 +- server.c | 8 ++++++-- 5 files changed, 26 insertions(+), 14 deletions(-) diff --git a/cmd-load-buffer.c b/cmd-load-buffer.c index 677f3656..a3cabdc0 100644 --- a/cmd-load-buffer.c +++ b/cmd-load-buffer.c @@ -127,6 +127,7 @@ error: free(pdata); if (f != NULL) fclose(f); + free(file); return (CMD_RETURN_ERROR); } diff --git a/cmd-save-buffer.c b/cmd-save-buffer.c index 68c8627a..be98117c 100644 --- a/cmd-save-buffer.c +++ b/cmd-save-buffer.c @@ -112,6 +112,7 @@ cmd_save_buffer_exec(struct cmd *self, struct cmdq_item *item) if (fwrite(bufdata, 1, bufsize, f) != bufsize) { cmdq_error(item, "%s: write error", file); fclose(f); + free(file); return (CMD_RETURN_ERROR); } diff --git a/cmd-set-option.c b/cmd-set-option.c index a0138d86..d862bb98 100644 --- a/cmd-set-option.c +++ b/cmd-set-option.c @@ -77,7 +77,8 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) enum options_table_scope scope; struct options *oo; struct options_entry *parent, *o; - const char *name, *value, *target; + char *name; + const char *value, *target; int window, idx, already, error, ambiguous; char *cause; @@ -121,7 +122,7 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) return (CMD_RETURN_NORMAL); cmdq_error(item, "%s", cause); free(cause); - return (CMD_RETURN_ERROR); + goto fail; } /* Which table should this option go into? */ @@ -136,7 +137,7 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) cmdq_error(item, "no such session: %s", target); else cmdq_error(item, "no current session"); - return (CMD_RETURN_ERROR); + goto fail; } else oo = s->options; } else if (scope == OPTIONS_TABLE_WINDOW) { @@ -148,7 +149,7 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) cmdq_error(item, "no such window: %s", target); else cmdq_error(item, "no current window"); - return (CMD_RETURN_ERROR); + goto fail; } else oo = wl->window->options; } @@ -159,7 +160,7 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) if (idx != -1) { if (*name == '@' || options_array_size(parent, NULL) == -1) { cmdq_error(item, "not an array: %s", args->argv[0]); - return (CMD_RETURN_ERROR); + goto fail; } } @@ -177,14 +178,14 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) if (args_has(args, 'q')) return (CMD_RETURN_NORMAL); cmdq_error(item, "already set: %s", args->argv[0]); - return (CMD_RETURN_ERROR); + goto fail; } } /* Change the option. */ if (args_has(args, 'u')) { if (o == NULL) - return (CMD_RETURN_NORMAL); + goto fail; if (idx == -1) { if (oo == global_options || oo == global_s_options || @@ -197,17 +198,17 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) } else if (*name == '@') { if (value == NULL) { cmdq_error(item, "empty value"); - return (CMD_RETURN_ERROR); + goto fail; } options_set_string(oo, name, append, "%s", value); } else if (idx == -1 && options_array_size(parent, NULL) == -1) { error = cmd_set_option_set(self, item, oo, parent, value); if (error != 0) - return (CMD_RETURN_ERROR); + goto fail; } else { if (value == NULL) { cmdq_error(item, "empty value"); - return (CMD_RETURN_ERROR); + goto fail; } if (o == NULL) o = options_empty(oo, options_table_entry(parent)); @@ -217,7 +218,7 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) options_array_assign(o, value); } else if (options_array_set(o, idx, value, append) != 0) { cmdq_error(item, "invalid index: %s", args->argv[0]); - return (CMD_RETURN_ERROR); + goto fail; } } @@ -261,7 +262,12 @@ cmd_set_option_exec(struct cmd *self, struct cmdq_item *item) server_redraw_client(c); } + free(name); return (CMD_RETURN_NORMAL); + +fail: + free(name); + return (CMD_RETURN_ERROR); } static int diff --git a/options.c b/options.c index 4cd3ea10..861bd8ac 100644 --- a/options.c +++ b/options.c @@ -433,7 +433,7 @@ options_match(const char *s, int *idx, int* ambiguous) if (*name == '@') { *ambiguous = 0; - return (xstrdup(name)); + return (name); } found = NULL; diff --git a/server.c b/server.c index 78bc70db..e0987fca 100644 --- a/server.c +++ b/server.c @@ -119,12 +119,16 @@ server_create_socket(void) return (-1); mask = umask(S_IXUSR|S_IXGRP|S_IRWXO); - if (bind(fd, (struct sockaddr *) &sa, sizeof(sa)) == -1) + if (bind(fd, (struct sockaddr *) &sa, sizeof(sa)) == -1) { + close(fd); return (-1); + } umask(mask); - if (listen(fd, 128) == -1) + if (listen(fd, 128) == -1) { + close(fd); return (-1); + } setblocking(fd, 0); return (fd); From 59ff9b812827a7a3ba4ded5a911a93fc08bc3586 Mon Sep 17 00:00:00 2001 From: nicm Date: Sat, 22 Apr 2017 06:15:22 +0000 Subject: [PATCH 2/3] Typo in example. --- tmux.1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tmux.1 b/tmux.1 index 0dc02ef2..04d98dae 100644 --- a/tmux.1 +++ b/tmux.1 @@ -3435,7 +3435,7 @@ or .Ql != and a colon. For example -.Ql #{==,#{host},myhost} +.Ql #{==:#{host},myhost} will be replaced by .Ql 1 if running on From 30348edc7c0e3fd7afa545efbe48cdad69102e65 Mon Sep 17 00:00:00 2001 From: nicm Date: Sat, 22 Apr 2017 06:27:15 +0000 Subject: [PATCH 3/3] Fix if-shell without a client (so in the config file). Reported by Theo Buehler. --- cmd-if-shell.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/cmd-if-shell.c b/cmd-if-shell.c index fafb8cee..4a93885b 100644 --- a/cmd-if-shell.c +++ b/cmd-if-shell.c @@ -120,7 +120,8 @@ cmd_if_shell_exec(struct cmd *self, struct cmdq_item *item) cdata->cmd_else = NULL; cdata->client = item->client; - cdata->client->references++; + if (cdata->client != NULL) + cdata->client->references++; if (!args_has(args, 'b')) cdata->item = item; @@ -193,7 +194,8 @@ cmd_if_shell_free(void *data) { struct cmd_if_shell_data *cdata = data; - server_client_unref(cdata->client); + if (cdata->client != NULL) + server_client_unref(cdata->client); free(cdata->cmd_else); free(cdata->cmd_if);