summaryrefslogtreecommitdiffstats
path: root/sparse-index.c
diff options
context:
space:
mode:
authorDerrick Stolee <dstolee@microsoft.com>2021-09-08 03:42:29 +0200
committerJunio C Hamano <gitster@pobox.com>2021-09-08 07:41:09 +0200
commit8a96b9d0a7c85a25e3550a14e5403eb95aca6d37 (patch)
treef18887afeda86f4d7dd9ca9c3cbfd0d5a7632230 /sparse-index.c
parentsparse-index: silently return when cache tree fails (diff)
downloadgit-8a96b9d0a7c85a25e3550a14e5403eb95aca6d37.tar.xz
git-8a96b9d0a7c85a25e3550a14e5403eb95aca6d37.zip
sparse-index: use WRITE_TREE_MISSING_OK
When updating the cache tree in convert_to_sparse(), the WRITE_TREE_MISSING_OK flag indicates that trees might be computed that do not already exist within the object database. This happens in cases such as 'git add' creating new trees that it wants to store in anticipation of a following 'git commit'. If this flag is not specified, then it might trigger a promisor fetch or a failure due to the object not existing locally. Use WRITE_TREE_MISSING_OK during convert_to_sparse() to avoid these possible reasons for the cache_tree_update() to fail. Signed-off-by: Derrick Stolee <dstolee@microsoft.com> Reviewed-by: Elijah Newren <newren@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'sparse-index.c')
-rw-r--r--sparse-index.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/sparse-index.c b/sparse-index.c
index d9b0769595..880c5f7233 100644
--- a/sparse-index.c
+++ b/sparse-index.c
@@ -181,8 +181,11 @@ int convert_to_sparse(struct index_state *istate)
/*
* Silently return if there is a problem with the cache tree update,
* which might just be due to a conflict state in some entry.
+ *
+ * This might create new tree objects, so be sure to use
+ * WRITE_TREE_MISSING_OK.
*/
- if (cache_tree_update(istate, 0))
+ if (cache_tree_update(istate, WRITE_TREE_MISSING_OK))
return 0;
remove_fsmonitor(istate);