mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-03 20:02:04 +00:00
Merge pull request #831 from schu/tree-walk-order
tree: fix ordering for git_tree_walk
This commit is contained in:
commit
c8a1892e71
20
src/tree.c
20
src/tree.c
@ -759,11 +759,12 @@ int git_tree_entry_bypath(
|
|||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tree_walk_post(
|
static int tree_walk(
|
||||||
git_tree *tree,
|
git_tree *tree,
|
||||||
git_treewalk_cb callback,
|
git_treewalk_cb callback,
|
||||||
git_buf *path,
|
git_buf *path,
|
||||||
void *payload)
|
void *payload,
|
||||||
|
bool preorder)
|
||||||
{
|
{
|
||||||
int error = 0;
|
int error = 0;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
@ -771,8 +772,8 @@ static int tree_walk_post(
|
|||||||
for (i = 0; i < tree->entries.length; ++i) {
|
for (i = 0; i < tree->entries.length; ++i) {
|
||||||
git_tree_entry *entry = tree->entries.contents[i];
|
git_tree_entry *entry = tree->entries.contents[i];
|
||||||
|
|
||||||
if (callback(path->ptr, entry, payload) < 0)
|
if (preorder && callback(path->ptr, entry, payload) < 0)
|
||||||
continue;
|
return -1;
|
||||||
|
|
||||||
if (git_tree_entry__is_tree(entry)) {
|
if (git_tree_entry__is_tree(entry)) {
|
||||||
git_tree *subtree;
|
git_tree *subtree;
|
||||||
@ -789,12 +790,15 @@ static int tree_walk_post(
|
|||||||
if (git_buf_oom(path))
|
if (git_buf_oom(path))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (tree_walk_post(subtree, callback, path, payload) < 0)
|
if (tree_walk(subtree, callback, path, payload, preorder) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
git_buf_truncate(path, path_len);
|
git_buf_truncate(path, path_len);
|
||||||
git_tree_free(subtree);
|
git_tree_free(subtree);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!preorder && callback(path->ptr, entry, payload) < 0)
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -807,12 +811,12 @@ int git_tree_walk(git_tree *tree, git_treewalk_cb callback, int mode, void *payl
|
|||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case GIT_TREEWALK_POST:
|
case GIT_TREEWALK_POST:
|
||||||
error = tree_walk_post(tree, callback, &root_path, payload);
|
error = tree_walk(tree, callback, &root_path, payload, false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GIT_TREEWALK_PRE:
|
case GIT_TREEWALK_PRE:
|
||||||
tree_error("Preorder tree walking is still not implemented");
|
error = tree_walk(tree, callback, &root_path, payload, true);
|
||||||
return -1;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
giterr_set(GITERR_INVALID, "Invalid walking mode for tree walk");
|
giterr_set(GITERR_INVALID, "Invalid walking mode for tree walk");
|
||||||
|
Loading…
Reference in New Issue
Block a user