diff options
| author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2014-06-13 19:19:42 +0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2014-06-13 11:49:41 -0700 | 
| commit | ce7c614bceedf0c0169dd5b02cae3e33ee45acdd (patch) | |
| tree | f4299db57da7bafc4d38a6b3d0bea85cb214b4c7 | |
| parent | 76b07b37a3fff15ce4852bd070a610b651c42e77 (diff) | |
| download | git-ce7c614bceedf0c0169dd5b02cae3e33ee45acdd.tar.gz | |
split-index: do not invalidate cache-tree at read time
We are sure that after merge_base_index() is done. cache-tree can
still be used with the final index. So don't destroy cache tree.
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | cache.h | 1 | ||||
| -rw-r--r-- | read-cache.c | 3 | ||||
| -rw-r--r-- | split-index.c | 1 | 
3 files changed, 4 insertions, 1 deletions
| @@ -488,6 +488,7 @@ extern int index_name_pos(const struct index_state *, const char *name, int name  #define ADD_CACHE_SKIP_DFCHECK 4	/* Ok to skip DF conflict checks */  #define ADD_CACHE_JUST_APPEND 8		/* Append only; tree.c::read_tree() */  #define ADD_CACHE_NEW_ONLY 16		/* Do not replace existing ones */ +#define ADD_CACHE_KEEP_CACHE_TREE 32	/* Do not invalidate cache-tree */  extern int add_index_entry(struct index_state *, struct cache_entry *ce, int option);  extern void rename_index_entry_at(struct index_state *, int pos, const char *new_name);  extern int remove_index_entry_at(struct index_state *, int pos); diff --git a/read-cache.c b/read-cache.c index 1a7ef7f783..d5f70a08b9 100644 --- a/read-cache.c +++ b/read-cache.c @@ -950,7 +950,8 @@ static int add_index_entry_with_check(struct index_state *istate, struct cache_e  	int skip_df_check = option & ADD_CACHE_SKIP_DFCHECK;  	int new_only = option & ADD_CACHE_NEW_ONLY; -	cache_tree_invalidate_path(istate, ce->name); +	if (!(option & ADD_CACHE_KEEP_CACHE_TREE)) +		cache_tree_invalidate_path(istate, ce->name);  	pos = index_name_stage_pos(istate, ce->name, ce_namelen(ce), ce_stage(ce));  	/* existing match? Just replace it. */ diff --git a/split-index.c b/split-index.c index b03a250e7c..33c0c4b698 100644 --- a/split-index.c +++ b/split-index.c @@ -133,6 +133,7 @@ void merge_base_index(struct index_state *istate)  	for (i = si->nr_replacements; i < si->saved_cache_nr; i++) {  		add_index_entry(istate, si->saved_cache[i],  				ADD_CACHE_OK_TO_ADD | +				ADD_CACHE_KEEP_CACHE_TREE |  				/*  				 * we may have to replay what  				 * merge-recursive.c:update_stages() | 
