X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=trees.c;h=43ee76a63e3cc8612abd351bc3a80f308acf8207;hb=db00b4e39677b0dbf3ea6f7694e0eac7be4ef141;hp=05a1138da6608bec6ef3fd0d3043cef3ad196ea7;hpb=302189d124ed5849c2589ea92e912eb24fdc4ab3;p=gzip diff --git a/trees.c b/trees.c index 05a1138..43ee76a 100644 --- a/trees.c +++ b/trees.c @@ -46,12 +46,13 @@ * void ct_tally (int dist, int lc); * Save the match info and tally the frequency counts. * - * off_t flush_block (char *buf, ulg stored_len, int eof) + * off_t flush_block (char *buf, ulg stored_len, int pad, int eof) * Determine the best encoding for the current block: dynamic trees, * static trees or store, and output the encoded block to the zip - * file. Returns the total compressed length for the file so far. - * - */ + * file. If pad is set, pads the block to the next + * byte. Returns the total compressed length for the file so + * far. + * */ #include #include @@ -847,9 +848,10 @@ local void send_all_trees(lcodes, dcodes, blcodes) * trees or store, and output the encoded block to the zip file. This function * returns the total compressed length for the file so far. */ -off_t flush_block(buf, stored_len, eof) +off_t flush_block(buf, stored_len, pad, eof) char *buf; /* input block, or NULL if too old */ ulg stored_len; /* length of input block */ + int pad; /* pad output to byte boundary */ int eof; /* true if this is the last block for a file */ { ulg opt_lenb, static_lenb; /* opt_len and static_len in bytes */ @@ -941,6 +943,10 @@ off_t flush_block(buf, stored_len, eof) Assert (input_len == bytes_in, "bad input size"); bi_windup(); compressed_len += 7; /* align on byte boundary */ + } else if (pad && (compressed_len % 8) != 0) { + send_bits((STORED_BLOCK<<1)+eof, 3); /* send block type */ + compressed_len = (compressed_len + 3 + 7) & ~7L; + copy_block(buf, 0, 1); /* with header */ } return compressed_len >> 3;