diff options
author | Colin Watson <cjwatson@debian.org> | 2003-08-04 18:36:30 +0000 |
---|---|---|
committer | Colin Watson <cjwatson@debian.org> | 2003-08-04 18:36:30 +0000 |
commit | 0607e1b5716ead842bd0a5678a4369909c8b4e46 (patch) | |
tree | d84a8be62e68cc060fe7f0405c93d1975397000f /lib/pipeline.c | |
parent | 44e033dce9911c142935dee9a4ed6a5f972f70d9 (diff) |
* lib/pipeline.c (command_dup): Terminate argv with a NULL.
(command_dup, command_arg): Assert that argc < argv_max after
changing either.
Diffstat (limited to 'lib/pipeline.c')
-rw-r--r-- | lib/pipeline.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/lib/pipeline.c b/lib/pipeline.c index 42004d75..0015cde1 100644 --- a/lib/pipeline.c +++ b/lib/pipeline.c @@ -228,10 +228,12 @@ command *command_dup (command *cmd) newcmd->name = xstrdup (cmd->name); newcmd->argc = cmd->argc; newcmd->argv_max = cmd->argv_max; + assert (newcmd->argc < newcmd->argv_max); newcmd->argv = xmalloc (newcmd->argv_max * sizeof *newcmd->argv); for (i = 0; i < cmd->argc; ++i) newcmd->argv[i] = xstrdup (cmd->argv[i]); + newcmd->argv[cmd->argc] = NULL; return newcmd; } @@ -245,6 +247,7 @@ void command_arg (command *cmd, const char *arg) } cmd->argv[cmd->argc++] = xstrdup (arg); + assert (cmd->argc < cmd->argv_max); cmd->argv[cmd->argc] = NULL; } |