X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=zip.c;h=be5c4b0b95267ddfaa67c3f439a87369d2e02f1c;hb=92249085071a973e2c0621b0415b93d2e48bb00d;hp=756c8fd042be9d715d7a1230648ea8ed5ab20cf0;hpb=a2016c1de6e4884f6c8ed5cc498f3bf821c25ca4;p=debian%2Fgzip diff --git a/zip.c b/zip.c index 756c8fd..be5c4b0 100644 --- a/zip.c +++ b/zip.c @@ -1,6 +1,6 @@ /* zip.c -- compress files to the gzip or pkzip format - Copyright (C) 1997-1999, 2006-2007, 2009-2010 Free Software Foundation, Inc. + Copyright (C) 1997-1999, 2006-2007, 2009-2018 Free Software Foundation, Inc. Copyright (C) 1992-1993 Jean-loup Gailly This program is free software; you can redistribute it and/or modify @@ -22,10 +22,6 @@ #include "tailor.h" #include "gzip.h" -#include "crypt.h" - -#include -#include local ulg crc; /* crc on uncompressed file data */ off_t header_bytes; /* number of bytes in gzip header */ @@ -55,12 +51,20 @@ int zip(in, out) put_byte(DEFLATED); /* compression method */ if (save_orig_name) { - flags |= ORIG_NAME; + flags |= ORIG_NAME; } put_byte(flags); /* general flags */ - stamp = (0 <= time_stamp.tv_sec && time_stamp.tv_sec <= 0xffffffff - ? (ulg) time_stamp.tv_sec - : (ulg) 0); + if (time_stamp.tv_nsec < 0) + stamp = 0; + else if (0 < time_stamp.tv_sec && time_stamp.tv_sec <= 0xffffffff) + stamp = time_stamp.tv_sec; + else + { + /* It's intended that timestamp 0 generates this warning, + since gzip format reserves 0 for something else. */ + warning ("file timestamp out of range for gzip format"); + stamp = 0; + } put_long (stamp); /* Write deflated file to zip file */ @@ -74,29 +78,29 @@ int zip(in, out) put_byte(OS_CODE); /* OS identifier */ if (save_orig_name) { - char *p = gzip_base_name (ifname); /* Don't save the directory part. */ - do { - put_char(*p); - } while (*p++); + char *p = gzip_base_name (ifname); /* Don't save the directory part. */ + do { + put_byte (*p); + } while (*p++); } header_bytes = (off_t)outcnt; (void)deflate(); -#if !defined(NO_SIZE_CHECK) && !defined(RECORD_IO) - /* Check input size (but not in VMS -- variable record lengths mess it up) - * and not on MSDOS -- diet in TSR mode reports an incorrect file size) +#ifndef NO_SIZE_CHECK + /* Check input size + * (but not on MSDOS -- diet in TSR mode reports an incorrect file size) */ if (ifile_size != -1L && bytes_in != ifile_size) { - fprintf(stderr, "%s: %s: file size changed while zipping\n", - program_name, ifname); + fprintf(stderr, "%s: %s: file size changed while zipping\n", + program_name, ifname); } #endif /* Write the crc and uncompressed size */ put_long(crc); put_long((ulg)bytes_in); - header_bytes += 2*sizeof(long); + header_bytes += 2*4; flush_outbuf(); return OK; @@ -119,8 +123,7 @@ int file_read(buf, size) len = read_buffer (ifd, buf, size); if (len == 0) return (int)len; if (len == (unsigned)-1) { - read_error(); - return EOF; + read_error(); } crc = updcrc((uch*)buf, len);