Make 'rerere forget' work from a subdirectory.
authorJohannes Sixt <j6t@kdbg.org>
Thu, 21 Jan 2010 08:23:48 +0000 (09:23 +0100)
committerJunio C Hamano <gitster@pobox.com>
Thu, 21 Jan 2010 08:42:20 +0000 (00:42 -0800)
It forgot to apply the prefix to the paths given on the command line.

[jc: added test]

Signed-off-by: Johannes Sixt <j6t@kdbg.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin-rerere.c
t/t2030-unresolve-info.sh

index 25f507a2f1df89919d966b7f586fd57d9c57a227..34f9acee910406c7ba0bf9eed76267a0cf8f46c2 100644 (file)
@@ -120,8 +120,10 @@ int cmd_rerere(int argc, const char **argv, const char *prefix)
        if (argc < 2)
                return rerere(flags);
 
-       if (!strcmp(argv[1], "forget"))
-               return rerere_forget(argv + 2);
+       if (!strcmp(argv[1], "forget")) {
+               const char **pathspec = get_pathspec(prefix, argv + 2);
+               return rerere_forget(pathspec);
+       }
 
        fd = setup_rerere(&merge_rr, flags);
        if (fd < 0)
index a38bd6df8490e8c54c29a54084f2a5c232f24e15..cb7effe0a3e38eeba92b43682de9be68e677099e 100755 (executable)
@@ -36,21 +36,22 @@ prime_resolve_undo () {
        test_must_fail git merge third^0 &&
        echo merge does not leave anything &&
        check_resolve_undo empty &&
-       echo different >file &&
-       git add file &&
+       echo different >fi/le &&
+       git add fi/le &&
        echo resolving records &&
-       check_resolve_undo recorded file initial:file second:file third:file
+       check_resolve_undo recorded fi/le initial:fi/le second:fi/le third:fi/le
 }
 
 test_expect_success setup '
-       test_commit initial file first &&
+       mkdir fi &&
+       test_commit initial fi/le first &&
        git branch side &&
        git branch another &&
-       test_commit second file second &&
+       test_commit second fi/le second &&
        git checkout side &&
-       test_commit third file third &&
+       test_commit third fi/le third &&
        git checkout another &&
-       test_commit fourth file fourth &&
+       test_commit fourth fi/le fourth &&
        git checkout master
 '
 
@@ -59,7 +60,7 @@ test_expect_success 'add records switch clears' '
        test_tick &&
        git commit -m merged &&
        echo committing keeps &&
-       check_resolve_undo kept file initial:file second:file third:file &&
+       check_resolve_undo kept fi/le initial:fi/le second:fi/le third:fi/le &&
        git checkout second^0 &&
        echo switching clears &&
        check_resolve_undo cleared
@@ -70,15 +71,15 @@ test_expect_success 'rm records reset clears' '
        test_tick &&
        git commit -m merged &&
        echo committing keeps &&
-       check_resolve_undo kept file initial:file second:file third:file &&
+       check_resolve_undo kept fi/le initial:fi/le second:fi/le third:fi/le &&
 
        echo merge clears upfront &&
        test_must_fail git merge fourth^0 &&
        check_resolve_undo nuked &&
 
-       git rm -f file &&
+       git rm -f fi/le &&
        echo resolving records &&
-       check_resolve_undo recorded file initial:file HEAD:file fourth:file &&
+       check_resolve_undo recorded fi/le initial:fi/le HEAD:fi/le fourth:fi/le &&
 
        git reset --hard &&
        echo resetting discards &&
@@ -90,7 +91,7 @@ test_expect_success 'plumbing clears' '
        test_tick &&
        git commit -m merged &&
        echo committing keeps &&
-       check_resolve_undo kept file initial:file second:file third:file &&
+       check_resolve_undo kept fi/le initial:fi/le second:fi/le third:fi/le &&
 
        echo plumbing clear &&
        git update-index --clear-resolve-undo &&
@@ -100,7 +101,7 @@ test_expect_success 'plumbing clears' '
 test_expect_success 'add records checkout -m undoes' '
        prime_resolve_undo &&
        git diff HEAD &&
-       git checkout --conflict=merge file &&
+       git checkout --conflict=merge fi/le &&
        echo checkout used the record and removed it &&
        check_resolve_undo removed &&
        echo the index and the work tree is unmerged again &&
@@ -110,12 +111,12 @@ test_expect_success 'add records checkout -m undoes' '
 
 test_expect_success 'unmerge with plumbing' '
        prime_resolve_undo &&
-       git update-index --unresolve file &&
+       git update-index --unresolve fi/le &&
        git ls-files -u >actual &&
        test $(wc -l <actual) = 3
 '
 
-test_expect_success 'rerere and rerere --forget' '
+test_expect_success 'rerere and rerere forget' '
        mkdir .git/rr-cache &&
        prime_resolve_undo &&
        echo record the resolution &&
@@ -123,20 +124,46 @@ test_expect_success 'rerere and rerere --forget' '
        rerere_id=$(cd .git/rr-cache && echo */postimage) &&
        rerere_id=${rerere_id%/postimage} &&
        test -f .git/rr-cache/$rerere_id/postimage &&
-       git checkout -m file &&
+       git checkout -m fi/le &&
        echo resurrect the conflict &&
-       grep "^=======" file &&
+       grep "^=======" fi/le &&
        echo reresolve the conflict &&
        git rerere &&
-       test "z$(cat file)" = zdifferent &&
+       test "z$(cat fi/le)" = zdifferent &&
        echo register the resolution again &&
-       git add file &&
-       check_resolve_undo kept file initial:file second:file third:file &&
+       git add fi/le &&
+       check_resolve_undo kept fi/le initial:fi/le second:fi/le third:fi/le &&
        test -z "$(git ls-files -u)" &&
-       git rerere forget file &&
+       git rerere forget fi/le &&
        ! test -f .git/rr-cache/$rerere_id/postimage &&
        tr "\0" "\n" <.git/MERGE_RR >actual &&
-       echo "$rerere_id        file" >expect &&
+       echo "$rerere_id        fi/le" >expect &&
+       test_cmp expect actual
+'
+
+test_expect_success 'rerere and rerere forget (subdirectory)' '
+       rm -fr .git/rr-cache &&
+       mkdir .git/rr-cache &&
+       prime_resolve_undo &&
+       echo record the resolution &&
+       (cd fi && git rerere) &&
+       rerere_id=$(cd .git/rr-cache && echo */postimage) &&
+       rerere_id=${rerere_id%/postimage} &&
+       test -f .git/rr-cache/$rerere_id/postimage &&
+       (cd fi && git checkout -m le) &&
+       echo resurrect the conflict &&
+       grep "^=======" fi/le &&
+       echo reresolve the conflict &&
+       (cd fi && git rerere) &&
+       test "z$(cat fi/le)" = zdifferent &&
+       echo register the resolution again &&
+       (cd fi && git add le) &&
+       check_resolve_undo kept fi/le initial:fi/le second:fi/le third:fi/le &&
+       test -z "$(git ls-files -u)" &&
+       (cd fi && git rerere forget le) &&
+       ! test -f .git/rr-cache/$rerere_id/postimage &&
+       tr "\0" "\n" <.git/MERGE_RR >actual &&
+       echo "$rerere_id        fi/le" >expect &&
        test_cmp expect actual
 '