diff options
| author | brian m. carlson <sandals@crustytoothpaste.net> | 2014-12-24 23:05:39 +0000 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2014-12-29 09:57:55 -0800 | 
| commit | 1684c1b219e02c91655ad929f752f4f864c72faf (patch) | |
| tree | 8c5c581b502587f2f4be3e375a37c43152210fc3 /list-objects.c | |
| parent | 8297643fcdb0e0f1edaff1fe026210dc6e073176 (diff) | |
| download | git-1684c1b219e02c91655ad929f752f4f864c72faf.tar.gz | |
rev-list: add an option to mark fewer edges as uninteresting
In commit fbd4a70 (list-objects: mark more commits as edges in
mark_edges_uninteresting - 2013-08-16), we marked an increasing number
of edges uninteresting.  This change, and the subsequent change to make
this conditional on --objects-edge, are used by --thin to make much
smaller packs for shallow clones.
Unfortunately, they cause a significant performance regression when
pushing non-shallow clones with lots of refs (23.322 seconds vs.
4.785 seconds with 22400 refs).  Add an option to git rev-list,
--objects-edge-aggressive, that preserves this more aggressive behavior,
while leaving --objects-edge to provide more performant behavior.
Preserve the current behavior for the moment by using the aggressive
option.
Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'list-objects.c')
| -rw-r--r-- | list-objects.c | 4 | 
1 files changed, 2 insertions, 2 deletions
| diff --git a/list-objects.c b/list-objects.c index 2910becd6c..2a139b6ced 100644 --- a/list-objects.c +++ b/list-objects.c @@ -157,7 +157,7 @@ void mark_edges_uninteresting(struct rev_info *revs, show_edge_fn show_edge)  		if (commit->object.flags & UNINTERESTING) {  			mark_tree_uninteresting(commit->tree); -			if (revs->edge_hint && !(commit->object.flags & SHOWN)) { +			if (revs->edge_hint_aggressive && !(commit->object.flags & SHOWN)) {  				commit->object.flags |= SHOWN;  				show_edge(commit);  			} @@ -165,7 +165,7 @@ void mark_edges_uninteresting(struct rev_info *revs, show_edge_fn show_edge)  		}  		mark_edge_parents_uninteresting(commit, revs, show_edge);  	} -	if (revs->edge_hint) { +	if (revs->edge_hint_aggressive) {  		for (i = 0; i < revs->cmdline.nr; i++) {  			struct object *obj = revs->cmdline.rev[i].item;  			struct commit *commit = (struct commit *)obj; | 
