Merge branch 'jk/read-packed-refs-without-path-max' into maint
authorJunio C Hamano <gitster@pobox.com>
Mon, 12 Jan 2015 22:02:54 +0000 (14:02 -0800)
committerJunio C Hamano <gitster@pobox.com>
Mon, 12 Jan 2015 22:02:54 +0000 (14:02 -0800)
* jk/read-packed-refs-without-path-max:
read_packed_refs: use skip_prefix instead of static array
read_packed_refs: pass strbuf to parse_ref_line
read_packed_refs: use a strbuf for reading lines

1  2 
refs.c
diff --cc refs.c
index 1f77fa6a2400a29819a65d189d0b25cf217af7df,ba3003ffd2bd63a1741771e63ed296de69f4e607..6664423f8d402b98a3aae90c932f64cff4d88cb2
--- 1/refs.c
--- 2/refs.c
+++ b/refs.c
@@@ -1144,15 -1051,9 +1146,15 @@@ static void read_packed_refs(FILE *f, s
                        continue;
                }
  
-               refname = parse_ref_line(refline, sha1);
+               refname = parse_ref_line(&line, sha1);
                if (refname) {
 -                      last = create_ref_entry(refname, sha1, REF_ISPACKED, 1);
 +                      int flag = REF_ISPACKED;
 +
 +                      if (check_refname_format(refname, REFNAME_ALLOW_ONELEVEL)) {
 +                              hashclr(sha1);
 +                              flag |= REF_BAD_NAME | REF_ISBROKEN;
 +                      }
 +                      last = create_ref_entry(refname, sha1, flag, 0);
                        if (peeled == PEELED_FULLY ||
                            (peeled == PEELED_TAGS && starts_with(refname, "refs/tags/")))
                                last->flag |= REF_KNOWS_PEELED;