Merge branch 'sm/show-superproject-while-conflicted' into maint

A corner-case bugfix.

* sm/show-superproject-while-conflicted:
  rev-parse: --show-superproject-working-tree should work during a merge
This commit is contained in:
Junio C Hamano 2018-11-21 22:57:48 +09:00
commit 9674e7a333
2 changed files with 17 additions and 1 deletions

View File

@ -1879,7 +1879,7 @@ const char *get_superproject_working_tree(void)
* We're only interested in the name after the tab. * We're only interested in the name after the tab.
*/ */
super_sub = strchr(sb.buf, '\t') + 1; super_sub = strchr(sb.buf, '\t') + 1;
super_sub_len = sb.buf + sb.len - super_sub - 1; super_sub_len = strlen(super_sub);
if (super_sub_len > cwd_len || if (super_sub_len > cwd_len ||
strcmp(&cwd[cwd_len - super_sub_len], super_sub)) strcmp(&cwd[cwd_len - super_sub_len], super_sub))

View File

@ -141,6 +141,22 @@ test_expect_success 'showing the superproject correctly' '
test_commit -C sub test_commit && test_commit -C sub test_commit &&
git -C super submodule add ../sub dir/sub && git -C super submodule add ../sub dir/sub &&
echo $(pwd)/super >expect && echo $(pwd)/super >expect &&
git -C super/dir/sub rev-parse --show-superproject-working-tree >out &&
test_cmp expect out &&
test_commit -C super submodule_add &&
git -C super checkout -b branch1 &&
git -C super/dir/sub checkout -b branch1 &&
test_commit -C super/dir/sub branch1_commit &&
git -C super add dir/sub &&
test_commit -C super branch1_commit &&
git -C super checkout -b branch2 master &&
git -C super/dir/sub checkout -b branch2 master &&
test_commit -C super/dir/sub branch2_commit &&
git -C super add dir/sub &&
test_commit -C super branch2_commit &&
test_must_fail git -C super merge branch1 &&
git -C super/dir/sub rev-parse --show-superproject-working-tree >out && git -C super/dir/sub rev-parse --show-superproject-working-tree >out &&
test_cmp expect out test_cmp expect out
' '