Skip to content

Commit ec04a27

Browse files
committed
Merge branch 'mh/ref-api'
Fixes a performance regression in the earlier series.
2 parents fca9e00 + 654ad40 commit ec04a27

File tree

1 file changed

+6
-0
lines changed

1 file changed

+6
-0
lines changed

refs.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -273,6 +273,12 @@ static void add_entry_to_dir(struct ref_dir *dir, struct ref_entry *entry)
273273
{
274274
ALLOC_GROW(dir->entries, dir->nr + 1, dir->alloc);
275275
dir->entries[dir->nr++] = entry;
276+
/* optimize for the case that entries are added in order */
277+
if (dir->nr == 1 ||
278+
(dir->nr == dir->sorted + 1 &&
279+
strcmp(dir->entries[dir->nr - 2]->name,
280+
dir->entries[dir->nr - 1]->name) < 0))
281+
dir->sorted = dir->nr;
276282
}
277283

278284
/*

0 commit comments

Comments
 (0)