]> git.ipfire.org Git - thirdparty/git.git/commitdiff
cache-tree: clean up cache_tree_update()
authorDerrick Stolee <dstolee@microsoft.com>
Sat, 23 Jan 2021 19:58:11 +0000 (19:58 +0000)
committerJunio C Hamano <gitster@pobox.com>
Sun, 24 Jan 2021 01:14:07 +0000 (17:14 -0800)
Make the method safer by allocating a cache_tree member for the given
index_state if it is not already present. This is preferrable to a
BUG() statement or returning with an error because future callers will
want to populate an empty cache-tree using this method.

Callers can also remove their conditional allocations of cache_tree.

Also drop local variables that can be found directly from the 'istate'
parameter.

Signed-off-by: Derrick Stolee <dstolee@microsoft.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/checkout.c
cache-tree.c
sequencer.c
unpack-trees.c

index c9ba23c27945b85059fbc4987c7927a720f7e74d..2d6550bc3c8638a3d25a04924a1352a43854d4c6 100644 (file)
@@ -821,9 +821,6 @@ static int merge_working_tree(const struct checkout_opts *opts,
                }
        }
 
-       if (!active_cache_tree)
-               active_cache_tree = cache_tree();
-
        if (!cache_tree_fully_valid(active_cache_tree))
                cache_tree_update(&the_index, WRITE_TREE_SILENT | WRITE_TREE_REPAIR);
 
index 3f1a8d4f1b7e0807d50db20fa2dbda31c80e843e..60b6aefbf516ab9056fea1a145ce8334fa41318e 100644 (file)
@@ -436,16 +436,20 @@ static int update_one(struct cache_tree *it,
 
 int cache_tree_update(struct index_state *istate, int flags)
 {
-       struct cache_tree *it = istate->cache_tree;
-       struct cache_entry **cache = istate->cache;
-       int entries = istate->cache_nr;
-       int skip, i = verify_cache(cache, entries, flags);
+       int skip, i;
+
+       i = verify_cache(istate->cache, istate->cache_nr, flags);
 
        if (i)
                return i;
+
+       if (!istate->cache_tree)
+               istate->cache_tree = cache_tree();
+
        trace_performance_enter();
        trace2_region_enter("cache_tree", "update", the_repository);
-       i = update_one(it, cache, entries, "", 0, &skip, flags);
+       i = update_one(istate->cache_tree, istate->cache, istate->cache_nr,
+                      "", 0, &skip, flags);
        trace2_region_leave("cache_tree", "update", the_repository);
        trace_performance_leave("cache_tree_update");
        if (i < 0)
@@ -635,9 +639,6 @@ static int write_index_as_tree_internal(struct object_id *oid,
                cache_tree_valid = 0;
        }
 
-       if (!index_state->cache_tree)
-               index_state->cache_tree = cache_tree();
-
        if (!cache_tree_valid && cache_tree_update(index_state, flags) < 0)
                return WRITE_TREE_UNMERGED_INDEX;
 
index 8909a467700c506f7068ed566aa7813c093157fd..aa3e4c81cf02465558b1590e5cb415510534907d 100644 (file)
@@ -679,9 +679,6 @@ static int do_recursive_merge(struct repository *r,
 
 static struct object_id *get_cache_tree_oid(struct index_state *istate)
 {
-       if (!istate->cache_tree)
-               istate->cache_tree = cache_tree();
-
        if (!cache_tree_fully_valid(istate->cache_tree))
                if (cache_tree_update(istate, 0)) {
                        error(_("unable to update cache tree"));
index af6e9b9c2fd558dc625ddd8f63b54c9e8d489e56..a810b79657ee948ac2197486b998e5badba73ef0 100644 (file)
@@ -1726,8 +1726,6 @@ int unpack_trees(unsigned len, struct tree_desc *t, struct unpack_trees_options
                if (!ret) {
                        if (git_env_bool("GIT_TEST_CHECK_CACHE_TREE", 0))
                                cache_tree_verify(the_repository, &o->result);
-                       if (!o->result.cache_tree)
-                               o->result.cache_tree = cache_tree();
                        if (!cache_tree_fully_valid(o->result.cache_tree))
                                cache_tree_update(&o->result,
                                                  WRITE_TREE_SILENT |