mirror of
https://github.com/git/git.git
synced 2024-11-25 02:44:48 +08:00
git branch: avoid unnecessary object lookups
They can be expensive in the cold-cache case, so don't bother looking up the commits for all branches unless we really need them for some reason. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
e6e4a47ba1
commit
191d1ac435
@ -191,7 +191,7 @@ struct ref_item {
|
|||||||
|
|
||||||
struct ref_list {
|
struct ref_list {
|
||||||
struct rev_info revs;
|
struct rev_info revs;
|
||||||
int index, alloc, maxwidth;
|
int index, alloc, maxwidth, verbose;
|
||||||
struct ref_item *list;
|
struct ref_item *list;
|
||||||
struct commit_list *with_commit;
|
struct commit_list *with_commit;
|
||||||
int kinds;
|
int kinds;
|
||||||
@ -244,17 +244,20 @@ static int append_ref(const char *refname, const unsigned char *sha1, int flags,
|
|||||||
if ((kind & ref_list->kinds) == 0)
|
if ((kind & ref_list->kinds) == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
commit = lookup_commit_reference_gently(sha1, 1);
|
commit = NULL;
|
||||||
if (!commit)
|
if (ref_list->verbose || ref_list->with_commit || merge_filter != NO_FILTER) {
|
||||||
return error("branch '%s' does not point at a commit", refname);
|
commit = lookup_commit_reference_gently(sha1, 1);
|
||||||
|
if (!commit)
|
||||||
|
return error("branch '%s' does not point at a commit", refname);
|
||||||
|
|
||||||
/* Filter with with_commit if specified */
|
/* Filter with with_commit if specified */
|
||||||
if (!is_descendant_of(commit, ref_list->with_commit))
|
if (!is_descendant_of(commit, ref_list->with_commit))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (merge_filter != NO_FILTER)
|
if (merge_filter != NO_FILTER)
|
||||||
add_pending_object(&ref_list->revs,
|
add_pending_object(&ref_list->revs,
|
||||||
(struct object *)commit, refname);
|
(struct object *)commit, refname);
|
||||||
|
}
|
||||||
|
|
||||||
/* Resize buffer */
|
/* Resize buffer */
|
||||||
if (ref_list->index >= ref_list->alloc) {
|
if (ref_list->index >= ref_list->alloc) {
|
||||||
@ -423,6 +426,7 @@ static void print_ref_list(int kinds, int detached, int verbose, int abbrev, str
|
|||||||
|
|
||||||
memset(&ref_list, 0, sizeof(ref_list));
|
memset(&ref_list, 0, sizeof(ref_list));
|
||||||
ref_list.kinds = kinds;
|
ref_list.kinds = kinds;
|
||||||
|
ref_list.verbose = verbose;
|
||||||
ref_list.with_commit = with_commit;
|
ref_list.with_commit = with_commit;
|
||||||
if (merge_filter != NO_FILTER)
|
if (merge_filter != NO_FILTER)
|
||||||
init_revisions(&ref_list.revs, NULL);
|
init_revisions(&ref_list.revs, NULL);
|
||||||
|
Loading…
Reference in New Issue
Block a user