Re-instate dry-run logic in git-unpack-objects

It can no longer be as verbose, since it doesn't have a good way to
resolve deltas (now that it is purely streaming, it cannot seek around
to read the objects a delta is based on).

But it can check that the thing unpacks cleanly at least as far as pack
syntax goes - all the objects uncompress cleanly, and the pack has the
right final SHA1.
This commit is contained in:
Linus Torvalds 2005-06-29 09:53:20 -07:00
parent cca7081a93
commit dddafffef6

View File

@ -155,7 +155,8 @@ static int unpack_non_delta_entry(enum object_type kind, unsigned long size)
case OBJ_TAG: type = "tag"; break;
default: die("bad type %d", kind);
}
write_object(buf, size, type);
if (!dry_run)
write_object(buf, size, type);
free(buf);
return 0;
}
@ -171,6 +172,10 @@ static int unpack_delta_entry(unsigned long delta_size)
use(20);
delta_data = get_data(delta_size);
if (dry_run) {
free(delta_data);
return 0;
}
if (!has_sha1_file(base_sha1)) {
add_delta_to_list(base_sha1, delta_data, delta_size);