Skip to content

Commit

Permalink
Merge pull request #36 Avoid sane_execvp in git rebase and `git s…
Browse files Browse the repository at this point in the history
…tash`

William Baker reported that the non-built-in rebase and stash fail to
run the post-command hook (which is important for VFS for Git, though).

The reason is that an `exec()` will replace the current process by the
newly-exec'ed one (our Windows-specific emulation cannot do that, and
does not even try, so this is only an issue on Linux/macOS). As a
consequence, not even the atexit() handlers are run, including the
one running the post-command hook.

To work around that, let's spawn the legacy rebase/stash and exit with
the reported exit code.
  • Loading branch information
derrickstolee authored and dscho committed May 25, 2019
2 parents d774d62 + 6c22444 commit 21746a2
Showing 1 changed file with 11 additions and 7 deletions.
18 changes: 11 additions & 7 deletions builtin/stash.c
Original file line number Diff line number Diff line change
Expand Up @@ -1564,13 +1564,17 @@ int cmd_stash(int argc, const char **argv, const char *prefix)
};

if (!use_builtin_stash()) {
const char *path = mkpath("%s/git-legacy-stash",
git_exec_path());

if (sane_execvp(path, (char **)argv) < 0)
die_errno(_("could not exec %s"), path);
else
BUG("sane_execvp() returned???");
struct argv_array args = ARGV_ARRAY_INIT;
int code;

argv_array_push(&args, mkpath("%s/git-legacy-stash",
git_exec_path()));
argv_array_pushv(&args, argv + 1);
code = run_command_v_opt(args.argv, 0);
if (code < 0)
die_errno(_("could not exec %s"), args.argv[0]);
argv_array_clear(&args);
exit(code);
}

prefix = setup_git_directory();
Expand Down

0 comments on commit 21746a2

Please sign in to comment.