aboutsummaryrefslogtreecommitdiffstats
path: root/refs.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2025-03-26 16:26:10 +0900
committerJunio C Hamano <gitster@pobox.com>2025-03-26 16:26:10 +0900
commitdef5e32bc56617c8f43ddc17ee5785abf1b865d4 (patch)
tree3b7df4907bfd10d3d718325fc9c9e66c6ed82b8e /refs.c
parentMerge branch 'sj/ref-consistency-checks-more' (diff)
parentrefs.c: stop matching non-directory prefixes in exclude patterns (diff)
downloadgit-def5e32bc56617c8f43ddc17ee5785abf1b865d4.tar.gz
git-def5e32bc56617c8f43ddc17ee5785abf1b865d4.zip
Merge branch 'tb/refs-exclude-fixes'
The refname exclusion logic in the packed-ref backend has been broken for some time, which confused upload-pack to advertise different set of refs. This has been corrected. * tb/refs-exclude-fixes: refs.c: stop matching non-directory prefixes in exclude patterns refs.c: remove empty '--exclude' patterns
Diffstat (limited to 'refs.c')
-rw-r--r--refs.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/refs.c b/refs.c
index 118465271d..50c3849845 100644
--- a/refs.c
+++ b/refs.c
@@ -1699,6 +1699,24 @@ struct ref_iterator *refs_ref_iterator_begin(
enum do_for_each_ref_flags flags)
{
struct ref_iterator *iter;
+ struct strvec normalized_exclude_patterns = STRVEC_INIT;
+
+ if (exclude_patterns) {
+ for (size_t i = 0; exclude_patterns[i]; i++) {
+ const char *pattern = exclude_patterns[i];
+ size_t len = strlen(pattern);
+ if (!len)
+ continue;
+
+ if (pattern[len - 1] == '/')
+ strvec_push(&normalized_exclude_patterns, pattern);
+ else
+ strvec_pushf(&normalized_exclude_patterns, "%s/",
+ pattern);
+ }
+
+ exclude_patterns = normalized_exclude_patterns.v;
+ }
if (!(flags & DO_FOR_EACH_INCLUDE_BROKEN)) {
static int ref_paranoia = -1;
@@ -1719,6 +1737,8 @@ struct ref_iterator *refs_ref_iterator_begin(
if (trim)
iter = prefix_ref_iterator_begin(iter, "", trim);
+ strvec_clear(&normalized_exclude_patterns);
+
return iter;
}