diff options
author | Brandon Williams <bmwill@google.com> | 2018-04-03 10:57:45 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2018-04-05 17:05:48 +0900 |
commit | 86238e07ef633f7488ac708578aaf71e4375c057 (patch) | |
tree | 9654c313bcfe887648594ac787b1e304b527a88e | |
parent | Git 2.14.3 (diff) | |
download | tgif-86238e07ef633f7488ac708578aaf71e4375c057.tar.xz |
commit: allow partial commits with relative paths
Commit 8894d53580 (commit: allow partial commits with relative paths,
2011-07-30) ensured that partial commits were allowed when a user
supplies a relative pathspec but then this was regressed in 5879f5684c
(remove prefix argument from pathspec_prefix, 2011-09-04) when the
prefix argument to 'pathspec_prefix' removed and the 'list_paths'
function wasn't properly adjusted to cope with the change, resulting in
over-eager pruning of the tree that is overlayed on the index.
This fixes the regression and adds a regression test so this can be
prevented in the future.
Signed-off-by: Brandon Williams <bmwill@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r-- | builtin/commit.c | 3 | ||||
-rwxr-xr-x | t/t7501-commit.sh | 12 |
2 files changed, 13 insertions, 2 deletions
diff --git a/builtin/commit.c b/builtin/commit.c index 1a0da71a43..12a0995b36 100644 --- a/builtin/commit.c +++ b/builtin/commit.c @@ -253,8 +253,7 @@ static int list_paths(struct string_list *list, const char *with_tree, if (with_tree) { char *max_prefix = common_prefix(pattern); - overlay_tree_on_index(&the_index, with_tree, - max_prefix ? max_prefix : prefix); + overlay_tree_on_index(&the_index, with_tree, max_prefix); free(max_prefix); } diff --git a/t/t7501-commit.sh b/t/t7501-commit.sh index fa61b1a4ee..9dbbd01fc0 100755 --- a/t/t7501-commit.sh +++ b/t/t7501-commit.sh @@ -52,6 +52,18 @@ test_expect_success PERL 'can use paths with --interactive' ' git reset --hard HEAD^ ' +test_expect_success 'removed files and relative paths' ' + test_when_finished "rm -rf foo" && + git init foo && + >foo/foo.txt && + git -C foo add foo.txt && + git -C foo commit -m first && + git -C foo rm foo.txt && + + mkdir -p foo/bar && + git -C foo/bar commit -m second ../foo.txt +' + test_expect_success 'using invalid commit with -C' ' test_must_fail git commit --allow-empty -C bogus ' |