summaryrefslogtreecommitdiff
path: root/src/index.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/index.c')
-rw-r--r--src/index.c17
1 files changed, 6 insertions, 11 deletions
diff --git a/src/index.c b/src/index.c
index d0d2cf187..671bdfa79 100644
--- a/src/index.c
+++ b/src/index.c
@@ -2036,17 +2036,12 @@ int git_index_read_tree(git_index *index, const git_tree *tree)
error = git_tree_walk(tree, GIT_TREEWALK_POST, read_tree_cb, &data);
- if (error == GIT_EUSER) {
- giterr_set_oom();
- git_vector_free(&entries);
- return -1;
+ if (!error) {
+ git_vector_sort(&entries);
+ git_index_clear(index);
+ git_vector_swap(&entries, &index->entries);
}
- git_vector_sort(&entries);
-
- git_index_clear(index);
-
- git_vector_swap(&entries, &index->entries);
git_vector_free(&entries);
return error;
@@ -2122,7 +2117,7 @@ int git_index_add_all(
if (error > 0) /* return > 0 means skip this one */
continue;
if (error < 0) { /* return < 0 means abort */
- error = giterr_user_cancel();
+ GITERR_CALLBACK(error);
break;
}
}
@@ -2210,7 +2205,7 @@ static int index_apply_to_all(
continue;
}
if (error < 0) { /* return < 0 means abort */
- error = giterr_user_cancel();
+ giterr_set_callback(error, "git_index_matched_path");
break;
}
}