Michael Schubert <mschub@xxxxxxxxxxxxx> writes: > Currently, we allow refname components to start with a hyphen. There's > no good reason to do so... That is way too weak as a justification to potentially break existing repositories. Refusal upon attempted creation is probably OK, which is why the two checks you removed in your patches are fine. I do not know if it is justifiable to do that in check_refname_component() that is used in the reading codepath. > diff --git a/builtin/tag.c b/builtin/tag.c > index 7b1be85..c99fb42 100644 > --- a/builtin/tag.c > +++ b/builtin/tag.c > @@ -403,9 +403,6 @@ static int parse_msg_arg(const struct option *opt, const char *arg, int unset) > > static int strbuf_check_tag_ref(struct strbuf *sb, const char *name) > { > - if (name[0] == '-') > - return -1; > - > strbuf_reset(sb); > strbuf_addf(sb, "refs/tags/%s", name); > > diff --git a/refs.c b/refs.c > index da74a2b..5714681 100644 > --- a/refs.c > +++ b/refs.c > @@ -62,6 +62,8 @@ static int check_refname_component(const char *refname, int flags) > if (refname[1] == '\0') > return -1; /* Component equals ".". */ > } > + if (refname[0] == '-') > + return -1; /* Component starts with '-'. */ > if (cp - refname >= 5 && !memcmp(cp - 5, ".lock", 5)) > return -1; /* Refname ends with ".lock". */ > return cp - refname; > diff --git a/sha1_name.c b/sha1_name.c > index 5d81ea0..132d369 100644 > --- a/sha1_name.c > +++ b/sha1_name.c > @@ -892,8 +892,6 @@ int strbuf_branchname(struct strbuf *sb, const char *name) > int strbuf_check_branch_ref(struct strbuf *sb, const char *name) > { > strbuf_branchname(sb, name); > - if (name[0] == '-') > - return -1; > strbuf_splice(sb, 0, 0, "refs/heads/", 11); > return check_refname_format(sb->buf, 0); > } -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html