summaryrefslogtreecommitdiffstats
path: root/object.c
diff options
context:
space:
mode:
authorJeff King <peff@peff.net>2022-09-07 01:06:25 +0200
committerJunio C Hamano <gitster@pobox.com>2022-09-07 21:27:02 +0200
commit9a8c3c4a5f94aaed54ae26e4796c08ca9a1cbfbc (patch)
treeb3f7e00bd25b24e8031070a4050120f41438a319 /object.c
parentupload-pack: skip parse-object re-hashing of "want" objects (diff)
downloadgit-9a8c3c4a5f94aaed54ae26e4796c08ca9a1cbfbc.tar.xz
git-9a8c3c4a5f94aaed54ae26e4796c08ca9a1cbfbc.zip
parse_object(): check commit-graph when skip_hash set
If the caller told us that they don't care about us checking the object hash, then we're free to implement any optimizations that get us the parsed value more quickly. An obvious one is to check the commit graph before loading an object from disk. And in fact, both of the callers who pass in this flag are already doing so before they call parse_object()! So we can simplify those callers, as well as any possible future ones, by moving the logic into parse_object(). There are two subtle things to note in the diff, but neither has any impact in practice: - it seems least-surprising here to do the graph lookup on the git-replace'd oid, rather than the original. This is in theory a change of behavior from the earlier code, as neither caller did a replace lookup itself. But in practice it doesn't matter, as we disable the commit graph entirely if there are any replace refs. - the caller in get_reference() passes the skip_hash flag only if revs->verify_objects isn't set, whereas it would look in the commit graph unconditionally. In practice this should not matter as we should disable the commit graph entirely when using verify_objects (and that was done recently in another patch). So this should be a pure cleanup with no behavior change. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'object.c')
-rw-r--r--object.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/object.c b/object.c
index 8f6de09078..2e4589bae5 100644
--- a/object.c
+++ b/object.c
@@ -279,6 +279,12 @@ struct object *parse_object_with_flags(struct repository *r,
if (obj && obj->parsed)
return obj;
+ if (skip_hash) {
+ struct commit *commit = lookup_commit_in_graph(r, repl);
+ if (commit)
+ return &commit->object;
+ }
+
if ((obj && obj->type == OBJ_BLOB && repo_has_object_file(r, oid)) ||
(!obj && repo_has_object_file(r, oid) &&
oid_object_info(r, oid, NULL) == OBJ_BLOB)) {