post-release administrivia
[debian/gzip] / NEWS
1 GNU gzip NEWS                                    -*- outline -*-
2
3 * Noteworthy changes in release ?.? (????-??-??) [?]
4
5
6 * Noteworthy changes in release 1.4 (2010-01-20) [stable]
7
8 ** Bug fixes
9
10   gzip -d could segfault and/or clobber the stack, possibly leading to
11   arbitrary code execution.  This affects x86_64 but not 32-bit systems.
12   This fixes CVE-2010-0001.
13   For more details, see http://bugzilla.redhat.com/554418
14
15   gzip -d would fail with a CRC error for some valid inputs.
16   So far, the only valid input known to exhibit this failure was
17   compressed "from FAT filesystem (MS-DOS, OS/2, NT)".  In addition,
18   to trigger the failure, your memcpy implementation must copy in
19   the "reverse" order.
20
21
22 * Noteworthy changes in release 1.3.14 (2009-10-30) [beta]
23
24 ** Bug fixes
25
26   gzip no longer fails when there is exactly one trailing NUL byte
27   gzip has always accepted trailing NUL bytes.  Note the plural.
28
29   zdiff would exit with status 2 (indicating an error) rather than 1 to
30   indicate differences when both inputs were compressed and different.
31
32   zdiff would fail to print differences in two compressed inputs
33
34   zgrep -f - didn't work
35
36
37 * Noteworthy changes in release 1.3.13 (2009-09-30) [stable]
38
39 ** Bug fixes
40
41   gzip -d no longer fails with "-" as 2nd or subsequent argument
42
43   gzip no longer ignores a close-induced write failure, e.g., on NFS
44
45   gzip -d no longer segfaults on certain invalid inputs
46
47
48 Major changes in Gzip 1.3.12 (2007-04-13)
49
50 * znew now uses $TMPDIR (default /tmp) instead of always using /tmp.
51
52 * 'gzip -f foo.gz' now creates a file foo.gz.gz instead of complaining.
53
54 * It is now documented that gzip ignores case when examining file name
55   extensions; for example, 'gzip test.Gz' (without -f) fails because
56   the file name ends in '.Gz'.
57
58 Major changes in Gzip 1.3.11 (2007-02-05)
59
60 * As per the GNU coding standards, the behavior of gzip and its
61   companion executables no longer depend on the name used to invoke them.
62   For example, 'gzip' and 'gunzip' are no longer hard links;
63   instead, 'gunzip' is now a small program that invokes 'gzip -d'.
64
65 * zdiff now checks for subsidiary gzip failures, and works around
66   bugs in IRIX 6 sh, Tru64 4.0F ksh, and Solaris 8 bash.
67
68 Major changes in Gzip 1.3.10 (2006-12-30)
69
70 * gzip -c and zcat now work on special files, files with special mode bits,
71   and files with multiple hard links.
72 * gzip -q now exits with status 2 (not 1) when SIGPIPE is received.
73 * zcmp and zdiff did not work in the usual case, due to a typo.
74 * zgrep has many bugs fixed with argument handling, special characters,
75   and exit status.
76 * zless no longer mishandles $%=~ in file names.
77
78 Gzip 1.3.9 (2006-12-15)
79
80 * No major changes; only porting fixes.
81
82 Major changes in Gzip 1.3.8 (2006-12-08)
83
84 * Fix some gzip problems:
85   - A security fix from Debian 1.3.5-5 was inadvertently omitted.
86   - The assembler is now invoked with --noexecstack if supported,
87     so that gzip can better resist stack-smashing attacks.
88
89 Major changes in Gzip 1.3.7 (2006-12-06)
90
91 * Fix some gzip problems:
92   - Refuse to compress setuid or setgid files, or files with the sticky bit.
93   - Fix more race conditions in setting file permissions and owner,
94     removing output files, following symbolic links, and dealing with
95     special files.
96   - Remove most of the code working around ENAMETOOLONG deficiencies.
97     Systems with those deficiencies are long-dead, and the workarounds
98     had race conditions on modern hosts.
99   - Catch CPU time and file size limit signals, too.
100   - Check for read errors when closing files.
101   - Fix a core dump caused by a stray abort mistakenly introduced in 1.3.6.
102 * Fix some gzexe problems:
103   - Improve resistance to denial-of-service attacks.
104   - Fix some quoting and escaping bugs.
105   - Do not assume /tmp is sticky (though it should be!).
106   - Do not assume the working directory can be written.
107   - Rely on PATH in the generated executable, as the man page says.
108   - Don't assume IFS is sane.
109   - Exit with signal's status, if signaled.
110
111 Major changes in Gzip 1.3.6 (2006-11-20)
112
113 * Fix some race conditions in setting file time stamps, permissions, and owner.
114 * Fix some race conditions in signal handling.
115 * When gzip exits due to a signal, it exits with the signal's status, not 1.
116 * gzip now restores file time stamps to the resolution supported by the
117   time-setting primitives of the operating system, typically 1 microsecond.
118   Formerly it restored them only to the nearest second.
119 * gzip -r no longer attempts to reset the last-access times of directories
120   it reads, as this messes up when other processes are reading the directories.
121 * The options --version and --help now work on all gzip-installed executables,
122   and now use a format similar to other GNU programs.
123 * The manual is now distributed under the terms of the GNU Free
124   Documentation License without invariant sections or cover texts.
125 * Port to current versions of Autoconf, Automake, and Gnulib.
126
127 Major changes from 1.3.4 to 1.3.5
128 * gzip now removes any output symlink before writing output file.
129 * zgrep etc. scripts now port to POSIX 1003.1-2001 hosts.
130 * zforce no longer assumes 14-byte file name length limit.
131 * zless is now implemented using less and LESSOPEN, not zmore and PAGER.
132 * assembly-language speedups reenabled; were mistakenly disabled in 1.3.
133
134 Major changes from 1.3.3 to 1.3.4
135 * Less output is lost when decompressing a truncated file.
136 * The manual is now distributed under the terms of the GNU Free
137   Documentation License.
138
139 No major changes in 1.3.2 or 1.3.3 (bug fixes only)
140
141 Major changes from 1.3 to 1.3.1
142 * zgrep now supports --, -H, -h, -L, -l, -C, -d, -m and their long equivalents.
143
144 Major changes from 1.2.4 to 1.3
145 * Add support for large files, e.g. files larger than 2 GB on Solaris 2.6.
146 * Adjust file size listing format for files larger than 10 GB.
147 * New command `zless'.
148 * `zdiff' now reports exit status like `diff' does.
149 * `zcat' is now always called `zcat', not `gzcat'.
150   Similarly for `zdiff', `zgrep', `zmore', `znew', `zforce'.
151 * Warn about a compressed file's trailing zeros only if verbose,
152   for compatibility with recent versions of GNU tar.
153 * Conform to changes to GNU makefile standards.
154 * Port to Autoconf 2.13.
155 * Convert to Automake.
156 * Fix bugs in the following areas:
157   - files larger than 4 GB
158   - security hole involving symlinks from /tmp
159   - security hole involving long file names
160   - permissions bug when compressing a symbolic link to a file
161   - core dumps
162   - concatenated compressed files on INBUFSIZ boundaries
163   - porting bugs on hosts with signed chars
164   - porting bug with upper and lower case
165   - porting bug for hosts that reserve the names `basename' or `warning'
166
167 Major changes from 1.2.3 to 1.2.4
168 * By default, do not restore file name and timestamp from those saved
169   inside the .gz file (behave as 'compress'). Added the --name option
170   to force name and timestamp restoration.
171 * Accept - as synonym for stdin.
172 * Use manlinks=so or ln to support either hard links or .so in man pages
173 * Accept foo.gz~ in zdiff.
174 * Added support for Windows NT
175 * Handle ENAMETOOLONG for strict Posix systems
176 * Use --recursive instead of --recurse to comply with Webster and
177   the GNU stdandard.
178 * Allow installation of shell scripts with a g prefix: make G=g install
179 * Install by default zcat as gzcat if gzcat already exists in path.
180 * Let zmore behave as more when invoked without parameters (give help)
181 * Let gzip --list reject files not in gzip format even with --force.
182 * Don't complain about non gzip files for options -rt or -rl.
183 * Added advice in INSTALL for several systems.
184
185 Major changes from 1.2.2 to 1.2.3
186 * Don't display the output name when decompressing except with --verbose.
187 * Remove usage of alloca in getopt.c and all makefiles.
188 * Added the zfile shell script in subdirectory sample.
189 * Moved the list of compiler bugs from README to INSTALL.
190 * Added vms/Readme.vms.
191
192 Major changes from 1.2.1 to 1.2.2
193 * Fix a compilation error on Sun with cc (worked with gcc).
194
195 Major changes from 1.2 to 1.2.1
196 * Let zmore act as more if the data is not gzipped.
197 * made gzexe more secure (don't rely on PATH).
198 * By default, display output name only when the name was actually truncated.
199
200 Major changes from 1.1.2 to 1.2
201 * Added the --list option to display the file characteristics.
202 * Added the --no-name option: do not save or restore original filename
203   Save the original name by default.
204 * Allow gunzip --suffix "" to attempt decompression on any file
205   regardless of its extension if an original name is present.
206 * Add support for the SCO compress -H format.
207 * gzip --fast now compresses faster (speed close to that of compress)
208   with degraded compression ratio (but still better than compress).
209   Default level changed to -6 (acts exactly as previous level -5) to
210   be a better indication of its placement in the speed/ratio range.
211 * Use smart name truncation: 123456789012.c -> 123456789.c.gz
212    instead of 12345678901.gz
213 * With --force, let zcat pass non gzip'ed data unchanged (zcat == cat)
214 * Added the zgrep shell script.
215 * Made sub.c useful for 16 bit sound, 24 bit images, etc..
216 * Supress warnings about suffix for gunzip -r, except with --verbose.
217 * On MSDOS, use .gz extension when possible (files without extension)
218 * Moved the sample programs to a subdirectory sample.
219 * Added a "Special targets" section in INSTALL.
220
221 Major changes from 1.1.1 to 1.1.2.
222 * Fix serious bug for VMS (-gz not removed when decompressing).
223 * Allow suffix other than .gz in znew.
224 * Do not display compression ratio when decompressing stdin.
225 * In zmore.in, work around brain damaged stty -g (Ultrix).
226 * Display a correct compression ratio for .Z files.
227 * Added .z to .gz renaming script in INTALL.
228 * Allow setting CFLAGS in configure.
229
230 Major changes from 1.1 to 1.1.1.
231 * Fix serious bug in vms.c (affects Vax/VMS only).
232 * Added --ascii option.
233 * Add workaround in configure.in for Ultrix (quote eval argument)
234
235 Major changes from 1.0.7 to 1.1.
236 * Use .gz suffix by default, add --suffix option.
237 * Let gunzip accept a "_z" suffix (used by one 'compress' on Vax/VMS).
238 * Quit when reading garbage from stdin instead of reporting an error.
239 * Added makefile for VAX/MMS and support for wildcards on VMS.
240 * Added support for MSC under OS/2.
241 * Added support for Prime/PRIMOS.
242 * Display compression ratio also when decompressing (with --verbose).
243 * Quit after --version (GNU standard)
244 * Use --force to bypass isatty() check
245 * Continue processing other files in case of recoverable error.
246 * Added comparison of zip and gzip in the readme file.
247 * Added small sample programs (ztouch, sub, add)
248 * Use less memory when compiled with -DSMALL_MEM (for MSDOS).
249 * Remove the "off by more than one minute" time stamp kludge
250
251 Major changes from 1.0.6 to 1.0.7.
252 * Allow zmore to read from standard input (like more).
253 * Support the 68000 (Atari ST) in match.S.
254 * Retry partial writes (required on Linux when gzip is suspended in a pipe).
255 * Allow full pathnames and renamings in gzexe.
256 * Don't let gzexe compress setuid executables or gzip itself.
257 * Added vms/Makefile.gcc for gcc on the Vax.
258 * Allow installation of binaries and shell scripts in different dirs.
259 * Allows complex PAGER variable in zmore (e.g.: PAGER="col -x | more")
260 * Allow installation of zcat as gzcat.
261 * Several small changes for portability to old or weird systems.
262 * Suppress help message and send compressed data to the terminal when
263   gzip is invoked without parameters and without redirection.
264 *  Add compile option GNU_STANDARD to respect the GNU coding standards:
265    with -DGNU_STANDARD, behave as gzip even if invoked under the name gunzip.
266 (I don't like the last two changes, which were requested by the FSF.)
267
268 Major changes from 1.0.5 to 1.0.6.
269 * Let gzexe detect executables that are already gzexe'd.
270 * Keep file attributes in znew and gzexe if cpmod is available.
271 * Don't try restoring record format on VMS (1.0.5 did not work correctly)
272 * Added asm version for 68000 in amiga/match.a.
273   Use asm version for Atari TT and NeXT.
274 * For OS/2, assume HPFS by default, add flag OS2FAT if necessary.
275 * Fixed some bugs in zdiff and define zcmp as a link to zdiff.
276
277
278 Major changes from 1.0.4 to 1.0.5.
279 * For VMS, restore the file type for variable record format, otherwise
280     extract in fixed length format (not perfect, but better than
281     forcing all files to be in stream_LF format).
282 * For VMS, use "-z" default suffix and accept a version number in file names.
283 * For Unix, allow compression of files with name ending in 'z'. Use only
284   .z, .*-z, .tgz, .taz as valid gzip extensions. In the last two cases,
285   extract to .tar by default.
286 * On some versions of MSDOS, files with a 3 character extension could not
287   be compressed.
288 * Garbage collect files in /tmp created by gzexe.
289 * Fix the 'OS code' byte in the gzip header.
290 * For the Amiga, add the missing utime.h and add support for gcc.
291
292
293 Major changes from 1.0.3 to 1.0.4.
294 * Added optimized asm version for 68020.
295 * Add support for DJGPP.
296
297 * Add support for the Atari ST.
298 * Added zforce to rename gzip'ed files with truncated names.
299 * Do not install with name uncompress (some systems rely on the
300   absence of any check in the old uncompress).
301 * Added missing function (fcfree) in msdos/tailor.c
302 * Let gunzip handle .tgz files, and let gzip skip them.
303 * Added -d option (decompress) for gzexe and try preserving file permissions.
304 * Suppress all warnings with -q.
305 * Use GZIP_OPT for VMS to avoid conflict with program name.
306 * ... and many other small changes (see ChangeLog)
307
308
309 Major changes from 1.0.2 to 1.0.3
310 * Added -K option for znew to keep old .Z files if smaller
311 * Added -q option (quiet) to cancel -v in GZIP env variable.
312 * Made gzexe safer on systems with filename limitation to 14 chars.
313 * Fixed bugs in handling of GZIP env variable and incorrect free with Turbo C.
314
315
316 Major changes from 1.0.1 to 1.0.2
317 * Added env variable GZIP for default options. Example:
318    for sh:   GZIP="-8 -v"; export GZIP
319    for csh:  setenv GZIP "-8 -v"
320 * Added support for the Amiga.
321 * znew now keeps the old .Z if it is smaller than the .z file.
322   This can happen for some large and very redundant files.
323 * Do not complain about trailing garbage for record oriented IO (Vax/VMS).
324   This implies however that multi-part gzip files are not supported
325   on such systems.
326 * Added gzexe to compress rarely used executables.
327 * Reduce memory usage (required for MSDOS and useful on all systems).
328 * Preserve time stamp in znew -P (pipe option) if touch -r works.
329
330
331 Major changes from 1.0 to 1.0.1
332 * fix trivial errors in the Borland makefile (msdos/Makefile.bor)
333
334
335 Major changes from 0.8.2 to 1.0
336 * gzip now runs on Vax/VMS
337 * gzip will not not overwrite files without -f when using /bin/sh in
338   background.
339 * Support the test option -t for compressed (.Z) files.
340   Allow some data recovery for bad .Z files.
341 * Added makefiles for MSDOS (Only tested for MSC, not Borland).
342 * still more changes to configure for several systems
343
344
345 Major changes from 0.8.1 to 0.8.2:
346 * yet more changes to configure for Linux and other systems
347 * Allow zcat on a file with multiple links.
348
349
350 Major changes from 0.8 to 0.8.1:
351 * znew has now a pipe option -P to reduce the disk space requirements,
352   but this option does not preserve timestamps.
353 * Fixed some #if directives for compilation with TurboC.
354
355
356 Major changes from 0.7 to 0.8:
357 * gzip can now extract .z files created by 'pack'.
358 * configure should no longer believe that every machine is a 386
359 * Fix the entry for /etc/magic in INSTALL.
360 * Add patch for GNU tar 1.11.1 and a pointer to crypt++.el
361 * Uncompress files with multiple links only with -f.
362 * Fix for uncompress of .Z files on 16-bit machines
363 * Create a correct output name for file names of exactly N-1 chars when
364   the system has a limit of N chars.
365
366
367 Major changes from 0.6 to 0.7:
368 * Use "make check" instead of "make test".
369 * Keep time stamp and pass options to gzip in znew.
370 * Do not create .z.z files with gzip -r.
371 * Allow again gunzip .zip files (was working in 0.5)
372 * Allow again compilation with TurboC 2.0 (was working in 0.4)
373
374
375 Major changes form 0.5 to 0.6:
376 * gunzip reported an error when extracting certain .z files. The .z files
377   produced by gzip 0.5 are correct and can be read by gunzip 0.6.
378 * gunzip now supports multiple compressed members within a single .z file.
379 * Fix the check for i386 in configure.
380 * Added "make test" to check for compiler bugs. (gcc -finline-functions
381   is broken at least on the NeXT.)
382 * Use environment variable PAGER in zmore if it is defined.
383 * Accept gzcat in addition to zcat for people having /usr/bin before
384   /usr/local/bin in their path.
385
386
387 ========================================================================
388
389 Copyright (C) 1999, 2001-2002, 2006-2007, 2009-2010 Free Software Foundation,
390 Inc.
391 Copyright (C) 1992, 1993 Jean-loup Gailly
392
393 Permission is granted to copy, distribute and/or modify this document
394 under the terms of the GNU Free Documentation License, Version 1.3 or
395 any later version published by the Free Software Foundation; with no
396 Invariant Sections, with no Front-Cover Texts, and with no Back-Cover
397 Texts.  A copy of the license is included in the ``GNU Free
398 Documentation License'' file as part of this distribution.