Don't leak string arguments and options.

This commit is contained in:
Nicholas Marriott 2009-02-16 19:29:17 +00:00
parent b03783efad
commit 5a6ed33a3f
2 changed files with 13 additions and 2 deletions

View File

@ -1,4 +1,4 @@
/* $Id: cmd-string.c,v 1.12 2009-02-08 16:38:19 nicm Exp $ */ /* $Id: cmd-string.c,v 1.13 2009-02-16 19:29:17 nicm Exp $ */
/* /*
* Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net>
@ -94,6 +94,7 @@ cmd_string_parse(const char *s, struct cmd_list **cmdlist, char **cause)
buf = xrealloc(buf, 1, len + strlen(t) + 1); buf = xrealloc(buf, 1, len + strlen(t) + 1);
strlcpy(buf + len, t, strlen(t) + 1); strlcpy(buf + len, t, strlen(t) + 1);
len += strlen(t); len += strlen(t);
xfree(t);
have_arg = 1; have_arg = 1;
break; break;
@ -103,6 +104,7 @@ cmd_string_parse(const char *s, struct cmd_list **cmdlist, char **cause)
buf = xrealloc(buf, 1, len + strlen(t) + 1); buf = xrealloc(buf, 1, len + strlen(t) + 1);
strlcpy(buf + len, t, strlen(t) + 1); strlcpy(buf + len, t, strlen(t) + 1);
len += strlen(t); len += strlen(t);
xfree(t);
have_arg = 1; have_arg = 1;
break; break;
@ -145,6 +147,10 @@ cmd_string_parse(const char *s, struct cmd_list **cmdlist, char **cause)
if (*cmdlist == NULL) if (*cmdlist == NULL)
goto out; goto out;
do
xfree(argv[argc - 1]);
while (--argc > 0);
rval = 0; rval = 0;
goto out; goto out;
default: default:

View File

@ -1,4 +1,4 @@
/* $Id: server.c,v 1.122 2009-02-16 18:51:39 nicm Exp $ */ /* $Id: server.c,v 1.123 2009-02-16 19:29:17 nicm Exp $ */
/* /*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@ -336,6 +336,11 @@ server_main(const char *srv_path, int srv_fd)
close(srv_fd); close(srv_fd);
unlink(srv_path); unlink(srv_path);
options_free(&global_options);
options_free(&global_window_options);
if (server_password != NULL)
xfree(server_password);
return (0); return (0);
} }