checkout: implement "-" abbreviation, add docs and tests
Have '-' mean the same as '@{-1}', i.e., the last branch we were on. Signed-off-by: Thomas Rast <trast@student.ethz.ch> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
d18ba22154
commit
696acf45f9
@ -133,6 +133,10 @@ the conflicted merge in the specified paths.
|
|||||||
+
|
+
|
||||||
When this parameter names a non-branch (but still a valid commit object),
|
When this parameter names a non-branch (but still a valid commit object),
|
||||||
your HEAD becomes 'detached'.
|
your HEAD becomes 'detached'.
|
||||||
|
+
|
||||||
|
As a special case, the "`@\{-N\}`" syntax for the N-th last branch
|
||||||
|
checks out the branch (instead of detaching). You may also specify
|
||||||
|
"`-`" which is synonymous with "`@\{-1\}`".
|
||||||
|
|
||||||
|
|
||||||
Detached HEAD
|
Detached HEAD
|
||||||
|
@ -679,6 +679,9 @@ int cmd_checkout(int argc, const char **argv, const char *prefix)
|
|||||||
arg = argv[0];
|
arg = argv[0];
|
||||||
has_dash_dash = (argc > 1) && !strcmp(argv[1], "--");
|
has_dash_dash = (argc > 1) && !strcmp(argv[1], "--");
|
||||||
|
|
||||||
|
if (!strcmp(arg, "-"))
|
||||||
|
arg = "@{-1}";
|
||||||
|
|
||||||
if (get_sha1(arg, rev)) {
|
if (get_sha1(arg, rev)) {
|
||||||
if (has_dash_dash) /* case (1) */
|
if (has_dash_dash) /* case (1) */
|
||||||
die("invalid reference: %s", arg);
|
die("invalid reference: %s", arg);
|
||||||
|
50
t/t2012-checkout-last.sh
Executable file
50
t/t2012-checkout-last.sh
Executable file
@ -0,0 +1,50 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
test_description='checkout can switch to last branch'
|
||||||
|
|
||||||
|
. ./test-lib.sh
|
||||||
|
|
||||||
|
test_expect_success 'setup' '
|
||||||
|
echo hello >world &&
|
||||||
|
git add world &&
|
||||||
|
git commit -m initial &&
|
||||||
|
git branch other &&
|
||||||
|
echo "hello again" >>world &&
|
||||||
|
git add world &&
|
||||||
|
git commit -m second
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success '"checkout -" does not work initially' '
|
||||||
|
test_must_fail git checkout -
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'first branch switch' '
|
||||||
|
git checkout other
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success '"checkout -" switches back' '
|
||||||
|
git checkout - &&
|
||||||
|
test "z$(git symbolic-ref HEAD)" = "zrefs/heads/master"
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success '"checkout -" switches forth' '
|
||||||
|
git checkout - &&
|
||||||
|
test "z$(git symbolic-ref HEAD)" = "zrefs/heads/other"
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'detach HEAD' '
|
||||||
|
git checkout $(git rev-parse HEAD)
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success '"checkout -" attaches again' '
|
||||||
|
git checkout - &&
|
||||||
|
test "z$(git symbolic-ref HEAD)" = "zrefs/heads/other"
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success '"checkout -" detaches again' '
|
||||||
|
git checkout - &&
|
||||||
|
test "z$(git rev-parse HEAD)" = "z$(git rev-parse other)" &&
|
||||||
|
test_must_fail git symbolic-ref HEAD
|
||||||
|
'
|
||||||
|
|
||||||
|
test_done
|
Loading…
Reference in New Issue
Block a user