Use the final_oid_fn to finalize hashing of object IDs
When we're hashing a value which is going to be an object ID, we want to zero-pad that value if necessary. To do so, use the final_oid_fn instead of the final_fn anytime we're going to create an object ID to ensure we perform this operation. Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
ab795f0d77
commit
5951bf467e
@ -1054,7 +1054,7 @@ int check_object_signature(struct repository *r, const struct object_id *oid,
|
||||
break;
|
||||
r->hash_algo->update_fn(&c, buf, readlen);
|
||||
}
|
||||
r->hash_algo->final_fn(real_oid.hash, &c);
|
||||
r->hash_algo->final_oid_fn(&real_oid, &c);
|
||||
close_istream(st);
|
||||
return !oideq(oid, &real_oid) ? -1 : 0;
|
||||
}
|
||||
@ -1755,7 +1755,7 @@ static void write_object_file_prepare(const struct git_hash_algo *algo,
|
||||
algo->init_fn(&c);
|
||||
algo->update_fn(&c, hdr, *hdrlen);
|
||||
algo->update_fn(&c, buf, len);
|
||||
algo->final_fn(oid->hash, &c);
|
||||
algo->final_oid_fn(oid, &c);
|
||||
}
|
||||
|
||||
/*
|
||||
@ -1927,7 +1927,7 @@ static int write_loose_object(const struct object_id *oid, char *hdr,
|
||||
if (ret != Z_OK)
|
||||
die(_("deflateEnd on object %s failed (%d)"), oid_to_hex(oid),
|
||||
ret);
|
||||
the_hash_algo->final_fn(parano_oid.hash, &c);
|
||||
the_hash_algo->final_oid_fn(¶no_oid, &c);
|
||||
if (!oideq(oid, ¶no_oid))
|
||||
die(_("confused by unstable object source data for %s"),
|
||||
oid_to_hex(oid));
|
||||
@ -2508,7 +2508,7 @@ static int check_stream_oid(git_zstream *stream,
|
||||
return -1;
|
||||
}
|
||||
|
||||
the_hash_algo->final_fn(real_oid.hash, &c);
|
||||
the_hash_algo->final_oid_fn(&real_oid, &c);
|
||||
if (!oideq(expected_oid, &real_oid)) {
|
||||
error(_("hash mismatch for %s (expected %s)"), path,
|
||||
oid_to_hex(expected_oid));
|
||||
|
||||
Reference in New Issue
Block a user