diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-03-07 00:44:48 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-03-09 09:43:47 +0100 |
commit | bcbe5a515e837873f24dc9a764fa31e3ade45bb5 (patch) | |
tree | 8f32dd713d0b8a6798795632aba83cac6f8424d2 /tree-walk.c | |
parent | Move 'unpack_trees()' over to 'traverse_trees()' interface (diff) | |
download | git-bcbe5a515e837873f24dc9a764fa31e3ade45bb5.tar.xz git-bcbe5a515e837873f24dc9a764fa31e3ade45bb5.zip |
Fix tree-walking compare_entry() in the presense of --prefix
When we make the "root" tree-walk info entry have a pathname in it, we
need to have a ->prev pointer so that compare_entry will actually notice
and traverse into the root.
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'tree-walk.c')
-rw-r--r-- | tree-walk.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/tree-walk.c b/tree-walk.c index 842cb6ad2e..02e2aed773 100644 --- a/tree-walk.c +++ b/tree-walk.c @@ -107,6 +107,7 @@ int tree_entry(struct tree_desc *desc, struct name_entry *entry) void setup_traverse_info(struct traverse_info *info, const char *base) { int pathlen = strlen(base); + static struct traverse_info dummy; memset(info, 0, sizeof(*info)); if (pathlen && base[pathlen-1] == '/') @@ -114,6 +115,8 @@ void setup_traverse_info(struct traverse_info *info, const char *base) info->pathlen = pathlen ? pathlen + 1 : 0; info->name.path = base; info->name.sha1 = (void *)(base + pathlen + 1); + if (pathlen) + info->prev = &dummy; } char *make_traverse_path(char *path, const struct traverse_info *info, const struct name_entry *n) |