Avoid copying duplicate commits
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
diff --git a/src/transports/local.c b/src/transports/local.c
index 8b3a2d4..436ac43 100644
--- a/src/transports/local.c
+++ b/src/transports/local.c
@@ -263,6 +263,7 @@ static int local_download_pack(
git_oid oid;
git_packbuilder *pack = NULL;
git_odb_writepack *writepack = NULL;
+ git_odb *odb = NULL;
if ((error = git_revwalk_new(&walk, t->repo)) < 0)
goto cleanup;
@@ -295,10 +296,15 @@ static int local_download_pack(
}
/* Walk the objects, building a packfile */
+ if ((error = git_repository_odb__weakptr(&odb, repo)) < 0)
+ goto cleanup;
while ((error = git_revwalk_next(&oid, walk)) == 0) {
git_commit *commit;
+ /* Skip commits we already have */
+ if (git_odb_exists(odb, &oid)) continue;
+
stats->total_objects++;
if (!git_object_lookup((git_object**)&commit, t->repo, &oid, GIT_OBJ_COMMIT)) {
@@ -313,13 +319,8 @@ static int local_download_pack(
}
if (progress_cb) progress_cb(stats, progress_payload);
-
- {
- git_odb *odb;
- if ((error = git_repository_odb__weakptr(&odb, repo)) < 0 ||
- (error = git_odb_write_pack(&writepack, odb, progress_cb, progress_payload)) < 0)
- goto cleanup;
- }
+ if ((error = git_odb_write_pack(&writepack, odb, progress_cb, progress_payload)) < 0)
+ goto cleanup;
/* Write the data to the ODB */
{