get_sha1: teach ":$n:<path>" the same relative path logic
We taught the object name parser to take ":./<path>", ":../<path>", etc. and understand them to be relative to the current working directory. Given that ":<path>" is just a short-hand for ":0:<path>" (i.e. "take stage #0 of that path"), we should allow ":$n:<path>" to interpret them the same way. Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
979f792951
commit
3d6e0f745e
12
sha1_name.c
12
sha1_name.c
@ -1091,17 +1091,19 @@ int get_sha1_with_context_1(const char *name, unsigned char *sha1,
|
||||
return get_sha1_oneline(name + 2, sha1);
|
||||
if (namelen < 3 ||
|
||||
name[2] != ':' ||
|
||||
name[1] < '0' || '3' < name[1]) {
|
||||
name[1] < '0' || '3' < name[1])
|
||||
cp = name + 1;
|
||||
new_path = resolve_relative_path(cp);
|
||||
if (new_path)
|
||||
cp = new_path;
|
||||
}
|
||||
else {
|
||||
stage = name[1] - '0';
|
||||
cp = name + 3;
|
||||
}
|
||||
new_path = resolve_relative_path(cp);
|
||||
if (!new_path) {
|
||||
namelen = namelen - (cp - name);
|
||||
} else {
|
||||
cp = new_path;
|
||||
namelen = strlen(cp);
|
||||
}
|
||||
|
||||
strncpy(oc->path, cp,
|
||||
sizeof(oc->path));
|
||||
|
@ -34,6 +34,8 @@ test_expect_success 'correct file objects' '
|
||||
test_expect_success 'correct relative file objects (0)' '
|
||||
git rev-parse :file.txt >expected &&
|
||||
git rev-parse :./file.txt >result &&
|
||||
test_cmp expected result &&
|
||||
git rev-parse :0:./file.txt >result &&
|
||||
test_cmp expected result
|
||||
'
|
||||
|
||||
@ -68,6 +70,28 @@ test_expect_success 'correct relative file objects (4)' '
|
||||
)
|
||||
'
|
||||
|
||||
test_expect_success 'correct relative file objects (5)' '
|
||||
git rev-parse :subdir/file.txt >expected &&
|
||||
(
|
||||
cd subdir &&
|
||||
git rev-parse :./file.txt >result &&
|
||||
test_cmp ../expected result &&
|
||||
git rev-parse :0:./file.txt >result &&
|
||||
test_cmp ../expected result
|
||||
)
|
||||
'
|
||||
|
||||
test_expect_success 'correct relative file objects (6)' '
|
||||
git rev-parse :file.txt >expected &&
|
||||
(
|
||||
cd subdir &&
|
||||
git rev-parse :../file.txt >result &&
|
||||
test_cmp ../expected result &&
|
||||
git rev-parse :0:../file.txt >result &&
|
||||
test_cmp ../expected result
|
||||
)
|
||||
'
|
||||
|
||||
test_expect_success 'incorrect revision id' '
|
||||
test_must_fail git rev-parse foobar:file.txt 2>error &&
|
||||
grep "Invalid object name '"'"'foobar'"'"'." error &&
|
||||
|
Loading…
Reference in New Issue
Block a user