summaryrefslogtreecommitdiff
path: root/lib/pipeline.c
diff options
context:
space:
mode:
authorColin Watson <cjwatson@debian.org>2003-08-04 18:36:30 +0000
committerColin Watson <cjwatson@debian.org>2003-08-04 18:36:30 +0000
commit0607e1b5716ead842bd0a5678a4369909c8b4e46 (patch)
treed84a8be62e68cc060fe7f0405c93d1975397000f /lib/pipeline.c
parent44e033dce9911c142935dee9a4ed6a5f972f70d9 (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.c3
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;
}