diff options
Diffstat (limited to 'sha1_file.c')
| -rw-r--r-- | sha1_file.c | 24 | 
1 files changed, 10 insertions, 14 deletions
| diff --git a/sha1_file.c b/sha1_file.c index 657825e14e..9196b5783d 100644 --- a/sha1_file.c +++ b/sha1_file.c @@ -2281,8 +2281,7 @@ static int write_loose_object(const unsigned char *sha1, char *hdr, int hdrlen,  			      void *buf, unsigned long len, time_t mtime)  {  	int fd, ret; -	size_t size; -	unsigned char *compressed; +	unsigned char compressed[4096];  	z_stream stream;  	char *filename;  	static char tmpfile[PATH_MAX]; @@ -2301,12 +2300,8 @@ static int write_loose_object(const unsigned char *sha1, char *hdr, int hdrlen,  	/* Set it up */  	memset(&stream, 0, sizeof(stream));  	deflateInit(&stream, zlib_compression_level); -	size = 8 + deflateBound(&stream, len+hdrlen); -	compressed = xmalloc(size); - -	/* Compress it */  	stream.next_out = compressed; -	stream.avail_out = size; +	stream.avail_out = sizeof(compressed);  	/* First header.. */  	stream.next_in = (unsigned char *)hdr; @@ -2317,20 +2312,21 @@ static int write_loose_object(const unsigned char *sha1, char *hdr, int hdrlen,  	/* Then the data itself.. */  	stream.next_in = buf;  	stream.avail_in = len; -	ret = deflate(&stream, Z_FINISH); +	do { +		ret = deflate(&stream, Z_FINISH); +		if (write_buffer(fd, compressed, stream.next_out - compressed) < 0) +			die("unable to write sha1 file"); +		stream.next_out = compressed; +		stream.avail_out = sizeof(compressed); +	} while (ret == Z_OK); +  	if (ret != Z_STREAM_END)  		die("unable to deflate new object %s (%d)", sha1_to_hex(sha1), ret); -  	ret = deflateEnd(&stream);  	if (ret != Z_OK)  		die("deflateEnd on object %s failed (%d)", sha1_to_hex(sha1), ret); -	size = stream.total_out; - -	if (write_buffer(fd, compressed, size) < 0) -		die("unable to write sha1 file");  	close_sha1_file(fd); -	free(compressed);  	if (mtime) {  		struct utimbuf utb; | 
