diff options
| author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2009-08-20 20:47:08 +0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2009-08-23 17:14:41 -0700 | 
| commit | 08aefc9e47eb2eaf231352223c939d69b0fb3759 (patch) | |
| tree | 3975ee3df946e6f1d1e360ffd7204faba53bb826 /unpack-trees.c | |
| parent | 35a5aa79d040e2121b6f6bbb17b173f4644699e3 (diff) | |
| download | git-08aefc9e47eb2eaf231352223c939d69b0fb3759.tar.gz | |
unpack-trees(): "enable" sparse checkout and load $GIT_DIR/info/sparse-checkout
This patch introduces core.sparseCheckout, which will control whether
sparse checkout support is enabled in unpack_trees()
It also loads sparse-checkout file that will be used in the next patch.
I split it out so the next patch will be shorter, easier to read.
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 'unpack-trees.c')
| -rw-r--r-- | unpack-trees.c | 36 | 
1 files changed, 30 insertions, 6 deletions
| diff --git a/unpack-trees.c b/unpack-trees.c index 8eb4b7095c..44f8fdf808 100644 --- a/unpack-trees.c +++ b/unpack-trees.c @@ -378,6 +378,7 @@ int unpack_trees(unsigned len, struct tree_desc *t, struct unpack_trees_options  {  	int ret;  	static struct cache_entry *dfc; +	struct exclude_list el;  	if (len > MAX_UNPACK_TREES)  		die("unpack_trees takes at most %d trees", MAX_UNPACK_TREES); @@ -387,6 +388,16 @@ int unpack_trees(unsigned len, struct tree_desc *t, struct unpack_trees_options  	state.quiet = 1;  	state.refresh_cache = 1; +	memset(&el, 0, sizeof(el)); +	if (!core_apply_sparse_checkout || !o->update) +		o->skip_sparse_checkout = 1; +	if (!o->skip_sparse_checkout) { +		if (add_excludes_from_file_to_list(git_path("info/sparse-checkout"), "", 0, NULL, &el, 0) < 0) +			o->skip_sparse_checkout = 1; +		else +			o->el = ⪙ +	} +  	memset(&o->result, 0, sizeof(o->result));  	o->result.initialized = 1;  	if (o->src_index) { @@ -407,26 +418,39 @@ int unpack_trees(unsigned len, struct tree_desc *t, struct unpack_trees_options  		info.fn = unpack_callback;  		info.data = o; -		if (traverse_trees(len, t, &info) < 0) -			return unpack_failed(o, NULL); +		if (traverse_trees(len, t, &info) < 0) { +			ret = unpack_failed(o, NULL); +			goto done; +		}  	}  	/* Any left-over entries in the index? */  	if (o->merge) {  		while (o->pos < o->src_index->cache_nr) {  			struct cache_entry *ce = o->src_index->cache[o->pos]; -			if (unpack_index_entry(ce, o) < 0) -				return unpack_failed(o, NULL); +			if (unpack_index_entry(ce, o) < 0) { +				ret = unpack_failed(o, NULL); +				goto done; +			}  		}  	} -	if (o->trivial_merges_only && o->nontrivial_merge) -		return unpack_failed(o, "Merge requires file-level merging"); +	if (o->trivial_merges_only && o->nontrivial_merge) { +		ret = unpack_failed(o, "Merge requires file-level merging"); +		goto done; +	}  	o->src_index = NULL;  	ret = check_updates(o) ? (-2) : 0;  	if (o->dst_index)  		*o->dst_index = o->result; + +done: +	for (i = 0;i < el.nr;i++) +		free(el.excludes[i]); +	if (el.excludes) +		free(el.excludes); +  	return ret;  } | 
