X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=upload-pack.c;h=edc78612289c5bd774e18fe5f8e1b9ea80378a5f;hb=c5fe5b6de94c1dffac697b29920819f08e2c11fc;hp=495c99f80a9de2e28f0875560d920e5bb4155d7c;hpb=c276857ee250ca1c3a36cba8358f50ba01e97917;p=git.git diff --git a/upload-pack.c b/upload-pack.c index 495c99f80..edc786122 100644 --- a/upload-pack.c +++ b/upload-pack.c @@ -78,20 +78,22 @@ static void show_commit(struct commit *commit, void *data) commit->buffer = NULL; } -static void show_object(struct object_array_entry *p, void *data) +static void show_object(struct object *obj, const struct name_path *path, const char *component) { /* An object with name "foo\n0000000..." can be used to * confuse downstream git-pack-objects very badly. */ - const char *ep = strchr(p->name, '\n'); + const char *name = path_name(path, component); + const char *ep = strchr(name, '\n'); if (ep) { - fprintf(pack_pipe, "%s %.*s\n", sha1_to_hex(p->item->sha1), - (int) (ep - p->name), - p->name); + fprintf(pack_pipe, "%s %.*s\n", sha1_to_hex(obj->sha1), + (int) (ep - name), + name); } else fprintf(pack_pipe, "%s %s\n", - sha1_to_hex(p->item->sha1), p->name); + sha1_to_hex(obj->sha1), name); + free((char *)name); } static void show_edge(struct commit *commit)