]> granicus.if.org Git - git/commitdiff
refs: use skip_prefix() in ref_is_hidden()
authorChristian Couder <christian.couder@gmail.com>
Sat, 22 Jul 2017 04:39:12 +0000 (06:39 +0200)
committerJunio C Hamano <gitster@pobox.com>
Mon, 24 Jul 2017 21:48:59 +0000 (14:48 -0700)
This is shorter, makes the logic a bit easier to follow, and is
perhaps a bit faster too.

The logic is to make the final decision only when "subject" is there,
its early part matches "match", and the match is at the slash
boundary (or the whole thing).

Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Reviewed-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
refs.c

diff --git a/refs.c b/refs.c
index 2d717742d603d1bd7f6c1644c72ed2e2fd5ecb2f..dcfa4dee7a59c86cd80a7733c44dfb44b51405a0 100644 (file)
--- a/refs.c
+++ b/refs.c
@@ -1066,7 +1066,7 @@ int ref_is_hidden(const char *refname, const char *refname_full)
                const char *match = hide_refs->items[i].string;
                const char *subject;
                int neg = 0;
-               int len;
+               const char *p;
 
                if (*match == '!') {
                        neg = 1;
@@ -1081,10 +1081,9 @@ int ref_is_hidden(const char *refname, const char *refname_full)
                }
 
                /* refname can be NULL when namespaces are used. */
-               if (!subject || !starts_with(subject, match))
-                       continue;
-               len = strlen(match);
-               if (!subject[len] || subject[len] == '/')
+               if (subject &&
+                   skip_prefix(subject, match, &p) &&
+                   (!*p || *p == '/'))
                        return !neg;
        }
        return 0;