checkout: check_linked_checkout: improve "already checked out" aesthetic
authorEric Sunshine <sunshine@sunshineco.com>
Fri, 17 Jul 2015 23:00:01 +0000 (19:00 -0400)
committerJunio C Hamano <gitster@pobox.com>
Mon, 20 Jul 2015 18:29:24 +0000 (11:29 -0700)
When check_linked_checkout() discovers that the branch is already
checked out elsewhere, it emits the diagnostic:

'blorp' is already checked out at '/some/path/.git'

which is misleading since "checked out at" implies the working tree, but
".git" is the location of the repository administrative files. Fix by
dropping ".git" from the message.

Signed-off-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/checkout.c
index 177ad6a2d7c87cb0e9e2f569e05f26a28f78ee6f..de6619f4c503792ae727e3862a36712ca0e06e6a 100644 (file)
@@ -909,6 +909,7 @@ static void check_linked_checkout(const char *branch, const char *id)
        } else
                strbuf_addstr(&gitdir, get_git_common_dir());
        skip_prefix(branch, "refs/heads/", &branch);
        } else
                strbuf_addstr(&gitdir, get_git_common_dir());
        skip_prefix(branch, "refs/heads/", &branch);
+       strbuf_strip_suffix(&gitdir, ".git");
        die(_("'%s' is already checked out at '%s'"), branch, gitdir.buf);
 done:
        strbuf_release(&path);
        die(_("'%s' is already checked out at '%s'"), branch, gitdir.buf);
 done:
        strbuf_release(&path);