summaryrefslogtreecommitdiffstats
path: root/fast-import.c
diff options
context:
space:
mode:
authorShawn O. Pearce <spearce@spearce.org>2007-01-15 12:51:58 +0100
committerShawn O. Pearce <spearce@spearce.org>2007-01-15 13:12:23 +0100
commit2fce1f3c862845d23b2bd8305f97abb115623192 (patch)
treebffd9086a9fab8f8202303872da69ffa762c5bec /fast-import.c
parentDon't create a final empty packfile in fast-import. (diff)
downloadgit-2fce1f3c862845d23b2bd8305f97abb115623192.tar.xz
git-2fce1f3c862845d23b2bd8305f97abb115623192.zip
Optimize index creation on large object sets in fast-import.
When we are generating multiple packfiles at once we only need to scan the blocks of object_entry structs which contain objects for the current packfile. Because the most recent blocks are at the front of the linked list, and because all new objects going into the current file are allocated from the front of that list, we can stop scanning for objects as soon as we identify one which doesn't belong to the current packfile. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Diffstat (limited to '')
-rw-r--r--fast-import.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/fast-import.c b/fast-import.c
index 207acb3230..cfadda0432 100644
--- a/fast-import.c
+++ b/fast-import.c
@@ -678,10 +678,15 @@ static void write_index(const char *idx_name)
idx = xmalloc(object_count * sizeof(struct object_entry*));
c = idx;
for (o = blocks; o; o = o->next_pool)
- for (e = o->entries; e != o->next_free; e++)
- if (pack_id == e->pack_id)
- *c++ = e;
+ for (e = o->next_free; e-- != o->entries;) {
+ if (pack_id != e->pack_id)
+ goto sort_index;
+ *c++ = e;
+ }
+sort_index:
last = idx + object_count;
+ if (c != last)
+ die("internal consistency error creating the index");
qsort(idx, object_count, sizeof(struct object_entry*), oecmp);
/* Generate the fan-out array. */