As I was advocating for this series to go into 'next' without a large refactor of this series, I'll put my money were my mouth is and try to make the cleanups and fixes required, though without trying to avoid further external process calls, or changing the series around too much. One thing to consider here is that we have a GSoC project planned based on 'git stash'. If we can't get this to 'next' soon, I'd vote for taking that project out of this years GSoC, and maybe try again next year, if nobody implemented the feature in the meantime. One thing that came up in the latest reviews, was to keep the stash script intact throughout the series, and to not re-introduce it after deleting it. I did however not do that, as that would make the range-diff quite a bit harder to read. In addition removing the script bit by bit also allowed us to find the precise commit in which the missing 'discard_cache()' bug was introduced, which made it a bit easier to pinpoint where the bug comes from imo. Additionally now that we established that we re-introduce the same shell script in a previous review, it's now easy to see that we're still doing the right thing in this patch series. So what did change in this round? - Squashed Johannes Sixt patch into the relevant patch - Pulled out the test from Matthew Kraai into a separate patch, and squashed the rest of the patch into the relevant commit (The two changes above were credited by adding Helped-by trailers) - Fixed the missing discard_cache before reset --hard and apply --index -R. t3903-stash.sh --stress now passed more than 250 iterations without error. - Addressed my and Junios review comments on the previous round - Some small fixups range-diff below: 1: 0c1599c33c ! 1: baa5d369e4 strbuf.c: add `strbuf_join_argv()` @@ -6,7 +6,7 @@ into a strbuf. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/strbuf.c b/strbuf.c --- a/strbuf.c 2: bfc3fe33f6 ! 2: 08bb77502c strbuf.c: add `strbuf_insertf()` and `strbuf_vinsertf()` @@ -7,7 +7,8 @@ Original-idea-by: Johannes Schindelin <johannes.schindelin@xxxxxx> Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Helped-by: Johannes Sixt <j6t@xxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/strbuf.c b/strbuf.c --- a/strbuf.c @@ -37,7 +38,7 @@ + memmove(sb->buf + pos + len, sb->buf + pos, sb->len - pos); + /* vsnprintf() will append a NUL, overwriting one of our characters */ + save = sb->buf[pos + len]; -+ len2 = vsnprintf(sb->buf + pos, sb->alloc - sb->len, fmt, ap); ++ len2 = vsnprintf(sb->buf + pos, len + 1, fmt, ap); + sb->buf[pos + len] = save; + if (len2 != len) + BUG("your vsnprintf is broken (returns inconsistent lengths)"); 3: 97f56073ce ! 3: 2956b2bd27 ident: add the ability to provide a "fallback identity" @@ -12,7 +12,9 @@ function. Signed-off-by: Johannes Schindelin <johannes.schindelin@xxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + [tg: add docs; make it a bug to call the function before other + functions in the ident API] + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/cache.h b/cache.h --- a/cache.h @@ -21,6 +23,10 @@ extern const char *git_pager(int stdout_is_tty); extern int is_terminal_dumb(void); extern int git_ident_config(const char *, const char *, void *); ++/* ++ * Prepare an ident to fall back on if the user didn't configure it. ++ * Must be called before any other function from the ident API. ++ */ +void prepare_fallback_ident(const char *name, const char *email); extern void reset_ident_date(void); @@ -35,7 +41,9 @@ +static void set_env_if(const char *key, const char *value, int *given, int bit) +{ -+ if ((*given & bit) || getenv(key)) ++ if (*given & bit) ++ BUG("%s was checked before prepare_fallback got called", key); ++ if (getenv(key)) + return; /* nothing to do */ + setenv(key, value, 0); + *given |= bit; 4: 0654fe70a8 ! 4: 55db527e68 stash: improve option parsing test coverage @@ -8,7 +8,7 @@ Signed-off-by: Joel Teichroeb <joel@xxxxxxxxxxxxx> Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/t/t3903-stash.sh b/t/t3903-stash.sh --- a/t/t3903-stash.sh 5: caf7bc3cc6 ! 5: 7a5eb3a9e8 t3903: modernize style @@ -6,7 +6,7 @@ long lines. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/t/t3903-stash.sh b/t/t3903-stash.sh --- a/t/t3903-stash.sh 26: ed5d77f7d3 ! 6: 453543916d stash: fix segmentation fault when files were added with intent @@ -1,45 +1,17 @@ Author: Matthew Kraai <mkraai@xxxxxxxxxxx> - stash: fix segmentation fault when files were added with intent + t3903: add test for --intent-to-add file - After `git add -N <file>`, the index is in a special state. A state for - which the built-in stash was not prepared, as it failed to initialize - the `rev` structure in that case before using `&rev.pending`. If - `reset_tree()` returns a non-zero value, `stash_working_tree()` - calls `object_array_clear()` with `&rev.pending`. If `rev` is not - initialized, this causes a segmentation fault. + Add a test showing the 'git stash' behaviour with a file that has been + added with 'git add --intent-to-add'. Stash fails to stash the file, + so the purpose of this test is mainly to make sure git doesn't crash, + but exits normally in this situation. - Prevent this by initializing `rev` before calling `reset_tree()`. - - This fixes https://github.com/git-for-windows/git/issues/2006. - - [jes: modified the commit message in preparation for sending this patch - to the Git mailing list.] + [tg: pulled the test out into a separate commit] Signed-off-by: Matthew Kraai <mkraai@xxxxxxxxxxx> Signed-off-by: Johannes Schindelin <johannes.schindelin@xxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> - - diff --git a/builtin/stash.c b/builtin/stash.c - --- a/builtin/stash.c - +++ b/builtin/stash.c -@@ - struct strbuf diff_output = STRBUF_INIT; - struct index_state istate = { NULL }; - -+ init_revisions(&rev, NULL); -+ - set_alternate_index_output(stash_index_path.buf); - if (reset_tree(&info->i_tree, 0, 0)) { - ret = -1; -@@ - } - set_alternate_index_output(NULL); - -- init_revisions(&rev, NULL); - rev.prune_data = ps; - rev.diffopt.output_format = DIFF_FORMAT_CALLBACK; - rev.diffopt.format_callback = add_diff_to_buf; + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/t/t3903-stash.sh b/t/t3903-stash.sh --- a/t/t3903-stash.sh 6: ee77c6a603 ! 7: 587d3e8e49 stash: rename test cases to be more descriptive @@ -6,7 +6,7 @@ characters per line. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/t/t3903-stash.sh b/t/t3903-stash.sh --- a/t/t3903-stash.sh 7: cb2152ebce ! 8: b03c17e744 stash: add tests for `git stash show` config @@ -7,7 +7,7 @@ and `stash.showPatch` are unset or set to true / false. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/t/t3907-stash-show-config.sh b/t/t3907-stash-show-config.sh new file mode 100755 8: 983084d9ec ! 9: 010c5f4ce2 stash: mention options in `show` synopsis @@ -6,7 +6,7 @@ option known to `git diff`. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/Documentation/git-stash.txt b/Documentation/git-stash.txt --- a/Documentation/git-stash.txt 9: f6bbd78127 ! 10: 45670448e8 stash: convert apply to builtin @@ -17,7 +17,7 @@ Signed-off-by: Joel Teichroeb <joel@xxxxxxxxxxxxx> Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/.gitignore b/.gitignore --- a/.gitignore @@ -96,7 +96,6 @@ + * i_tree is set to the index tree + * u_tree is set to the untracked files tree + */ -+ +struct stash_info { + struct object_id w_commit; + struct object_id b_commit; @@ -357,7 +356,7 @@ + if (refresh_cache(REFRESH_QUIET)) + return -1; + -+ if (write_cache_as_tree(&c_tree, 0, NULL) || reset_tree(&c_tree, 0, 0)) ++ if (write_cache_as_tree(&c_tree, 0, NULL)) + return error(_("cannot apply a stash in the middle of a merge")); + + if (index) { 10: cdca49bc4c ! 11: cea038dd3c stash: convert drop and clear to builtin @@ -13,7 +13,7 @@ Signed-off-by: Joel Teichroeb <joel@xxxxxxxxxxxxx> Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c @@ -128,9 +128,9 @@ +static void assert_stash_ref(struct stash_info *info) +{ + if (!info->is_stash_ref) { -+ free_stash_info(info); + error(_("'%s' is not a stash reference"), info->revision.buf); -+ exit(128); ++ free_stash_info(info); ++ exit(1); + } +} + 11: f596f3366c ! 12: deb4f6cee9 stash: convert branch to builtin @@ -11,7 +11,7 @@ Signed-off-by: Joel Teichroeb <joel@xxxxxxxxxxxxx> Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c 12: e1d01876a4 ! 13: 75f9431abf stash: convert pop to builtin @@ -8,7 +8,7 @@ Signed-off-by: Joel Teichroeb <joel@xxxxxxxxxxxxx> Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c 13: 9b77b07ba4 ! 14: f6814704ee stash: convert list to builtin @@ -6,7 +6,7 @@ from the shell script. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c 14: b4493f269e ! 15: d1098f2c8e stash: convert show to builtin @@ -11,7 +11,7 @@ further to `git diff`. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c 15: 847eb0b0a8 ! 16: 9706cab487 stash: convert store to builtin @@ -6,7 +6,7 @@ from the shell script. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c 16: 1f5a011d90 ! 17: a5d6a3bd14 stash: convert create to builtin @@ -5,7 +5,8 @@ Add stash create to the helper. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Helped-by: Matthew Kraai <mkraai@xxxxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c @@ -45,11 +46,7 @@ + for (i = 0; i < q->nr; i++) { + strbuf_addstr(data, q->queue[i]->one->path); + -+ /* -+ * The reason we add "0" at the end of this strbuf -+ * is because we will pass the output further to -+ * "git update-index -z ...". -+ */ ++ /* NUL-terminate: will be fed to update-index -z */ + strbuf_addch(data, '\0'); + } +} @@ -98,7 +95,7 @@ + found++; + strbuf_addstr(untracked_files, ent->name); + /* NUL-terminate: will be fed to update-index -z */ -+ strbuf_addch(untracked_files, 0); ++ strbuf_addch(untracked_files, '\0'); + } + free(ent); + } @@ -278,6 +275,8 @@ + struct strbuf out = STRBUF_INIT; + struct strbuf diff_output = STRBUF_INIT; + ++ init_revisions(&rev, NULL); ++ + set_alternate_index_output(stash_index_path.buf); + if (reset_tree(&info->i_tree, 0, 0)) { + ret = -1; @@ -285,7 +284,6 @@ + } + set_alternate_index_output(NULL); + -+ init_revisions(&rev, NULL); + rev.prune_data = ps; + rev.diffopt.output_format = DIFF_FORMAT_CALLBACK; + rev.diffopt.format_callback = add_diff_to_buf; @@ -471,7 +469,6 @@ + memset(&ps, 0, sizeof(ps)); + strbuf_addstr(&stash_msg_buf, stash_msg); + ret = do_create_stash(ps, &stash_msg_buf, include_untracked, 0, &info); -+ + if (!ret) + printf_ln("%s", oid_to_hex(&info.w_commit)); + 17: fa38428f76 ! 18: 3065f08c65 stash: convert push to builtin @@ -5,7 +5,7 @@ Add stash push to the helper. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c @@ -67,9 +67,9 @@ - ret = do_create_stash(ps, &stash_msg_buf, include_untracked, 0, &info); + ret = do_create_stash(ps, &stash_msg_buf, include_untracked, 0, &info, + NULL); - if (!ret) printf_ln("%s", oid_to_hex(&info.w_commit)); + @@ return ret < 0; } @@ -158,6 +158,7 @@ + goto done; + } + } ++ discard_cache(); + if (ps.nr) { + struct child_process cp_add = CHILD_PROCESS_INIT; + struct child_process cp_diff = CHILD_PROCESS_INIT; 18: 9a95010a11 ! 19: 31dd0edc0c stash: make push -q quiet @@ -8,7 +8,7 @@ `--quiet` or `-q` is specified. Add tests for `--quiet`. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c @@ -118,9 +118,9 @@ ret = do_create_stash(ps, &stash_msg_buf, include_untracked, 0, &info, - NULL); + NULL, 0); - if (!ret) printf_ln("%s", oid_to_hex(&info.w_commit)); + @@ if (!reflog_exists(ref_stash) && do_clear_stash()) { 19: cf5b27d699 ! 20: f5644a4fdc stash: convert save to builtin @@ -8,7 +8,7 @@ `no_changes()`). Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c 20: 168e6cff5e ! 21: 367511ab8f stash: optimize `get_untracked_files()` and `check_changes()` @@ -29,10 +29,8 @@ This way `check_changes()` and `get_untracked files()` are called only one time. - https://public-inbox.org/git/20180818223329.GJ11326@xxxxxxxxxxxxxxxxxxxxxxxx/ - Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c @@ -49,7 +47,6 @@ * > 0 if there are changes. */ -static int check_changes(struct pathspec ps, int include_untracked) -+ +static int check_changes_tracked_files(struct pathspec ps) { int result; @@ -70,7 +67,6 @@ + * The function will fill `untracked_files` with the names of untracked files + * It will return 1 if there were any changes and 0 if there were not. + */ -+ +static int check_changes(struct pathspec ps, int include_untracked, + struct strbuf *untracked_files) +{ @@ -115,15 +111,13 @@ 0); memset(&ps, 0, sizeof(ps)); -- strbuf_addstr(&stash_msg_buf, stash_msg); -- ret = do_create_stash(ps, &stash_msg_buf, include_untracked, 0, &info, -- NULL, 0); + if (!check_changes_tracked_files(ps)) + return 0; - -- if (!ret) -+ strbuf_addstr(&stash_msg_buf, stash_msg); -+ if (!(ret = do_create_stash(ps, &stash_msg_buf, 0, 0, &info, NULL, 0))) ++ + strbuf_addstr(&stash_msg_buf, stash_msg); + ret = do_create_stash(ps, &stash_msg_buf, include_untracked, 0, &info, + NULL, 0); +@@ printf_ln("%s", oid_to_hex(&info.w_commit)); strbuf_release(&stash_msg_buf); 21: 559edead8f ! 22: 376bb4adc9 stash: replace all `write-tree` child processes with API calls @@ -2,10 +2,11 @@ stash: replace all `write-tree` child processes with API calls - This commit replaces spawning `git write-tree` with API calls. + Avoid spawning write-tree child processes by replacing the calls with + in-core API calls. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash--helper.c b/builtin/stash--helper.c --- a/builtin/stash--helper.c @@ -100,8 +101,8 @@ struct strbuf diff_output = STRBUF_INIT; + struct index_state istate = { NULL }; - set_alternate_index_output(stash_index_path.buf); - if (reset_tree(&info->i_tree, 0, 0)) { + init_revisions(&rev, NULL); + @@ goto done; } 22: 51809c70ca ! 23: 56a5ce2aeb stash: convert `stash--helper.c` into `stash.c` @@ -13,7 +13,7 @@ called directly and not by a shell script. Signed-off-by: Paul-Sebastian Ungureanu <ungureanupaulsebastian@xxxxxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/.gitignore b/.gitignore --- a/.gitignore @@ -273,9 +273,11 @@ return 0; - strbuf_addstr(&stash_msg_buf, stash_msg); - if (!(ret = do_create_stash(ps, &stash_msg_buf, 0, 0, &info, NULL, 0))) +- ret = do_create_stash(ps, &stash_msg_buf, include_untracked, 0, &info, ++ ret = do_create_stash(ps, &stash_msg_buf, 0, 0, &info, + NULL, 0); + if (!ret) printf_ln("%s", oid_to_hex(&info.w_commit)); - @@ OPT_END() }; 23: c907fe1cd6 ! 24: 830c1d6dbe stash: add back the original, scripted `git stash` @@ -9,7 +9,7 @@ scripted `git stash` when `stash.useBuiltin=false`. Signed-off-by: Johannes Schindelin <johannes.schindelin@xxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/git-stash.sh b/git-stash.sh new file mode 100755 24: 26799a208f ! 25: 00fb753d5e stash: optionally use the scripted version again @@ -17,7 +17,7 @@ code 129 for `git stash -h`. Signed-off-by: Johannes Schindelin <johannes.schindelin@xxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/.gitignore b/.gitignore --- a/.gitignore 25: bec65d5b78 ! 26: 49b7f82db9 tests: add a special setup where stash.useBuiltin is off @@ -12,7 +12,7 @@ 2018-11-14). Signed-off-by: Johannes Schindelin <johannes.schindelin@xxxxxx> - Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> + Signed-off-by: Thomas Gummerer <t.gummerer@xxxxxxxxx> diff --git a/builtin/stash.c b/builtin/stash.c --- a/builtin/stash.c 27: 8187099d9c < -: ---------- strbuf_vinsertf: provide the correct buffer size to vsnprintf Joel Teichroeb (5): stash: improve option parsing test coverage stash: convert apply to builtin stash: convert drop and clear to builtin stash: convert branch to builtin stash: convert pop to builtin Johannes Schindelin (4): ident: add the ability to provide a "fallback identity" stash: add back the original, scripted `git stash` stash: optionally use the scripted version again tests: add a special setup where stash.useBuiltin is off Matthew Kraai (1): t3903: add test for --intent-to-add file Paul-Sebastian Ungureanu (17): sha1-name.c: add `get_oidf()` which acts like `get_oid()` strbuf.c: add `strbuf_join_argv()` strbuf.c: add `strbuf_insertf()` and `strbuf_vinsertf()` t3903: modernize style stash: rename test cases to be more descriptive stash: add tests for `git stash show` config stash: mention options in `show` synopsis stash: convert list to builtin stash: convert show to builtin stash: convert store to builtin stash: convert create to builtin stash: convert push to builtin stash: make push -q quiet stash: convert save to builtin stash: optimize `get_untracked_files()` and `check_changes()` stash: replace all `write-tree` child processes with API calls stash: convert `stash--helper.c` into `stash.c` .gitignore | 1 + Documentation/git-stash.txt | 4 +- Makefile | 3 +- builtin.h | 1 + builtin/stash.c | 1633 +++++++++++++++++++++++++++ cache.h | 6 + git-stash.sh => git-legacy-stash.sh | 34 +- git-sh-setup.sh | 1 + git.c | 6 + ident.c | 22 + sha1-name.c | 19 + strbuf.c | 51 + strbuf.h | 16 + t/README | 4 + t/t3903-stash.sh | 200 ++-- t/t3907-stash-show-config.sh | 83 ++ 16 files changed, 2012 insertions(+), 72 deletions(-) create mode 100644 builtin/stash.c rename git-stash.sh => git-legacy-stash.sh (97%) create mode 100755 t/t3907-stash-show-config.sh -- 2.21.0.rc2.291.g17236886c5