rebase (autostash): use an explicit OID to apply the stash

When `git stash apply <argument>` sees an argument that consists only of
digits, it tries to be smart and interpret it as `stash@{<number>}`.

Unfortunately, an all-digit hash (which is unlikely but still possible)
is therefore misinterpreted as `stash@{<n>}` reflog.

To prevent that from happening, let's append `^0` after the stash hash,
to make sure that it is interpreted as an OID rather than as a number.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Reviewed-by: SZEDER Gábor <szeder.dev@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Johannes Schindelin 2018-10-22 15:15:05 -07:00 committed by Junio C Hamano
parent 12aeb00a22
commit b98e914e46

View File

@ -252,6 +252,8 @@ static int apply_autostash(struct rebase_options *opts)
if (read_one(path, &autostash)) if (read_one(path, &autostash))
return error(_("Could not read '%s'"), path); return error(_("Could not read '%s'"), path);
/* Ensure that the hash is not mistaken for a number */
strbuf_addstr(&autostash, "^0");
argv_array_pushl(&stash_apply.args, argv_array_pushl(&stash_apply.args,
"stash", "apply", autostash.buf, NULL); "stash", "apply", autostash.buf, NULL);
stash_apply.git_cmd = 1; stash_apply.git_cmd = 1;