diff options
| author | Junio C Hamano <junkio@cox.net> | 2006-04-27 15:42:01 -0700 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-04-27 15:42:17 -0700 | 
| commit | 55e1805dffeb5d2a8ccd717b2d07ca8887436a69 (patch) | |
| tree | 9e969600edcc30c54db9d7d561b457f3d47e7c88 | |
| parent | 5981e09999e90b389a02843671529a0faaf72143 (diff) | |
| download | git-55e1805dffeb5d2a8ccd717b2d07ca8887436a69.tar.gz | |
verify-pack: check integrity in a saner order.
Check internal integrity to report corrupt pack or idx, and
then check cross-integrity between idx and pack.
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
| -rw-r--r-- | pack-check.c | 6 | 
1 files changed, 3 insertions, 3 deletions
| diff --git a/pack-check.c b/pack-check.c index 84ed90d369..e57587909e 100644 --- a/pack-check.c +++ b/pack-check.c @@ -29,12 +29,12 @@ static int verify_packfile(struct packed_git *p)  	pack_base = p->pack_base;  	SHA1_Update(&ctx, pack_base, pack_size - 20);  	SHA1_Final(sha1, &ctx); -	if (memcmp(sha1, index_base + index_size - 40, 20)) -		return error("Packfile %s SHA1 mismatch with idx", -			     p->pack_name);  	if (memcmp(sha1, pack_base + pack_size - 20, 20))  		return error("Packfile %s SHA1 mismatch with itself",  			     p->pack_name); +	if (memcmp(sha1, index_base + index_size - 40, 20)) +		return error("Packfile %s SHA1 mismatch with idx", +			     p->pack_name);  	/* Make sure everything reachable from idx is valid.  Since we  	 * have verified that nr_objects matches between idx and pack, | 
