diff options
author | Junio C Hamano <gitster@pobox.com> | 2019-02-06 22:05:26 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2019-02-06 22:05:26 -0800 |
commit | 96e6547c2e4c137222c01582b52c0c974a02fd63 (patch) | |
tree | 3e5534ed73d44c1c96fe629b2e746f908fe5c63d /builtin/rebase.c | |
parent | Merge branch 'js/vsts-ci' (diff) | |
parent | rebase -x: sanity check command (diff) | |
download | tgif-96e6547c2e4c137222c01582b52c0c974a02fd63.tar.xz |
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
Diffstat (limited to 'builtin/rebase.c')
-rw-r--r-- | builtin/rebase.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/builtin/rebase.c b/builtin/rebase.c index 0b039319e1..b9d61771ab 100644 --- a/builtin/rebase.c +++ b/builtin/rebase.c @@ -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"); |