summaryrefslogtreecommitdiffstats
path: root/sha1_name.c
diff options
context:
space:
mode:
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>2010-12-15 10:02:54 +0100
committerJunio C Hamano <gitster@pobox.com>2010-12-16 22:11:42 +0100
commit4322842acfaace812308f8aec0fe39a358f3c6f2 (patch)
tree31cb3e55eccfa2f4aa3d58985866a3870f85faf0 /sha1_name.c
parentget_sha1: support $commit^{/regex} syntax (diff)
downloadgit-4322842acfaace812308f8aec0fe39a358f3c6f2.tar.xz
git-4322842acfaace812308f8aec0fe39a358f3c6f2.zip
get_sha1: handle special case $commit^{/}
Empty regex pattern should always match. But the exact behavior of regexec() may vary. Because it always matches anyway, we can just return 'matched' without calling regex machinery. Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'sha1_name.c')
-rw-r--r--sha1_name.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/sha1_name.c b/sha1_name.c
index 1ba4bc3b68..c5c59ced7f 100644
--- a/sha1_name.c
+++ b/sha1_name.c
@@ -599,6 +599,13 @@ static int peel_onion(const char *name, int len, unsigned char *sha1)
int ret;
struct commit_list *list = NULL;
+ /*
+ * $commit^{/}. Some regex implementation may reject.
+ * We don't need regex anyway. '' pattern always matches.
+ */
+ if (sp[1] == '}')
+ return 0;
+
prefix = xstrndup(sp + 1, name + len - 1 - (sp + 1));
commit_list_insert((struct commit *)o, &list);
ret = get_sha1_oneline(prefix, sha1, list);