Merge branch 'pw/rebase-x-sanity-check'
"git rebase -x $cmd" did not reject multi-line command, even though the command is incapable of handling such a command. It now is rejected upfront. * pw/rebase-x-sanity-check: rebase -x: sanity check command
This commit is contained in:
@ -1005,6 +1005,19 @@ static void set_reflog_action(struct rebase_options *options)
|
||||
strbuf_release(&buf);
|
||||
}
|
||||
|
||||
static int check_exec_cmd(const char *cmd)
|
||||
{
|
||||
if (strchr(cmd, '\n'))
|
||||
return error(_("exec commands cannot contain newlines"));
|
||||
|
||||
/* Does the command consist purely of whitespace? */
|
||||
if (!cmd[strspn(cmd, " \t\r\f\v")])
|
||||
return error(_("empty exec command"));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
int cmd_rebase(int argc, const char **argv, const char *prefix)
|
||||
{
|
||||
struct rebase_options options = {
|
||||
@ -1348,6 +1361,10 @@ int cmd_rebase(int argc, const char **argv, const char *prefix)
|
||||
}
|
||||
}
|
||||
|
||||
for (i = 0; i < exec.nr; i++)
|
||||
if (check_exec_cmd(exec.items[i].string))
|
||||
exit(1);
|
||||
|
||||
if (!(options.flags & REBASE_NO_QUIET))
|
||||
argv_array_push(&options.git_am_opts, "-q");
|
||||
|
||||
|
Reference in New Issue
Block a user