diff options
| author | Björn Steinbrink <B.Steinbrink@gmx.de> | 2008-07-24 18:32:00 +0100 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-07-25 10:46:46 -0700 | 
| commit | 72de2883bd7d4ceda05f107826c7607c594de965 (patch) | |
| tree | d33a645c78dd830e77ea77e6efcaef931f364b1a /index-pack.c | |
| parent | 8892048d516fffab2000c2b47e006d8d8ebaa8c7 (diff) | |
| download | git-72de2883bd7d4ceda05f107826c7607c594de965.tar.gz | |
index-pack.c: correctly initialize appended objects
When index-pack completes a thin pack it appends objects to the pack.
Since the commit 92392b4(index-pack: Honor core.deltaBaseCacheLimit when
resolving deltas) such an object can be pruned in case of memory
pressure, and will be read back again by get_data_from_pack().  For this
to work, the fields in object_entry structure need to be initialized
properly.
Noticed by Pierre Habouzit.
Signed-off-by: Björn Steinbrink <B.Steinbrink@gmx.de>
Acked-by: Nicolas Pitre <nico@cam.org>
Acked-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'index-pack.c')
| -rw-r--r-- | index-pack.c | 4 | 
1 files changed, 4 insertions, 0 deletions
| diff --git a/index-pack.c b/index-pack.c index c359f8c9df..7d5344abc0 100644 --- a/index-pack.c +++ b/index-pack.c @@ -698,6 +698,10 @@ static struct object_entry *append_obj_to_pack(  	write_or_die(output_fd, header, n);  	obj[0].idx.crc32 = crc32(0, Z_NULL, 0);  	obj[0].idx.crc32 = crc32(obj[0].idx.crc32, header, n); +	obj[0].size = size; +	obj[0].hdr_size = n; +	obj[0].type = type; +	obj[0].real_type = type;  	obj[1].idx.offset = obj[0].idx.offset + n;  	obj[1].idx.offset += write_compressed(output_fd, buf, size, &obj[0].idx.crc32);  	hashcpy(obj->idx.sha1, sha1); | 
