diff options
author | Junio C Hamano <gitster@pobox.com> | 2015-09-04 10:25:23 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2015-09-04 10:25:23 -0700 |
commit | f54cb059b18e704d8b51d0cd4736344422650d6f (patch) | |
tree | 324187d0682f989593a532d231acf8472d4d2f2b /notes.c | |
parent | fdf96a20acf96a6ac538df8113b2aafd6ed71d50 (diff) | |
parent | 78f23bdf68dae56d644892990484951583a64014 (diff) | |
download | git-f54cb059b18e704d8b51d0cd4736344422650d6f.tar.gz |
Merge branch 'jk/long-paths' into maint-2.2
Diffstat (limited to 'notes.c')
-rw-r--r-- | notes.c | 19 |
1 files changed, 10 insertions, 9 deletions
@@ -362,13 +362,14 @@ static int non_note_cmp(const struct non_note *a, const struct non_note *b) return strcmp(a->path, b->path); } -static void add_non_note(struct notes_tree *t, const char *path, +/* note: takes ownership of path string */ +static void add_non_note(struct notes_tree *t, char *path, unsigned int mode, const unsigned char *sha1) { struct non_note *p = t->prev_non_note, *n; n = (struct non_note *) xmalloc(sizeof(struct non_note)); n->next = NULL; - n->path = xstrdup(path); + n->path = path; n->mode = mode; hashcpy(n->sha1, sha1); t->prev_non_note = n; @@ -482,17 +483,17 @@ handle_non_note: * component. */ { - char non_note_path[PATH_MAX]; - char *p = non_note_path; + struct strbuf non_note_path = STRBUF_INIT; const char *q = sha1_to_hex(subtree->key_sha1); int i; for (i = 0; i < prefix_len; i++) { - *p++ = *q++; - *p++ = *q++; - *p++ = '/'; + strbuf_addch(&non_note_path, *q++); + strbuf_addch(&non_note_path, *q++); + strbuf_addch(&non_note_path, '/'); } - strcpy(p, entry.path); - add_non_note(t, non_note_path, entry.mode, entry.sha1); + strbuf_addstr(&non_note_path, entry.path); + add_non_note(t, strbuf_detach(&non_note_path, NULL), + entry.mode, entry.sha1); } } free(buf); |