diff options
| author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2014-06-13 19:19:32 +0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2014-06-13 11:49:39 -0700 | 
| commit | d0cfc3e866a77eed98ab2caf41a39a87837950e6 (patch) | |
| tree | 21a6cb067150bec1081c9ef3ac00504004f20707 /cache-tree.c | |
| parent | a5400efe29fdaabbe5266d11d255b2ef5a4c3a66 (diff) | |
| download | git-d0cfc3e866a77eed98ab2caf41a39a87837950e6.tar.gz | |
cache-tree: mark istate->cache_changed on cache tree update
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'cache-tree.c')
| -rw-r--r-- | cache-tree.c | 25 | 
1 files changed, 11 insertions, 14 deletions
diff --git a/cache-tree.c b/cache-tree.c index 23ddc73720..18055f1c96 100644 --- a/cache-tree.c +++ b/cache-tree.c @@ -151,7 +151,7 @@ void cache_tree_invalidate_path(struct index_state *istate, const char *path)  		istate->cache_changed |= CACHE_TREE_CHANGED;  } -static int verify_cache(const struct cache_entry * const *cache, +static int verify_cache(struct cache_entry **cache,  			int entries, int flags)  {  	int i, funny; @@ -236,7 +236,7 @@ int cache_tree_fully_valid(struct cache_tree *it)  }  static int update_one(struct cache_tree *it, -		      const struct cache_entry * const *cache, +		      struct cache_entry **cache,  		      int entries,  		      const char *base,  		      int baselen, @@ -398,18 +398,19 @@ static int update_one(struct cache_tree *it,  	return i;  } -int cache_tree_update(struct cache_tree *it, -		      const struct cache_entry * const *cache, -		      int entries, -		      int flags) +int cache_tree_update(struct index_state *istate, int flags)  { -	int i, skip; -	i = verify_cache(cache, entries, 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); +  	if (i)  		return i;  	i = update_one(it, cache, entries, "", 0, &skip, flags);  	if (i < 0)  		return i; +	istate->cache_changed |= CACHE_TREE_CHANGED;  	return 0;  } @@ -597,9 +598,7 @@ int write_cache_as_tree(unsigned char *sha1, int flags, const char *prefix)  	was_valid = cache_tree_fully_valid(active_cache_tree);  	if (!was_valid) { -		if (cache_tree_update(active_cache_tree, -				      (const struct cache_entry * const *)active_cache, -				      active_nr, flags) < 0) +		if (cache_tree_update(&the_index, flags) < 0)  			return WRITE_TREE_UNMERGED_INDEX;  		if (0 <= newfd) {  			if (!write_locked_index(&the_index, lock_file, COMMIT_LOCK)) @@ -698,7 +697,5 @@ int update_main_cache_tree(int flags)  {  	if (!the_index.cache_tree)  		the_index.cache_tree = cache_tree(); -	return cache_tree_update(the_index.cache_tree, -				 (const struct cache_entry * const *)the_index.cache, -				 the_index.cache_nr, flags); +	return cache_tree_update(&the_index, flags);  }  | 
