summaryrefslogtreecommitdiff
path: root/remote.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2020-12-23 21:59:46 (GMT)
committerJunio C Hamano <gitster@pobox.com>2020-12-23 21:59:46 (GMT)
commit73583204d9114b4c86453f5ae74397d9f951072f (patch)
tree3283adb168a8aaa8514c5f4262d20f2d3e0d471e /remote.c
parent7a5026529529e811b41de02ca12aa6c8ff3d11c5 (diff)
parent773c694142c630ccbf161287b5c2a7ad13e8ca9f (diff)
downloadgit-73583204d9114b4c86453f5ae74397d9f951072f.zip
git-73583204d9114b4c86453f5ae74397d9f951072f.tar.gz
git-73583204d9114b4c86453f5ae74397d9f951072f.tar.bz2
Merge branch 'nk/refspecs-negative-fix'
Hotfix for recent regression. * nk/refspecs-negative-fix: negative-refspec: improve comment on query_matches_negative_refspec negative-refspec: fix segfault on : refspec
Diffstat (limited to 'remote.c')
-rw-r--r--remote.c16
1 files changed, 13 insertions, 3 deletions
diff --git a/remote.c b/remote.c
index 9f2450c..c3f85c1 100644
--- a/remote.c
+++ b/remote.c
@@ -736,6 +736,12 @@ static int query_matches_negative_refspec(struct refspec *rs, struct refspec_ite
* item uses the destination. To handle this, we apply pattern
* refspecs in reverse to figure out if the query source matches any
* of the negative refspecs.
+ *
+ * The first loop finds and expands all positive refspecs
+ * matched by the queried ref.
+ *
+ * The second loop checks if any of the results of the first loop
+ * match any negative refspec.
*/
for (i = 0; i < rs->nr; i++) {
struct refspec_item *refspec = &rs->items[i];
@@ -751,9 +757,13 @@ static int query_matches_negative_refspec(struct refspec *rs, struct refspec_ite
if (match_name_with_pattern(key, needle, value, &expn_name))
string_list_append_nodup(&reversed, expn_name);
- } else {
- if (!strcmp(needle, refspec->src))
- string_list_append(&reversed, refspec->src);
+ } else if (refspec->matching) {
+ /* For the special matching refspec, any query should match */
+ string_list_append(&reversed, needle);
+ } else if (!refspec->src) {
+ BUG("refspec->src should not be null here");
+ } else if (!strcmp(needle, refspec->src)) {
+ string_list_append(&reversed, refspec->src);
}
}