Merge branch 'jk/tighten-alloc' into maint
* jk/tighten-alloc: (23 commits)
compat/mingw: brown paper bag fix for 50a6c8e
ewah: convert to REALLOC_ARRAY, etc
convert ewah/bitmap code to use xmalloc
diff_populate_gitlink: use a strbuf
transport_anonymize_url: use xstrfmt
git-compat-util: drop mempcpy compat code
sequencer: simplify memory allocation of get_message
test-path-utils: fix normalize_path_copy output buffer size
fetch-pack: simplify add_sought_entry
fast-import: simplify allocation in start_packfile
write_untracked_extension: use FLEX_ALLOC helper
prepare_{git,shell}_cmd: use argv_array
use st_add and st_mult for allocation size computation
convert trivial cases to FLEX_ARRAY macros
use xmallocz to avoid size arithmetic
convert trivial cases to ALLOC_ARRAY
convert manual allocations to argv_array
argv-array: add detach function
add helpers for allocating flex-array structs
harden REALLOC_ARRAY and xcalloc against size_t overflow
...
This commit is contained in:
@ -158,50 +158,41 @@ int sane_execvp(const char *file, char * const argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
static const char **prepare_shell_cmd(const char **argv)
|
||||
static const char **prepare_shell_cmd(struct argv_array *out, const char **argv)
|
||||
{
|
||||
int argc, nargc = 0;
|
||||
const char **nargv;
|
||||
|
||||
for (argc = 0; argv[argc]; argc++)
|
||||
; /* just counting */
|
||||
/* +1 for NULL, +3 for "sh -c" plus extra $0 */
|
||||
nargv = xmalloc(sizeof(*nargv) * (argc + 1 + 3));
|
||||
|
||||
if (argc < 1)
|
||||
if (!argv[0])
|
||||
die("BUG: shell command is empty");
|
||||
|
||||
if (strcspn(argv[0], "|&;<>()$`\\\"' \t\n*?[#~=%") != strlen(argv[0])) {
|
||||
#ifndef GIT_WINDOWS_NATIVE
|
||||
nargv[nargc++] = SHELL_PATH;
|
||||
argv_array_push(out, SHELL_PATH);
|
||||
#else
|
||||
nargv[nargc++] = "sh";
|
||||
argv_array_push(out, "sh");
|
||||
#endif
|
||||
nargv[nargc++] = "-c";
|
||||
argv_array_push(out, "-c");
|
||||
|
||||
if (argc < 2)
|
||||
nargv[nargc++] = argv[0];
|
||||
else {
|
||||
struct strbuf arg0 = STRBUF_INIT;
|
||||
strbuf_addf(&arg0, "%s \"$@\"", argv[0]);
|
||||
nargv[nargc++] = strbuf_detach(&arg0, NULL);
|
||||
}
|
||||
/*
|
||||
* If we have no extra arguments, we do not even need to
|
||||
* bother with the "$@" magic.
|
||||
*/
|
||||
if (!argv[1])
|
||||
argv_array_push(out, argv[0]);
|
||||
else
|
||||
argv_array_pushf(out, "%s \"$@\"", argv[0]);
|
||||
}
|
||||
|
||||
for (argc = 0; argv[argc]; argc++)
|
||||
nargv[nargc++] = argv[argc];
|
||||
nargv[nargc] = NULL;
|
||||
|
||||
return nargv;
|
||||
argv_array_pushv(out, argv);
|
||||
return out->argv;
|
||||
}
|
||||
|
||||
#ifndef GIT_WINDOWS_NATIVE
|
||||
static int execv_shell_cmd(const char **argv)
|
||||
{
|
||||
const char **nargv = prepare_shell_cmd(argv);
|
||||
trace_argv_printf(nargv, "trace: exec:");
|
||||
sane_execvp(nargv[0], (char **)nargv);
|
||||
free(nargv);
|
||||
struct argv_array nargv = ARGV_ARRAY_INIT;
|
||||
prepare_shell_cmd(&nargv, argv);
|
||||
trace_argv_printf(nargv.argv, "trace: exec:");
|
||||
sane_execvp(nargv.argv[0], (char **)nargv.argv);
|
||||
argv_array_clear(&nargv);
|
||||
return -1;
|
||||
}
|
||||
#endif
|
||||
@ -455,6 +446,7 @@ fail_pipe:
|
||||
{
|
||||
int fhin = 0, fhout = 1, fherr = 2;
|
||||
const char **sargv = cmd->argv;
|
||||
struct argv_array nargv = ARGV_ARRAY_INIT;
|
||||
|
||||
if (cmd->no_stdin)
|
||||
fhin = open("/dev/null", O_RDWR);
|
||||
@ -480,9 +472,9 @@ fail_pipe:
|
||||
fhout = dup(cmd->out);
|
||||
|
||||
if (cmd->git_cmd)
|
||||
cmd->argv = prepare_git_cmd(cmd->argv);
|
||||
cmd->argv = prepare_git_cmd(&nargv, cmd->argv);
|
||||
else if (cmd->use_shell)
|
||||
cmd->argv = prepare_shell_cmd(cmd->argv);
|
||||
cmd->argv = prepare_shell_cmd(&nargv, cmd->argv);
|
||||
|
||||
cmd->pid = mingw_spawnvpe(cmd->argv[0], cmd->argv, (char**) cmd->env,
|
||||
cmd->dir, fhin, fhout, fherr);
|
||||
@ -492,9 +484,7 @@ fail_pipe:
|
||||
if (cmd->clean_on_exit && cmd->pid >= 0)
|
||||
mark_child_for_cleanup(cmd->pid);
|
||||
|
||||
if (cmd->git_cmd)
|
||||
free(cmd->argv);
|
||||
|
||||
argv_array_clear(&nargv);
|
||||
cmd->argv = sargv;
|
||||
if (fhin != 0)
|
||||
close(fhin);
|
||||
|
Reference in New Issue
Block a user