shuf: correctly document --head-count
[platform/upstream/coreutils.git] / NEWS
1 GNU coreutils NEWS                                    -*- outline -*-
2
3 * Noteworthy changes in release 7.0 (????-??-??) [beta]
4
5 ** New programs
6
7   timeout: Run a command with bounded time.
8   truncate: Set the size of a file to a specified size.
9
10 ** New features
11
12   comm now verifies that the inputs are in sorted order.  This check can
13   be turned off with the --nocheck-order option.
14
15   comm accepts new option, --output-delimiter=STR, that allows specification
16   of an output delimiter other than the default single TAB.
17
18   dd accepts iflag=fullblock to make it accumulate full input blocks.
19   With this new option, after a short read, dd repeatedly calls read,
20   until it fills the incomplete block, reaches EOF, or encounters an error.
21
22   md5sum now accepts the new option, --quiet, to suppress the printing of
23   'OK' messages.  sha1sum, sha224sum, sha384sum, and sha512sum accept it, too.
24
25   shuf honors the --zero-terminated (-z) option, even with --input-range=LO-HI
26
27   sort accepts a new option, --files0-from=F, that specifies a file
28   containing a null-separated list of files to sort.  This list is used
29   instead of filenames passed on the command-line to avoid problems with
30   maximum command-line (argv) length.
31
32   sort accepts a new option --batch-size=NMERGE, where NMERGE
33   represents the maximum number of inputs that will be merged at once.
34   When processing more than NMERGE inputs, sort uses temporary files.
35
36 ** Bug fixes
37
38   chcon --verbose now prints a newline after each message
39
40   od no longer suffers from platform bugs in printf(3).  This is
41   probably most noticeable when using 'od -tfL' to print long doubles.
42
43   shuf --head-count is now correctly documented.  The documentation
44   previously claimed it was called --head-lines.
45
46 ** Improvements
47
48   Improved support for access control lists (ACLs): On MacOS X, Solaris 7..10,
49   HP-UX 11, Tru64, AIX, IRIX 6.5, and Cygwin, "ls -l" now displays the presence
50   of an ACL on a file via a '+' sign after the mode, and "cp -p" copies ACLs.
51
52   join has significantly better performance due to better memory management
53
54   od now aligns fields across lines when printing multiple -t
55   specifiers, and no longer prints fields that resulted entirely from
56   padding the input out to the least common multiple width.
57
58 ** Changes in behavior
59
60   stat's --context (-Z) option has always been a no-op.
61   Now it evokes a warning that it is obsolete and will be removed.
62
63
64 * Noteworthy changes in release 6.12 (2008-05-31) [stable]
65
66 ** Bug fixes
67
68   chcon, runcon: --help output now includes the bug-reporting address
69
70   cp -p copies permissions more portably.  For example, on MacOS X 10.5,
71   "cp -p some-fifo some-file" no longer fails while trying to copy the
72   permissions from the some-fifo argument.
73
74   id with no options now prints the SELinux context only when invoked
75   with no USERNAME argument.
76
77   id and groups once again print the AFS-specific nameless group-ID (PAG).
78   Printing of such large-numbered, kernel-only (not in /etc/group) group-IDs
79   was suppressed in 6.11 due to ignorance that they are useful.
80
81   uniq: avoid subtle field-skipping malfunction due to isblank misuse.
82   In some locales on some systems, isblank(240) (aka &nbsp) is nonzero.
83   On such systems, uniq --skip-fields=N would fail to skip the proper
84   number of fields for some inputs.
85
86   tac: avoid segfault with --regex (-r) and multiple files, e.g.,
87   "echo > x; tac -r x x".  [bug present at least in textutils-1.8b, from 1992]
88
89 ** Changes in behavior
90
91   install once again sets SELinux context, when possible
92   [it was deliberately disabled in 6.9.90]
93
94
95 * Noteworthy changes in release 6.11 (2008-04-19) [stable]
96
97 ** Bug fixes
98
99   configure --enable-no-install-program=groups now works.
100
101   "cp -fR fifo E" now succeeds with an existing E.  Before this fix, using
102   -fR to copy a fifo or "special" file onto an existing file would fail
103   with EEXIST.  Now, it once again unlinks the destination before trying
104   to create the destination file.  [bug introduced in coreutils-5.90]
105
106   dd once again works with unnecessary options like if=/dev/stdin and
107   of=/dev/stdout.  [bug introduced in fileutils-4.0h]
108
109   id now uses getgrouplist, when possible.  This results in
110   much better performance when there are many users and/or groups.
111
112   ls no longer segfaults on files in /proc when linked with an older version
113   of libselinux.  E.g., ls -l /proc/sys would dereference a NULL pointer.
114
115   md5sum would segfault for invalid BSD-style input, e.g.,
116   echo 'MD5 (' | md5sum -c -  Now, md5sum ignores that line.
117   sha1sum, sha224sum, sha384sum, and sha512sum are affected, too.
118   [bug introduced in coreutils-5.1.0]
119
120   md5sum -c would accept a NUL-containing checksum string like "abcd\0..."
121   and would unnecessarily read and compute the checksum of the named file,
122   and then compare that checksum to the invalid one: guaranteed to fail.
123   Now, it recognizes that the line is not valid and skips it.
124   sha1sum, sha224sum, sha384sum, and sha512sum are affected, too.
125   [bug present in the original version, in coreutils-4.5.1, 1995]
126
127   "mkdir -Z x dir" no longer segfaults when diagnosing invalid context "x"
128   mkfifo and mknod would fail similarly.  Now they're fixed.
129
130   mv would mistakenly unlink a destination file before calling rename,
131   when the destination had two or more hard links.  It no longer does that.
132   [bug introduced in coreutils-5.3.0]
133
134   "paste -d'\' file" no longer overruns memory (heap since coreutils-5.1.2,
135   stack before then) [bug present in the original version, in 1992]
136
137   "pr -e" with a mix of backspaces and TABs no longer corrupts the heap
138   [bug present in the original version, in 1992]
139
140   "ptx -F'\' long-file-name" would overrun a malloc'd buffer and corrupt
141   the heap.  That was triggered by a lone backslash (or odd number of them)
142   at the end of the option argument to --flag-truncation=STRING (-F),
143   --word-regexp=REGEXP (-W), or --sentence-regexp=REGEXP (-S).
144
145   "rm -r DIR" would mistakenly declare to be "write protected" -- and
146   prompt about -- full DIR-relative names longer than MIN (PATH_MAX, 8192).
147
148   "rmdir --ignore-fail-on-non-empty" detects and ignores the failure
149   in more cases when a directory is empty.
150
151   "seq -f % 1" would issue the erroneous diagnostic "seq: memory exhausted"
152   rather than reporting the invalid string format.
153   [bug introduced in coreutils-6.0]
154
155 ** New features
156
157   join now verifies that the inputs are in sorted order.  This check can
158   be turned off with the --nocheck-order option.
159
160   sort accepts the new option --sort=WORD, where WORD can be one of
161   general-numeric, month, numeric or random.  These are equivalent to the
162   options --general-numeric-sort/-g, --month-sort/-M, --numeric-sort/-n
163   and --random-sort/-R, resp.
164
165 ** Improvements
166
167   id and groups work around an AFS-related bug whereby those programs
168   would print an invalid group number, when given no user-name argument.
169
170   ls --color no longer outputs unnecessary escape sequences
171
172   seq gives better diagnostics for invalid formats.
173
174 ** Portability
175
176   rm now works properly even on systems like BeOS and Haiku,
177   which have negative errno values.
178
179 ** Consistency
180
181   install, mkdir, rmdir and split now write --verbose output to stdout,
182   not to stderr.
183
184
185 * Noteworthy changes in release 6.10 (2008-01-22) [stable]
186
187 ** Bug fixes
188
189   Fix a non-portable use of sed in configure.ac.
190   [bug introduced in coreutils-6.9.92]
191
192
193 * Noteworthy changes in release 6.9.92 (2008-01-12) [beta]
194
195 ** Bug fixes
196
197   cp --parents no longer uses uninitialized memory when restoring the
198   permissions of a just-created destination directory.
199   [bug introduced in coreutils-6.9.90]
200
201   tr's case conversion would fail in a locale with differing numbers
202   of lower case and upper case characters.  E.g., this would fail:
203   env LC_CTYPE=en_US.ISO-8859-1 tr '[:upper:]' '[:lower:]'
204   [bug introduced in coreutils-6.9.90]
205
206 ** Improvements
207
208   "touch -d now writable-but-owned-by-someone-else" now succeeds
209   whenever that same command would succeed without "-d now".
210   Before, it would work fine with no -d option, yet it would
211   fail with the ostensibly-equivalent "-d now".
212
213
214 * Noteworthy changes in release 6.9.91 (2007-12-15) [beta]
215
216 ** Bug fixes
217
218   "ls -l" would not output "+" on SELinux hosts unless -Z was also given.
219
220   "rm" would fail to unlink a non-directory when run in an environment
221   in which the user running rm is capable of unlinking a directory.
222   [bug introduced in coreutils-6.9]
223
224
225 * Noteworthy changes in release 6.9.90 (2007-12-01) [beta]
226
227 ** New programs
228
229   arch: equivalent to uname -m, not installed by default
230   But don't install this program on Solaris systems.
231
232   chcon: change the SELinux security context of a file
233
234   mktemp: create a temporary file or directory (or names)
235
236   runcon: run a program in a different SELinux security context
237
238 ** Programs no longer installed by default
239
240   hostname, su
241
242 ** Changes in behavior
243
244   cp, by default, refuses to copy through a dangling destination symlink
245   Set POSIXLY_CORRECT if you require the old, risk-prone behavior.
246
247   pr -F no longer suppresses the footer or the first two blank lines in
248   the header.  This is for compatibility with BSD and POSIX.
249
250   tr now warns about an unescaped backslash at end of string.
251   The tr from coreutils-5.2.1 and earlier would fail for such usage,
252   and Solaris' tr ignores that final byte.
253
254 ** New features
255
256   Add SELinux support, based on the patch from Fedora:
257   * cp accepts new --preserve=context option.
258   * "cp -a" works with SELinux:
259   Now, cp -a attempts to preserve context, but failure to do so does
260   not change cp's exit status.  However "cp --preserve=context" is
261   similar, but failure *does* cause cp to exit with nonzero status.
262   * install accepts new "-Z, --context=C" option.
263   * id accepts new "-Z" option.
264   * stat honors the new %C format directive: SELinux security context string
265   * ls accepts a slightly modified -Z option.
266   * ls: contrary to Fedora version, does not accept --lcontext and --scontext
267
268   The following commands and options now support the standard size
269   suffixes kB, M, MB, G, GB, and so on for T, P, Y, Z, and Y:
270   head -c, head -n, od -j, od -N, od -S, split -b, split -C,
271   tail -c, tail -n.
272
273   cp -p tries to preserve the GID of a file even if preserving the UID
274   is not possible.
275
276   uniq accepts a new option: --zero-terminated (-z).  As with the sort
277   option of the same name, this makes uniq consume and produce
278   NUL-terminated lines rather than newline-terminated lines.
279
280   wc no longer warns about character decoding errors in multibyte locales.
281   This means for example that "wc /bin/sh" now produces normal output
282   (though the word count will have no real meaning) rather than many
283   error messages.
284
285 ** New build options
286
287   By default, "make install" no longer attempts to install (or even build) su.
288   To change that, use ./configure --enable-install-program=su.
289   If you also want to install the new "arch" program, do this:
290   ./configure --enable-install-program=arch,su.
291
292   You can inhibit the compilation and installation of selected programs
293   at configure time.  For example, to avoid installing "hostname" and
294   "uptime", use ./configure --enable-no-install-program=hostname,uptime
295   Note: currently, "make check" passes, even when arch and su are not
296   built (that's the new default).  However, if you inhibit the building
297   and installation of other programs, don't be surprised if some parts
298   of "make check" fail.
299
300 ** Remove deprecated options
301
302   df no longer accepts the --kilobytes option.
303   du no longer accepts the --kilobytes or --megabytes options.
304   ls no longer accepts the --kilobytes option.
305   ptx longer accepts the --copyright option.
306   who no longer accepts -i or --idle.
307
308 ** Improved robustness
309
310   ln -f can no longer silently clobber a just-created hard link.
311   In some cases, ln could be seen as being responsible for data loss.
312   For example, given directories a, b, c, and files a/f and b/f, we
313   should be able to do this safely: ln -f a/f b/f c && rm -f a/f b/f
314   However, before this change, ln would succeed, and thus cause the
315   loss of the contents of a/f.
316
317   stty no longer silently accepts certain invalid hex values
318   in its 35-colon command-line argument
319
320 ** Bug fixes
321
322   chmod no longer ignores a dangling symlink.  Now, chmod fails
323   with a diagnostic saying that it cannot operate on such a file.
324   [bug introduced in coreutils-5.1.0]
325
326   cp attempts to read a regular file, even if stat says it is empty.
327   Before, "cp /proc/cpuinfo c" would create an empty file when the kernel
328   reports stat.st_size == 0, while "cat /proc/cpuinfo > c" would "work",
329   and create a nonempty one. [bug introduced in coreutils-6.0]
330
331   cp --parents no longer mishandles symlinks to directories in file
332   name components in the source, e.g., "cp --parents symlink/a/b d"
333   no longer fails.  Also, 'cp' no longer considers a destination
334   symlink to be the same as the referenced file when copying links
335   or making backups.  For example, if SYM is a symlink to FILE,
336   "cp -l FILE SYM" now reports an error instead of silently doing
337   nothing.  The behavior of 'cp' is now better documented when the
338   destination is a symlink.
339
340   "cp -i --update older newer" no longer prompts; same for mv
341
342   "cp -i" now detects read errors on standard input, and no longer consumes
343   too much seekable input; same for ln, install, mv, and rm.
344
345   cut now diagnoses a range starting with zero (e.g., -f 0-2) as invalid;
346   before, it would treat it as if it started with 1 (-f 1-2).
347
348   "cut -f 2-0" now fails; before, it was equivalent to "cut -f 2-"
349
350   cut now diagnoses the '-' in "cut -f -" as an invalid range, rather
351   than interpreting it as the unlimited range, "1-".
352
353   date -d now accepts strings of the form e.g., 'YYYYMMDD +N days',
354   in addition to the usual 'YYYYMMDD N days'.
355
356   du -s now includes the size of any stat'able-but-inaccessible directory
357   in the total size.
358
359   du (without -s) prints whatever it knows of the size of an inaccessible
360   directory.  Before, du would print nothing for such a directory.
361
362   ls -x DIR would sometimes output the wrong string in place of the
363   first entry.  [introduced in coreutils-6.8]
364
365   ls --color would mistakenly color a dangling symlink as if it were
366   a regular symlink.  This would happen only when the dangling symlink
367   was not a command-line argument and in a directory with d_type support.
368   [introduced in coreutils-6.0]
369
370   ls --color, (with a custom LS_COLORS envvar value including the
371   ln=target attribute) would mistakenly output the string "target"
372   before the name of each symlink.  [introduced in coreutils-6.0]
373
374   od's --skip (-j) option now works even when the kernel says that a
375   nonempty regular file has stat.st_size = 0.  This happens at least
376   with files in /proc and linux-2.6.22.
377
378   "od -j L FILE" had a bug: when the number of bytes to skip, L, is exactly
379   the same as the length of FILE, od would skip *no* bytes.  When the number
380   of bytes to skip is exactly the sum of the lengths of the first N files,
381   od would skip only the first N-1 files. [introduced in textutils-2.0.9]
382
383   ./printf %.10000000f 1 could get an internal ENOMEM error and generate
384   no output, yet erroneously exit with status 0.  Now it diagnoses the error
385   and exits with nonzero status.  [present in initial implementation]
386
387   seq no longer mishandles obvious cases like "seq 0 0.000001 0.000003",
388   so workarounds like "seq 0 0.000001 0.0000031" are no longer needed.
389
390   seq would mistakenly reject some valid format strings containing %%,
391   and would mistakenly accept some invalid ones. e.g., %g%% and %%g, resp.
392
393   "seq .1 .1" would mistakenly generate no output on some systems
394
395   Obsolete sort usage with an invalid ordering-option character, e.g.,
396   "env _POSIX2_VERSION=199209 sort +1x" no longer makes sort free an
397   invalid pointer [introduced in coreutils-6.5]
398
399   sorting very long lines (relative to the amount of available memory)
400   no longer provokes unaligned memory access
401
402   split --line-bytes=N (-C N) no longer creates an empty file
403   [this bug is present at least as far back as textutils-1.22 (Jan, 1997)]
404
405   tr -c no longer aborts when translating with Set2 larger than the
406   complement of Set1.  [present in the original version, in 1992]
407
408   tr no longer rejects an unmatched [:lower:] or [:upper:] in SET1.
409   [present in the original version]
410
411
412 * Noteworthy changes in release 6.9 (2007-03-22) [stable]
413
414 ** Bug fixes
415
416   cp -x (--one-file-system) would fail to set mount point permissions
417
418   The default block size and output format for df -P are now unaffected by
419   the DF_BLOCK_SIZE, BLOCK_SIZE, and BLOCKSIZE environment variables.  It
420   is still affected by POSIXLY_CORRECT, though.
421
422   Using pr -m -s (i.e. merging files, with TAB as the output separator)
423   no longer inserts extraneous spaces between output columns.
424
425 * Noteworthy changes in release 6.8 (2007-02-24) [not-unstable]
426
427 ** Bug fixes
428
429   chgrp, chmod, and chown now honor the --preserve-root option.
430   Before, they would warn, yet continuing traversing and operating on /.
431
432   chmod no longer fails in an environment (e.g., a chroot) with openat
433   support but with insufficient /proc support.
434
435   "cp --parents F/G D" no longer creates a directory D/F when F is not
436   a directory (and F/G is therefore invalid).
437
438   "cp --preserve=mode" would create directories that briefly had
439   too-generous permissions in some cases.  For example, when copying a
440   directory with permissions 777 the destination directory might
441   temporarily be setgid on some file systems, which would allow other
442   users to create subfiles with the same group as the directory.  Fix
443   similar problems with 'install' and 'mv'.
444
445   cut no longer dumps core for usage like "cut -f2- f1 f2" with two or
446   more file arguments.  This was due to a double-free bug, introduced
447   in coreutils-5.3.0.
448
449   dd bs= operands now silently override any later ibs= and obs=
450   operands, as POSIX and tradition require.
451
452   "ls -FRL" always follows symbolic links on Linux.  Introduced in
453   coreutils-6.0.
454
455   A cross-partition "mv /etc/passwd ~" (by non-root) now prints
456   a reasonable diagnostic.  Before, it would print this:
457   "mv: cannot remove `/etc/passwd': Not a directory".
458
459   pwd and "readlink -e ." no longer fail unnecessarily when a parent
460   directory is unreadable.
461
462   rm (without -f) could prompt when it shouldn't, or fail to prompt
463   when it should, when operating on a full name longer than 511 bytes
464   and getting an ENOMEM error while trying to form the long name.
465
466   rm could mistakenly traverse into the wrong directory under unusual
467   conditions: when a full name longer than 511 bytes specifies a search-only
468   directory, and when forming that name fails with ENOMEM, rm would attempt
469   to open a truncated-to-511-byte name with the first five bytes replaced
470   with "[...]".  If such a directory were to actually exist, rm would attempt
471   to remove it.
472
473   "rm -rf /etc/passwd" (run by non-root) now prints a diagnostic.
474   Before it would print nothing.
475
476   "rm --interactive=never F" no longer prompts for an unwritable F
477
478   "rm -rf D" would emit an misleading diagnostic when failing to
479   remove a symbolic link within the unwritable directory, D.
480   Introduced in coreutils-6.0.  Similarly, when a cross-partition
481   "mv" fails because the source directory is unwritable, it now gives
482   a reasonable diagnostic.  Before, this would print
483     $ mkdir /tmp/x; touch /tmp/x/y; chmod -w /tmp/x;
484     $ test $(stat -c %d /tmp/x) -ne $(stat -c %d .) && mv /tmp/x/y .
485     mv: cannot remove `/tmp/x/y': Not a directory
486   Now it prints this:
487     mv: cannot remove `/tmp/x/y': Permission denied.
488
489 ** New features
490
491   sort's new --compress-program=PROG option specifies a compression
492   program to use when writing and reading temporary files.
493   This can help save both time and disk space when sorting large inputs.
494
495   sort accepts the new option -C, which acts like -c except no diagnostic
496   is printed.  Its --check option now accepts an optional argument, and
497   --check=quiet and --check=silent are now aliases for -C, while
498   --check=diagnose-first is an alias for -c or plain --check.
499
500
501 * Noteworthy changes in release 6.7 (2006-12-08) [stable]
502
503 ** Bug fixes
504
505   When cp -p copied a file with special mode bits set, the same bits
506   were set on the copy even when ownership could not be preserved.
507   This could result in files that were setuid to the wrong user.
508   To fix this, special mode bits are now set in the copy only if its
509   ownership is successfully preserved.  Similar problems were fixed
510   with mv when copying across file system boundaries.  This problem
511   affects all versions of coreutils through 6.6.
512
513   cp --preserve=ownership would create output files that temporarily
514   had too-generous permissions in some cases.  For example, when
515   copying a file with group A and mode 644 into a group-B sticky
516   directory, the output file was briefly readable by group B.
517   Fix similar problems with cp options like -p that imply
518   --preserve=ownership, with install -d when combined with either -o
519   or -g, and with mv when copying across file system boundaries.
520   This bug affects all versions of coreutils through 6.6.
521
522   du --one-file-system (-x) would skip subdirectories of any directory
523   listed as second or subsequent command line argument.  This bug affects
524   coreutils-6.4, 6.5 and 6.6.
525
526
527 * Noteworthy changes in release 6.6 (2006-11-22) [stable]
528
529 ** Bug fixes
530
531   ls would segfault (dereference a NULL pointer) for a file with a
532   nameless group or owner.  This bug was introduced in coreutils-6.5.
533
534   A bug in the latest official m4/gettext.m4 (from gettext-0.15)
535   made configure fail to detect gettext support, due to the unusual
536   way in which coreutils uses AM_GNU_GETTEXT.
537
538 ** Improved robustness
539
540   Now, du (and the other fts clients: chmod, chgrp, chown) honor a
541   trailing slash in the name of a symlink-to-directory even on
542   Solaris 9, by working around its buggy fstatat implementation.
543
544
545 * Major changes in release 6.5 (2006-11-19) [stable]
546
547 ** Bug fixes
548
549   du (and the other fts clients: chmod, chgrp, chown) would exit early
550   when encountering an inaccessible directory on a system with native
551   openat support (i.e., linux-2.6.16 or newer along with glibc-2.4
552   or newer).  This bug was introduced with the switch to gnulib's
553   openat-based variant of fts, for coreutils-6.0.
554
555   "ln --backup f f" now produces a sensible diagnostic
556
557 ** New features
558
559   rm accepts a new option: --one-file-system
560
561
562 * Major changes in release 6.4 (2006-10-22) [stable]
563
564 ** Bug fixes
565
566   chgrp and chown would malfunction when invoked with both -R and -H and
567   with one or more of the following: --preserve-root, --verbose, --changes,
568   --from=o:g (chown only).  This bug was introduced with the switch to
569   gnulib's openat-based variant of fts, for coreutils-6.0.
570
571   cp --backup dir1 dir2, would rename an existing dir2/dir1 to dir2/dir1~.
572   This bug was introduced in coreutils-6.0.
573
574   With --force (-f), rm no longer fails for ENOTDIR.
575   For example, "rm -f existing-non-directory/anything" now exits
576   successfully, ignoring the error about a nonexistent file.
577
578
579 * Major changes in release 6.3 (2006-09-30) [stable]
580
581 ** Improved robustness
582
583   pinky no longer segfaults on Darwin 7.9.0 (MacOS X 10.3.9) due to a
584   buggy native getaddrinfo function.
585
586   rm works around a bug in Darwin 7.9.0 (MacOS X 10.3.9) that would
587   sometimes keep it from removing all entries in a directory on an HFS+
588   or NFS-mounted partition.
589
590   sort would fail to handle very large input (around 40GB) on systems with a
591   mkstemp function that returns a file descriptor limited to 32-bit offsets.
592
593 ** Bug fixes
594
595   chmod would fail unnecessarily in an unusual case: when an initially-
596   inaccessible argument is rendered accessible by chmod's action on a
597   preceding command line argument.  This bug also affects chgrp, but
598   it is harder to demonstrate.  It does not affect chown.  The bug was
599   introduced with the switch from explicit recursion to the use of fts
600   in coreutils-5.1.0 (2003-10-15).
601
602   cp -i and mv -i occasionally neglected to prompt when the copy or move
603   action was bound to fail.  This bug dates back to before fileutils-4.0.
604
605   With --verbose (-v), cp and mv would sometimes generate no output,
606   or neglect to report file removal.
607
608   For the "groups" command:
609
610     "groups" no longer prefixes the output with "user :" unless more
611     than one user is specified; this is for compatibility with BSD.
612
613     "groups user" now exits nonzero when it gets a write error.
614
615     "groups" now processes options like --help more compatibly.
616
617   shuf would infloop, given 8KB or more of piped input
618
619 ** Portability
620
621   Versions of chmod, chown, chgrp, du, and rm (tools that use openat etc.)
622   compiled for Solaris 8 now also work when run on Solaris 10.
623
624
625 * Major changes in release 6.2 (2006-09-18) [stable candidate]
626
627 ** Changes in behavior
628
629   mkdir -p and install -d (or -D) now use a method that forks a child
630   process if the working directory is unreadable and a later argument
631   uses a relative file name.  This avoids some race conditions, but it
632   means you may need to kill two processes to stop these programs.
633
634   rm now rejects attempts to remove the root directory, e.g., `rm -fr /'
635   now fails without removing anything.  Likewise for any file name with
636   a final `./' or `../' component.
637
638   tail now ignores the -f option if POSIXLY_CORRECT is set, no file
639   operand is given, and standard input is any FIFO; formerly it did
640   this only for pipes.
641
642 ** Infrastructure changes
643
644   Coreutils now uses gnulib via the gnulib-tool script.
645   If you check the source out from CVS, then follow the instructions
646   in README-cvs.  Although this represents a large change to the
647   infrastructure, it should cause no change in how the tools work.
648
649 ** Bug fixes
650
651   cp --backup no longer fails when the last component of a source file
652   name is "." or "..".
653
654   "ls --color" would highlight other-writable and sticky directories
655   no differently than regular directories on a file system with
656   dirent.d_type support.
657
658   "mv -T --verbose --backup=t A B" now prints the " (backup: B.~1~)"
659   suffix when A and B are directories as well as when they are not.
660
661   mv and "cp -r" no longer fail when invoked with two arguments
662   where the first one names a directory and the second name ends in
663   a slash and doesn't exist.  E.g., "mv dir B/", for nonexistent B,
664   now succeeds, once more.  This bug was introduced in coreutils-5.3.0.
665
666
667 * Major changes in release 6.1 (2006-08-19) [unstable]
668
669 ** Changes in behavior
670
671   df now considers BSD "kernfs" file systems to be dummies
672
673 ** New features
674
675   printf now supports the 'I' flag on hosts whose underlying printf
676   implementations support 'I', e.g., "printf %Id 2".
677
678 ** Bug fixes
679
680   cp --sparse preserves sparseness at the end of a file, even when
681   the file's apparent size is not a multiple of its block size.
682   [introduced with the original design, in fileutils-4.0r, 2000-04-29]
683
684   df (with a command line argument) once again prints its header
685   [introduced in coreutils-6.0]
686
687   ls -CF would misalign columns in some cases involving non-stat'able files
688   [introduced in coreutils-6.0]
689
690 * Major changes in release 6.0 (2006-08-15) [unstable]
691
692 ** Improved robustness
693
694   df: if the file system claims to have more available than total blocks,
695   report the number of used blocks as being "total - available"
696   (a negative number) rather than as garbage.
697
698   dircolors: a new autoconf run-test for AIX's buggy strndup function
699   prevents malfunction on that system;  may also affect cut, expand,
700   and unexpand.
701
702   fts no longer changes the current working directory, so its clients
703   (chmod, chown, chgrp, du) no longer malfunction under extreme conditions.
704
705   pwd and other programs using lib/getcwd.c work even on file systems
706   where dirent.d_ino values are inconsistent with those from stat.st_ino.
707
708   rm's core is now reentrant: rm --recursive (-r) now processes
709   hierarchies without changing the working directory at all.
710
711 ** Changes in behavior
712
713   basename and dirname now treat // as different from / on platforms
714   where the two are distinct.
715
716   chmod, install, and mkdir now preserve a directory's set-user-ID and
717   set-group-ID bits unless you explicitly request otherwise.  E.g.,
718   `chmod 755 DIR' and `chmod u=rwx,go=rx DIR' now preserve DIR's
719   set-user-ID and set-group-ID bits instead of clearing them, and
720   similarly for `mkdir -m 755 DIR' and `mkdir -m u=rwx,go=rx DIR'.  To
721   clear the bits, mention them explicitly in a symbolic mode, e.g.,
722   `mkdir -m u=rwx,go=rx,-s DIR'.  To set them, mention them explicitly
723   in either a symbolic or a numeric mode, e.g., `mkdir -m 2755 DIR',
724   `mkdir -m u=rwx,go=rx,g+s' DIR.  This change is for convenience on
725   systems where these bits inherit from parents.  Unfortunately other
726   operating systems are not consistent here, and portable scripts
727   cannot assume the bits are set, cleared, or preserved, even when the
728   bits are explicitly mentioned.  For example, OpenBSD 3.9 `mkdir -m
729   777 D' preserves D's setgid bit but `chmod 777 D' clears it.
730   Conversely, Solaris 10 `mkdir -m 777 D', `mkdir -m g-s D', and
731   `chmod 0777 D' all preserve D's setgid bit, and you must use
732   something like `chmod g-s D' to clear it.
733
734   `cp --link --no-dereference' now works also on systems where the
735   link system call cannot create a hard link to a symbolic link.
736   This change has no effect on systems with a Linux-based kernel.
737
738   csplit and nl now use POSIX syntax for regular expressions, not
739   Emacs syntax.  As a result, character classes like [[:print:]] and
740   interval expressions like A\{1,9\} now have their usual meaning,
741   . no longer matches the null character, and \ must precede the + and
742   ? operators.
743
744   date: a command like date -d '2006-04-23 21 days ago' would print
745   the wrong date in some time zones.  (see the test for an example)
746
747   df changes:
748
749     df now considers "none" and "proc" file systems to be dummies and
750     therefore does not normally display them.  Also, inaccessible file
751     systems (which can be caused by shadowed mount points or by
752     chrooted bind mounts) are now dummies, too.
753
754     df now fails if it generates no output, so you can inspect the
755     exit status of a command like "df -t ext3 -t reiserfs DIR" to test
756     whether DIR is on a file system of type "ext3" or "reiserfs".
757
758   expr no longer complains about leading ^ in a regular expression
759   (the anchor is ignored), or about regular expressions like A** (the
760   second "*" is ignored).  expr now exits with status 2 (not 3) for
761   errors it detects in the expression's values; exit status 3 is now
762   used only for internal errors (such as integer overflow, which expr
763   now checks for).
764
765   install and mkdir now implement the X permission symbol correctly,
766   e.g., `mkdir -m a+X dir'; previously the X was ignored.
767
768   install now creates parent directories with mode u=rwx,go=rx (755)
769   instead of using the mode specified by the -m option; and it does
770   not change the owner or group of parent directories.  This is for
771   compatibility with BSD and closes some race conditions.
772
773   ln now uses different (and we hope clearer) diagnostics when it fails.
774   ln -v now acts more like FreeBSD, so it generates output only when
775   successful and the output is easier to parse.
776
777   ls now defaults to --time-style='locale', not --time-style='posix-long-iso'.
778   However, the 'locale' time style now behaves like 'posix-long-iso'
779   if your locale settings appear to be messed up.  This change
780   attempts to have the default be the best of both worlds.
781
782   mkfifo and mknod no longer set special mode bits (setuid, setgid,
783   and sticky) with the -m option.
784
785   nohup's usual diagnostic now more precisely specifies the I/O
786   redirections, e.g., "ignoring input and appending output to
787   nohup.out".  Also, nohup now redirects stderr to nohup.out (or
788   $HOME/nohup.out) if stdout is closed and stderr is a tty; this is in
789   response to Open Group XCU ERN 71.
790
791   rm --interactive now takes an optional argument, although the
792   default of using no argument still acts like -i.
793
794   rm no longer fails to remove an empty, unreadable directory
795
796   seq changes:
797
798     seq defaults to a minimal fixed point format that does not lose
799     information if seq's operands are all fixed point decimal numbers.
800     You no longer need the `-f%.f' in `seq -f%.f 1048575 1024 1050623',
801     for example, since the default format now has the same effect.
802
803     seq now lets you use %a, %A, %E, %F, and %G formats.
804
805     seq now uses long double internally rather than double.
806
807   sort now reports incompatible options (e.g., -i and -n) rather than
808   silently ignoring one of them.
809
810   stat's --format=FMT option now works the way it did before 5.3.0:
811   FMT is automatically newline terminated.  The first stable release
812   containing this change was 5.92.
813
814   stat accepts the new option --printf=FMT, where FMT is *not*
815   automatically newline terminated.
816
817   stat: backslash escapes are interpreted in a format string specified
818   via --printf=FMT, but not one specified via --format=FMT.  That includes
819   octal (\ooo, at most three octal digits), hexadecimal (\xhh, one or
820   two hex digits), and the standard sequences (\a, \b, \f, \n, \r, \t,
821   \v, \", \\).
822
823   With no operand, 'tail -f' now silently ignores the '-f' only if
824   standard input is a FIFO or pipe and POSIXLY_CORRECT is set.
825   Formerly, it ignored the '-f' when standard input was a FIFO, pipe,
826   or socket.
827
828 ** Scheduled for removal
829
830   ptx's --copyright (-C) option is scheduled for removal in 2007, and
831   now evokes a warning.  Use --version instead.
832
833   rm's --directory (-d) option is scheduled for removal in 2006.  This
834   option has been silently ignored since coreutils 5.0.  On systems
835   that support unlinking of directories, you can use the "unlink"
836   command to unlink a directory.
837
838   Similarly, we are considering the removal of ln's --directory (-d,
839   -F) option in 2006.  Please write to <bug-coreutils@gnu.org> if this
840   would cause a problem for you.  On systems that support hard links
841   to directories, you can use the "link" command to create one.
842
843 ** New programs
844
845   base64: base64 encoding and decoding (RFC 3548) functionality.
846   sha224sum: print or check a SHA224 (224-bit) checksum
847   sha256sum: print or check a SHA256 (256-bit) checksum
848   sha384sum: print or check a SHA384 (384-bit) checksum
849   sha512sum: print or check a SHA512 (512-bit) checksum
850   shuf: Shuffle lines of text.
851
852 ** New features
853
854   chgrp now supports --preserve-root, --no-preserve-root (default),
855   as it was documented to do, and just as chmod, chown, and rm do.
856
857   New dd iflag= and oflag= flags:
858
859     'directory' causes dd to fail unless the file is a directory, on
860     hosts that support this (e.g., Linux kernels, version 2.1.126 and
861     later).  This has limited utility but is present for completeness.
862
863     'noatime' causes dd to read a file without updating its access
864     time, on hosts that support this (e.g., Linux kernels, version
865     2.6.8 and later).
866
867     'nolinks' causes dd to fail if the file has multiple hard links,
868     on hosts that support this (e.g., Solaris 10 and later).
869
870   ls accepts the new option --group-directories-first, to make it
871   list directories before files.
872
873   rm now accepts the -I (--interactive=once) option.  This new option
874   prompts once if rm is invoked recursively or if more than three
875   files are being deleted, which is less intrusive than -i prompting
876   for every file, but provides almost the same level of protection
877   against mistakes.
878
879   shred and sort now accept the --random-source option.
880
881   sort now accepts the --random-sort (-R) option and `R' ordering option.
882
883   sort now supports obsolete usages like "sort +1 -2" unless
884   POSIXLY_CORRECT is set.  However, when conforming to POSIX
885   1003.1-2001 "sort +1" still sorts the file named "+1".
886
887   wc accepts a new option --files0-from=FILE, where FILE contains a
888   list of NUL-terminated file names.
889
890 ** Bug fixes
891
892   cat with any of the options, -A -v -e -E -T, when applied to a
893   file in /proc or /sys (linux-specific), would truncate its output,
894   usually printing nothing.
895
896   cp -p would fail in a /proc-less chroot, on some systems
897
898   When `cp -RL' encounters the same directory more than once in the
899   hierarchy beneath a single command-line argument, it no longer confuses
900   them with hard-linked directories.
901
902   fts-using tools (chmod, chown, chgrp, du) no longer fail due to
903   a double-free bug -- it could be triggered by making a directory
904   inaccessible while e.g., du is traversing the hierarchy under it.
905
906   fts-using tools (chmod, chown, chgrp, du) no longer misinterpret
907   a very long symlink chain as a dangling symlink.  Before, such a
908   misinterpretation would cause these tools not to diagnose an ELOOP error.
909
910   ls --indicator-style=file-type would sometimes stat a symlink
911   unnecessarily.
912
913   ls --file-type worked like --indicator-style=slash (-p),
914   rather than like --indicator-style=file-type.
915
916   mv: moving a symlink into the place of an existing non-directory is
917   now done atomically;  before, mv would first unlink the destination.
918
919   mv -T DIR EMPTY_DIR no longer fails unconditionally.  Also, mv can
920   now remove an empty destination directory: mkdir -p a b/a; mv a b
921
922   rm (on systems with openat) can no longer exit before processing
923   all command-line arguments.
924
925   rm is no longer susceptible to a few low-probability memory leaks.
926
927   rm -r no longer fails to remove an inaccessible and empty directory
928
929   rm -r's cycle detection code can no longer be tricked into reporting
930   a false positive (introduced in fileutils-4.1.9).
931
932   shred --remove FILE no longer segfaults on Gentoo systems
933
934   sort would fail for large inputs (~50MB) on systems with a buggy
935   mkstemp function.  sort and tac now use the replacement mkstemp
936   function, and hence are no longer subject to limitations (of 26 or 32,
937   on the maximum number of files from a given template) on HP-UX 10.20,
938   SunOS 4.1.4, Solaris 2.5.1 and OSF1/Tru64 V4.0F&V5.1.
939
940   tail -f once again works on a file with the append-only
941   attribute (affects at least Linux ext2, ext3, xfs file systems)
942
943 * Major changes in release 5.97 (2006-06-24) [stable]
944 * Major changes in release 5.96 (2006-05-22) [stable]
945 * Major changes in release 5.95 (2006-05-12) [stable]
946 * Major changes in release 5.94 (2006-02-13) [stable]
947
948 [see the b5_9x branch for details]
949
950 * Major changes in release 5.93 (2005-11-06) [stable]
951
952 ** Bug fixes
953
954   dircolors no longer segfaults upon an attempt to use the new
955   STICKY_OTHER_WRITABLE (OWT) attribute.
956
957   du no longer overflows a counter when processing a file larger than
958   2^31-1 on some 32-bit systems (at least some AIX 5.1 configurations).
959
960   md5sum once again defaults to using the ` ' non-binary marker
961   (rather than the `*' binary marker) by default on Unix-like systems.
962
963   mkdir -p and install -d no longer exit nonzero when asked to create
964   a directory like `nonexistent/.'
965
966   rm emits a better diagnostic when (without -r) it fails to remove
967   a directory on e.g., Solaris 9/10 systems.
968
969   tac now works when stdin is a tty, even on non-Linux systems.
970
971   "tail -c 2 FILE" and "touch 0101000000" now operate as POSIX
972   1003.1-2001 requires, even when coreutils is conforming to older
973   POSIX standards, as the newly-required behavior is upward-compatible
974   with the old.
975
976   The documentation no longer mentions rm's --directory (-d) option.
977
978 ** Build-related bug fixes
979
980   installing .mo files would fail
981
982
983 * Major changes in release 5.92 (2005-10-22) [stable]
984
985 ** Bug fixes
986
987   chmod now diagnoses an invalid mode string starting with an octal digit
988
989   dircolors now properly quotes single-quote characters
990
991
992 * Major changes in release 5.91 (2005-10-17) [stable candidate]
993
994 ** Bug fixes
995
996   "mkdir -p /a/b/c" no longer fails merely because a leading prefix
997   directory (e.g., /a or /a/b) exists on a read-only file system.
998
999 ** Removed options
1000
1001   tail's --allow-missing option has been removed.  Use --retry instead.
1002
1003   stat's --link and -l options have been removed.
1004   Use --dereference (-L) instead.
1005
1006 ** Deprecated options
1007
1008   Using ls, du, or df with the --kilobytes option now evokes a warning
1009   that the long-named option is deprecated.  Use `-k' instead.
1010
1011   du's long-named --megabytes option now evokes a warning.
1012   Use -m instead.
1013
1014
1015 * Major changes in release 5.90 (2005-09-29) [unstable]
1016
1017 ** Bring back support for `head -NUM', `tail -NUM', etc. even when
1018   conforming to POSIX 1003.1-2001.  The following changes apply only
1019   when conforming to POSIX 1003.1-2001; there is no effect when
1020   conforming to older POSIX versions.
1021
1022   The following usages now behave just as when conforming to older POSIX:
1023
1024     date -I
1025     expand -TAB1[,TAB2,...]
1026     fold -WIDTH
1027     head -NUM
1028     join -j FIELD
1029     join -j1 FIELD
1030     join -j2 FIELD
1031     join -o FIELD_NAME1 FIELD_NAME2...
1032     nice -NUM
1033     od -w
1034     pr -S
1035     split -NUM
1036     tail -[NUM][bcl][f] [FILE]
1037
1038   The following usages no longer work, due to the above changes:
1039
1040     date -I TIMESPEC  (use `date -ITIMESPEC' instead)
1041     od -w WIDTH       (use `od -wWIDTH' instead)
1042     pr -S STRING      (use `pr -SSTRING' instead)
1043
1044   A few usages still have behavior that depends on which POSIX standard is
1045   being conformed to, and portable applications should beware these
1046   problematic usages.  These include:
1047
1048     Problematic       Standard-conforming replacement, depending on
1049        usage            whether you prefer the behavior of:
1050                       POSIX 1003.2-1992    POSIX 1003.1-2001
1051     sort +4           sort -k 5            sort ./+4
1052     tail +4           tail -n +4           tail ./+4
1053     tail - f          tail f               [see (*) below]
1054     tail -c 4         tail -c 10 ./4       tail -c4
1055     touch 12312359 f  touch -t 12312359 f  touch ./12312359 f
1056     uniq +4           uniq -s 4            uniq ./+4
1057
1058     (*) "tail - f" does not conform to POSIX 1003.1-2001; to read
1059     standard input and then "f", use the command "tail -- - f".
1060
1061   These changes are in response to decisions taken in the January 2005
1062   Austin Group standardization meeting.  For more details, please see
1063   "Utility Syntax Guidelines" in the Minutes of the January 2005
1064   Meeting <http://www.opengroup.org/austin/docs/austin_239.html>.
1065
1066 ** Binary input and output are now implemented more consistently.
1067   These changes affect only platforms like MS-DOS that distinguish
1068   between binary and text files.
1069
1070   The following programs now always use text input/output:
1071
1072     expand unexpand
1073
1074   The following programs now always use binary input/output to copy data:
1075
1076     cp install mv shred
1077
1078   The following programs now always use binary input/output to copy
1079   data, except for stdin and stdout when it is a terminal.
1080
1081     head tac tail tee tr
1082     (cat behaves similarly, unless one of the options -bensAE is used.)
1083
1084   cat's --binary or -B option has been removed.  It existed only on
1085   MS-DOS-like platforms, and didn't work as documented there.
1086
1087   md5sum and sha1sum now obey the -b or --binary option, even if
1088   standard input is a terminal, and they no longer report files to be
1089   binary if they actually read them in text mode.
1090
1091 ** Changes for better conformance to POSIX
1092
1093   cp, ln, mv, rm changes:
1094
1095     Leading white space is now significant in responses to yes-or-no questions.
1096     For example, if "rm" asks "remove regular file `foo'?" and you respond
1097     with " y" (i.e., space before "y"), it counts as "no".
1098
1099   dd changes:
1100
1101     On a QUIT or PIPE signal, dd now exits without printing statistics.
1102
1103     On hosts lacking the INFO signal, dd no longer treats the USR1
1104     signal as if it were INFO when POSIXLY_CORRECT is set.
1105
1106     If the file F is non-seekable and contains fewer than N blocks,
1107     then before copying "dd seek=N of=F" now extends F with zeroed
1108     blocks until F contains N blocks.
1109
1110   fold changes:
1111
1112     When POSIXLY_CORRECT is set, "fold file -3" is now equivalent to
1113     "fold file ./-3", not the obviously-erroneous "fold file ./-w3".
1114
1115   ls changes:
1116
1117     -p now marks only directories; it is equivalent to the new option
1118     --indicator-style=slash.  Use --file-type or
1119     --indicator-style=file-type to get -p's old behavior.
1120
1121   nice changes:
1122
1123     Documentation and diagnostics now refer to "nicenesses" (commonly
1124     in the range -20...19) rather than "nice values" (commonly 0...39).
1125
1126   nohup changes:
1127
1128     nohup now ignores the umask when creating nohup.out.
1129
1130     nohup now closes stderr if it is a terminal and stdout is closed.
1131
1132     nohup now exits with status 127 (not 1) when given an invalid option.
1133
1134   pathchk changes:
1135
1136     It now rejects the empty name in the normal case.  That is,
1137     "pathchk -p ''" now fails, and "pathchk ''" fails unless the
1138     current host (contra POSIX) allows empty file names.
1139
1140     The new -P option checks whether a file name component has leading "-",
1141     as suggested in interpretation "Austin-039:XCU:pathchk:pathchk -p"
1142     <http://www.opengroup.org/austin/interps/doc.tpl?gdid=6232>.
1143     It also rejects the empty name even if the current host accepts it; see
1144     <http://www.opengroup.org/austin/interps/doc.tpl?gdid=6233>.
1145
1146     The --portability option is now equivalent to -p -P.
1147
1148 ** Bug fixes
1149
1150   chmod, mkdir, mkfifo, and mknod formerly mishandled rarely-used symbolic
1151   permissions like =xX and =u, and did not properly diagnose some invalid
1152   strings like g+gr, ug,+x, and +1.  These bugs have been fixed.
1153
1154   csplit could produce corrupt output, given input lines longer than 8KB
1155
1156   dd now computes statistics using a realtime clock (if available)
1157   rather than the time-of-day clock, to avoid glitches if the
1158   time-of-day is changed while dd is running.  Also, it avoids
1159   using unsafe code in signal handlers; this fixes some core dumps.
1160
1161   expr and test now correctly compare integers of unlimited magnitude.
1162
1163   expr now detects integer overflow when converting strings to integers,
1164   rather than silently wrapping around.
1165
1166   ls now refuses to generate time stamps containing more than 1000 bytes, to
1167   foil potential denial-of-service attacks on hosts with very large stacks.
1168
1169   "mkdir -m =+x dir" no longer ignores the umask when evaluating "+x",
1170   and similarly for mkfifo and mknod.
1171
1172   "mkdir -p /tmp/a/b dir" no longer attempts to create the `.'-relative
1173   directory, dir (in /tmp/a), when, after creating /tmp/a/b, it is unable
1174   to return to its initial working directory.  Similarly for "install -D
1175   file /tmp/a/b/file".
1176
1177   "pr -D FORMAT" now accepts the same formats that "date +FORMAT" does.
1178
1179   stat now exits nonzero if a file operand does not exist
1180
1181 ** Improved robustness
1182
1183   Date no longer needs to allocate virtual memory to do its job,
1184   so it can no longer fail due to an out-of-memory condition,
1185   no matter how large the result.
1186
1187 ** Improved portability
1188
1189   hostid now prints exactly 8 hexadecimal digits, possibly with leading zeros,
1190   and without any spurious leading "fff..." on 64-bit hosts.
1191
1192   nice now works on Darwin 7.7.0 in spite of its invalid definition of NZERO.
1193
1194   `rm -r' can remove all entries in a directory even when it is on a
1195   file system for which readdir is buggy and that was not checked by
1196   coreutils' old configure-time run-test.
1197
1198   sleep no longer fails when resumed after being suspended on linux-2.6.8.1,
1199   in spite of that kernel's buggy nanosleep implementation.
1200
1201 ** New features
1202
1203   chmod -w now complains if its behavior differs from what chmod a-w
1204   would do, and similarly for chmod -r, chmod -x, etc.
1205
1206   cp and mv: the --reply=X option is deprecated
1207
1208   date accepts the new option --rfc-3339=TIMESPEC.  The old --iso-8601 (-I)
1209   option is deprecated; it still works, but new applications should avoid it.
1210   date, du, ls, and pr's time formats now support new %:z, %::z, %:::z
1211   specifiers for numeric time zone offsets like -07:00, -07:00:00, and -07.
1212
1213   dd has new iflag= and oflag= flags "binary" and "text", which have an
1214   effect only on nonstandard platforms that distinguish text from binary I/O.
1215
1216   dircolors now supports SETUID, SETGID, STICKY_OTHER_WRITABLE,
1217   OTHER_WRITABLE, and STICKY, with ls providing default colors for these
1218   categories if not specified by dircolors.
1219
1220   du accepts new options: --time[=TYPE] and --time-style=STYLE
1221
1222   join now supports a NUL field separator, e.g., "join -t '\0'".
1223   join now detects and reports incompatible options, e.g., "join -t x -t y",
1224
1225   ls no longer outputs an extra space between the mode and the link count
1226   when none of the listed files has an ACL.
1227
1228   md5sum --check now accepts multiple input files, and similarly for sha1sum.
1229
1230   If stdin is a terminal, nohup now redirects it from /dev/null to
1231   prevent the command from tying up an OpenSSH session after you logout.
1232
1233   "rm -FOO" now suggests "rm ./-FOO" if the file "-FOO" exists and
1234   "-FOO" is not a valid option.
1235
1236   stat -f -c %S outputs the fundamental block size (used for block counts).
1237   stat -f's default output format has been changed to output this size as well.
1238   stat -f recognizes file systems of type XFS and JFS
1239
1240   "touch -" now touches standard output, not a file named "-".
1241
1242   uname -a no longer generates the -p and -i outputs if they are unknown.
1243
1244 * Major changes in release 5.3.0 (2005-01-08) [unstable]
1245
1246 ** Bug fixes
1247
1248   Several fixes to chgrp and chown for compatibility with POSIX and BSD:
1249
1250     Do not affect symbolic links by default.
1251     Now, operate on whatever a symbolic link points to, instead.
1252     To get the old behavior, use --no-dereference (-h).
1253
1254     --dereference now works, even when the specified owner
1255     and/or group match those of an affected symlink.
1256
1257     Check for incompatible options.  When -R and --dereference are
1258     both used, then either -H or -L must also be used.  When -R and -h
1259     are both used, then -P must be in effect.
1260
1261     -H, -L, and -P have no effect unless -R is also specified.
1262     If -P and -R are both specified, -h is assumed.
1263
1264     Do not optimize away the chown() system call when the file's owner
1265     and group already have the desired value.  This optimization was
1266     incorrect, as it failed to update the last-changed time and reset
1267     special permission bits, as POSIX requires.
1268
1269     "chown : file", "chown '' file", and "chgrp '' file" now succeed
1270     without changing the uid or gid, instead of reporting an error.
1271
1272     Do not report an error if the owner or group of a
1273     recursively-encountered symbolic link cannot be updated because
1274     the file system does not support it.
1275
1276   chmod now accepts multiple mode-like options, e.g., "chmod -r -w f".
1277
1278   chown is no longer subject to a race condition vulnerability, when
1279   used with --from=O:G and without the (-h) --no-dereference option.
1280
1281   cut's --output-delimiter=D option works with abutting byte ranges.
1282
1283   dircolors's documentation now recommends that shell scripts eval
1284   "`dircolors`" rather than `dircolors`, to avoid shell expansion pitfalls.
1285
1286   du no longer segfaults when a subdirectory of an operand
1287   directory is removed while du is traversing that subdirectory.
1288   Since the bug was in the underlying fts.c module, it also affected
1289   chown, chmod, and chgrp.
1290
1291   du's --exclude-from=FILE and --exclude=P options now compare patterns
1292   against the entire name of each file, rather than against just the
1293   final component.
1294
1295   echo now conforms to POSIX better.  It supports the \0ooo syntax for
1296   octal escapes, and \c now terminates printing immediately.  If
1297   POSIXLY_CORRECT is set and the first argument is not "-n", echo now
1298   outputs all option-like arguments instead of treating them as options.
1299
1300   expand and unexpand now conform to POSIX better.  They check for
1301   blanks (which can include characters other than space and tab in
1302   non-POSIX locales) instead of spaces and tabs.  Unexpand now
1303   preserves some blanks instead of converting them to tabs or spaces.
1304
1305   "ln x d/" now reports an error if d/x is a directory and x a file,
1306   instead of incorrectly creating a link to d/x/x.
1307
1308   ls no longer segfaults on systems for which SIZE_MAX != (size_t) -1.
1309
1310   md5sum and sha1sum now report an error when given so many input
1311   lines that their line counter overflows, instead of silently
1312   reporting incorrect results.
1313
1314   Fixes for "nice":
1315
1316     If it fails to lower the niceness due to lack of permissions,
1317     it goes ahead and runs the command anyway, as POSIX requires.
1318
1319     It no longer incorrectly reports an error if the current niceness
1320     happens to be -1.
1321
1322     It no longer assumes that nicenesses range from -20 through 19.
1323
1324     It now consistently adjusts out-of-range nicenesses to the
1325     closest values in range; formerly it sometimes reported an error.
1326
1327   pathchk no longer accepts trailing options, e.g., "pathchk -p foo -b"
1328   now treats -b as a file name to check, not as an invalid option.
1329
1330   `pr --columns=N' was not equivalent to `pr -N' when also using
1331   either -s or -w.
1332
1333   pr now supports page numbers up to 2**64 on most hosts, and it
1334   detects page number overflow instead of silently wrapping around.
1335   pr now accepts file names that begin with "+" so long as the rest of
1336   the file name does not look like a page range.
1337
1338   printf has several changes:
1339
1340     It now uses 'intmax_t' (not 'long int') to format integers, so it
1341     can now format 64-bit integers on most modern hosts.
1342
1343     On modern hosts it now supports the C99-inspired %a, %A, %F conversion
1344     specs, the "'" and "0" flags, and the ll, j, t, and z length modifiers
1345     (this is compatible with recent Bash versions).
1346
1347     The printf command now rejects invalid conversion specifications
1348     like %#d, instead of relying on undefined behavior in the underlying
1349     printf function.
1350
1351   ptx now diagnoses invalid values for its --width=N (-w)
1352   and --gap-size=N (-g) options.
1353
1354   mv (when moving between partitions) no longer fails when
1355   operating on too many command-line-specified nonempty directories.
1356
1357   "readlink -f" is more compatible with prior implementations
1358
1359   rm (without -f) no longer hangs when attempting to remove a symlink
1360   to a file on an off-line NFS-mounted partition.
1361
1362   rm no longer gets a failed assertion under some unusual conditions.
1363
1364   rm no longer requires read access to the current directory.
1365
1366   "rm -r" would mistakenly fail to remove files under a directory
1367   for some types of errors (e.g., read-only file system, I/O error)
1368   when first encountering the directory.
1369
1370   "sort" fixes:
1371
1372     "sort -o -" now writes to a file named "-" instead of to standard
1373     output; POSIX requires this.
1374
1375     An unlikely race condition has been fixed where "sort" could have
1376     mistakenly removed a temporary file belonging to some other process.
1377
1378     "sort" no longer has O(N**2) behavior when it creates many temporary files.
1379
1380   tac can now handle regular, nonseekable files like Linux's
1381   /proc/modules.  Before, it would produce no output for such a file.
1382
1383   tac would exit immediately upon I/O or temp-file creation failure.
1384   Now it continues on, processing any remaining command line arguments.
1385
1386   "tail -f" no longer mishandles pipes and fifos.  With no operands,
1387   tail now ignores -f if standard input is a pipe, as POSIX requires.
1388   When conforming to POSIX 1003.2-1992, tail now supports the SUSv2 b
1389   modifier (e.g., "tail -10b file") and it handles some obscure cases
1390   more correctly, e.g., "tail +cl" now reads the file "+cl" rather
1391   than reporting an error, "tail -c file" no longer reports an error,
1392   and "tail - file" no longer reads standard input.
1393
1394   tee now exits when it gets a SIGPIPE signal, as POSIX requires.
1395   To get tee's old behavior, use the shell command "(trap '' PIPE; tee)".
1396   Also, "tee -" now writes to standard output instead of to a file named "-".
1397
1398   "touch -- MMDDhhmm[yy] file" is now equivalent to
1399   "touch MMDDhhmm[yy] file" even when conforming to pre-2001 POSIX.
1400
1401   tr no longer mishandles a second operand with leading "-".
1402
1403   who now prints user names in full instead of truncating them after 8 bytes.
1404
1405   The following commands now reject unknown options instead of
1406   accepting them as operands, so that users are properly warned that
1407   options may be added later.  Formerly they accepted unknown options
1408   as operands; e.g., "basename -a a" acted like "basename -- -a a".
1409
1410     basename dirname factor hostname link nohup sync unlink yes
1411
1412 ** New features
1413
1414   For efficiency, `sort -m' no longer copies input to a temporary file
1415   merely because the input happens to come from a pipe.  As a result,
1416   some relatively-contrived examples like `cat F | sort -m -o F - G'
1417   are no longer safe, as `sort' might start writing F before `cat' is
1418   done reading it.  This problem cannot occur unless `-m' is used.
1419
1420   When outside the default POSIX locale, the 'who' and 'pinky'
1421   commands now output time stamps like "2004-06-21 13:09" instead of
1422   the traditional "Jun 21 13:09".
1423
1424   pwd now works even when run from a working directory whose name
1425   is longer than PATH_MAX.
1426
1427   cp, install, ln, and mv have a new --no-target-directory (-T) option,
1428   and -t is now a short name for their --target-directory option.
1429
1430   cp -pu and mv -u (when copying) now don't bother to update the
1431   destination if the resulting time stamp would be no newer than the
1432   preexisting time stamp.  This saves work in the common case when
1433   copying or moving multiple times to the same destination in a file
1434   system with a coarse time stamp resolution.
1435
1436   cut accepts a new option, --complement, to complement the set of
1437   selected bytes, characters, or fields.
1438
1439   dd now also prints the number of bytes transferred, the time, and the
1440   transfer rate.  The new "status=noxfer" operand suppresses this change.
1441
1442   dd has new conversions for the conv= option:
1443
1444     nocreat   do not create the output file
1445     excl      fail if the output file already exists
1446     fdatasync physically write output file data before finishing
1447     fsync     likewise, but also write metadata
1448
1449   dd has new iflag= and oflag= options with the following flags:
1450
1451     append    append mode (makes sense for output file only)
1452     direct    use direct I/O for data
1453     dsync     use synchronized I/O for data
1454     sync      likewise, but also for metadata
1455     nonblock  use non-blocking I/O
1456     nofollow  do not follow symlinks
1457     noctty    do not assign controlling terminal from file
1458
1459   stty now provides support (iutf8) for setting UTF-8 input mode.
1460
1461   With stat, a specified format is no longer automatically newline terminated.
1462   If you want a newline at the end of your output, append `\n' to the format
1463   string.
1464
1465   'df', 'du', and 'ls' now take the default block size from the
1466   BLOCKSIZE environment variable if the BLOCK_SIZE, DF_BLOCK_SIZE,
1467   DU_BLOCK_SIZE, and LS_BLOCK_SIZE environment variables are not set.
1468   Unlike the other variables, though, BLOCKSIZE does not affect
1469   values like 'ls -l' sizes that are normally displayed as bytes.
1470   This new behavior is for compatibility with BSD.
1471
1472   du accepts a new option --files0-from=FILE, where FILE contains a
1473   list of NUL-terminated file names.
1474
1475   Date syntax as used by date -d, date -f, and touch -d has been
1476   changed as follows:
1477
1478     Dates like `January 32' with out-of-range components are now rejected.
1479
1480     Dates can have fractional time stamps like 2004-02-27 14:19:13.489392193.
1481
1482     Dates can be entered via integer counts of seconds since 1970 when
1483     prefixed by `@'.  For example, `@321' represents 1970-01-01 00:05:21 UTC.
1484
1485     Time zone corrections can now separate hours and minutes with a colon,
1486     and can follow standard abbreviations like "UTC".  For example,
1487     "UTC +0530" and "+05:30" are supported, and are both equivalent to "+0530".
1488
1489     Date values can now have leading TZ="..." assignments that override
1490     the environment only while that date is being processed.  For example,
1491     the following shell command converts from Paris to New York time:
1492
1493       TZ="America/New_York" date --date='TZ="Europe/Paris" 2004-10-31 06:30'
1494
1495   `date' has a new option --iso-8601=ns that outputs
1496   nanosecond-resolution time stamps.
1497
1498   echo -e '\xHH' now outputs a byte whose hexadecimal value is HH,
1499   for compatibility with bash.
1500
1501   ls now exits with status 1 on minor problems, 2 if serious trouble.
1502
1503   ls has a new --hide=PATTERN option that behaves like
1504   --ignore=PATTERN, except that it is overridden by -a or -A.
1505   This can be useful for aliases, e.g., if lh is an alias for
1506   "ls --hide='*~'", then "lh -A" lists the file "README~".
1507
1508   In the following cases POSIX allows the default GNU behavior,
1509   so when POSIXLY_CORRECT is set:
1510
1511     false, printf, true, unlink, and yes all support --help and --option.
1512     ls supports TABSIZE.
1513     pr no longer depends on LC_TIME for the date format in non-POSIX locales.
1514     printf supports \u, \U, \x.
1515     tail supports two or more files when using the obsolete option syntax.
1516
1517   The usual `--' operand is now supported by chroot, hostid, hostname,
1518   pwd, sync, and yes.
1519
1520   `od' now conforms to POSIX better, and is more compatible with BSD:
1521
1522     The older syntax "od [-abcdfilosx]... [FILE] [[+]OFFSET[.][b]]" now works
1523     even without --traditional.  This is a change in behavior if there
1524     are one or two operands and the last one begins with +, or if
1525     there are two operands and the latter one begins with a digit.
1526     For example, "od foo 10" and "od +10" now treat the last operand as
1527     an offset, not as a file name.
1528
1529     -h is no longer documented, and may be withdrawn in future versions.
1530     Use -x or -t x2 instead.
1531
1532     -i is now equivalent to -t dI (not -t d2), and
1533     -l is now equivalent to -t dL (not -t d4).
1534
1535     -s is now equivalent to -t d2.  The old "-s[NUM]" or "-s NUM"
1536     option has been renamed to "-S NUM".
1537
1538     The default output format is now -t oS, not -t o2, i.e., short int
1539     rather than two-byte int.  This makes a difference only on hosts like
1540     Cray systems where the C short int type requires more than two bytes.
1541
1542   readlink accepts new options: --canonicalize-existing (-e)
1543   and --canonicalize-missing (-m).
1544
1545   The stat option --filesystem has been renamed to --file-system, for
1546   consistency with POSIX "file system" and with cp and du --one-file-system.
1547
1548 ** Removed features
1549
1550   md5sum and sha1sum's undocumented --string option has been removed.
1551
1552   tail's undocumented --max-consecutive-size-changes option has been removed.
1553
1554 * Major changes in release 5.2.1 (2004-03-12) [stable]
1555
1556 ** Bug fixes
1557
1558   mv could mistakenly fail to preserve hard links when moving two
1559   or more arguments between partitions.
1560
1561   `cp --sparse=always F /dev/hdx' no longer tries to use lseek to create
1562   holes in the destination.
1563
1564   nohup now sets the close-on-exec flag for its copy of the stderr file
1565   descriptor.  This avoids some nohup-induced hangs.  For example, before
1566   this change, if you ran `ssh localhost', then `nohup sleep 600 </dev/null &',
1567   and then exited that remote shell, the ssh session would hang until the
1568   10-minute sleep terminated.  With the fixed nohup, the ssh session
1569   terminates immediately.
1570
1571   `expr' now conforms to POSIX better:
1572
1573     Integers like -0 and 00 are now treated as zero.
1574
1575     The `|' operator now returns 0, not its first argument, if both
1576     arguments are null or zero.  E.g., `expr "" \| ""' now returns 0,
1577     not the empty string.
1578
1579     The `|' and `&' operators now use short-circuit evaluation, e.g.,
1580     `expr 1 \| 1 / 0' no longer reports a division by zero.
1581
1582 ** New features
1583
1584   `chown user.group file' now has its traditional meaning even when
1585   conforming to POSIX 1003.1-2001, so long as no user has a name
1586   containing `.' that happens to equal `user.group'.
1587
1588
1589 * Major changes in release 5.2.0 (2004-02-19) [stable]
1590
1591 ** Bug fixes
1592
1593   none
1594
1595
1596 * Major changes in release 5.1.3 (2004-02-08): candidate to become stable 5.2.0
1597
1598 ** Bug fixes
1599
1600   `cp -d' now works as required even on systems like OSF V5.1 that
1601   declare stat and lstat as `static inline' functions.
1602
1603   time stamps output by stat now include actual fractional seconds,
1604   when available -- or .0000000 for files without that information.
1605
1606   seq no longer infloops when printing 2^31 or more numbers.
1607   For reference, seq `echo 2^31|bc` > /dev/null takes about one hour
1608   on a 1.6 GHz Athlon 2000 XP.  Now it can output 2^53-1 numbers before
1609   misbehaving.
1610
1611 * Major changes in release 5.1.2 (2004-01-25):
1612
1613 ** Bug fixes
1614
1615   rmdir -p exits with status 1 on error; formerly it sometimes exited
1616   with status 0 when given more than one argument.
1617
1618   nohup now always exits with status 127 when it finds an error,
1619   as POSIX requires; formerly it sometimes exited with status 1.
1620
1621   Several programs (including cut, date, dd, env, hostname, nl, pr,
1622   stty, and tr) now always exit with status 1 when they find an error;
1623   formerly they sometimes exited with status 2.
1624
1625   factor no longer reports a usage error if stdin has the wrong format.
1626
1627   paste no longer infloops on ppc systems (bug introduced in 5.1.1)
1628
1629
1630 * Major changes in release 5.1.1 (2004-01-17):
1631
1632 ** Configuration option
1633
1634   You can select the default level of POSIX conformance at configure-time,
1635   e.g., by ./configure DEFAULT_POSIX2_VERSION=199209
1636
1637 ** Bug fixes
1638
1639   fold -s works once again on systems with differing sizes for int
1640   and size_t (bug introduced in 5.1.0)
1641
1642 ** New features
1643
1644   touch -r now specifies the origin for any relative times in the -d
1645   operand, if both options are given.  For example, "touch -r FOO -d
1646   '-5 seconds' BAR" sets BAR's modification time to be five seconds
1647   before FOO's.
1648
1649   join: The obsolete options "-j1 FIELD", "-j2 FIELD", and
1650   "-o LIST1 LIST2..." are no longer supported on POSIX 1003.1-2001 systems.
1651   Portable scripts should use "-1 FIELD", "-2 FIELD", and
1652   "-o LIST1,LIST2..." respectively.  If join was compiled on a
1653   POSIX 1003.1-2001 system, you may enable the old behavior
1654   by setting _POSIX2_VERSION=199209 in your environment.
1655   [This change was reverted in coreutils 5.3.1.]
1656
1657
1658 * Major changes in release 5.1.0 (2003-12-21):
1659
1660 ** New features
1661
1662   chgrp, chmod, and chown can now process (with -R) hierarchies of virtually
1663   unlimited depth.  Before, they would fail to operate on any file they
1664   encountered with a relative name of length PATH_MAX (often 4096) or longer.
1665
1666   chgrp, chmod, chown, and rm accept the new options:
1667   --preserve-root, --no-preserve-root (default)
1668
1669   chgrp and chown now accept POSIX-mandated -L, -H, and -P options
1670
1671   du can now process hierarchies of virtually unlimited depth.
1672   Before, du was limited by the user's stack size and it would get a
1673   stack overflow error (often a segmentation fault) when applied to
1674   a hierarchy of depth around 30,000 or larger.
1675
1676   du works even when run from an inaccessible directory
1677
1678   du -D now dereferences all symlinks specified on the command line,
1679   not just the ones that reference directories
1680
1681   du now accepts -P (--no-dereference), for compatibility with du
1682   of NetBSD and for consistency with e.g., chown and chgrp
1683
1684   du's -H option will soon have the meaning required by POSIX
1685   (--dereference-args, aka -D) rather then the current meaning of --si.
1686   Now, using -H elicits a warning to that effect.
1687
1688   When given -l and similar options, ls now adjusts the output column
1689   widths to fit the data, so that output lines are shorter and have
1690   columns that line up better.  This may adversely affect shell
1691   scripts that expect fixed-width columns, but such shell scripts were
1692   not portable anyway, even with old GNU ls where the columns became
1693   ragged when a datum was too wide.
1694
1695   du accepts a new option, -0/--null, to make it produce NUL-terminated
1696   output lines
1697
1698 ** Bug fixes
1699
1700   printf, seq, tail, and sleep now parse floating-point operands
1701   and options in the C locale.  POSIX requires this for printf.
1702
1703   od -c -w9999999 no longer segfaults
1704
1705   csplit no longer reads from freed memory (dumping core on some systems)
1706
1707   csplit would mistakenly exhaust virtual memory in some cases
1708
1709   ls --width=N (for very large N) is no longer subject to an address
1710   arithmetic bug that could result in bounds violations.
1711
1712   ls --width=N (with -x or -C) no longer allocates more space
1713   (potentially much more) than necessary for a given directory.
1714
1715   dd `unblock' and `sync' may now be combined (e.g., dd conv=unblock,sync)
1716
1717 * Major changes in release 5.0.91 (2003-09-08):
1718
1719 ** New features
1720
1721   date accepts a new option --rfc-2822, an alias for --rfc-822.
1722
1723   split accepts a new option -d or --numeric-suffixes.
1724
1725   cp, install, mv, and touch now preserve microsecond resolution on
1726   file timestamps, on platforms that have the 'utimes' system call.
1727   Unfortunately there is no system call yet to preserve file
1728   timestamps to their full nanosecond resolution; microsecond
1729   resolution is the best we can do right now.
1730
1731   sort now supports the zero byte (NUL) as a field separator; use -t '\0'.
1732   The -t '' option, which formerly had no effect, is now an error.
1733
1734   sort option order no longer matters for the options -S, -d, -i, -o, and -t.
1735   Stronger options override weaker, and incompatible options are diagnosed.
1736
1737   `sha1sum --check' now accepts the BSD format for SHA1 message digests
1738   in addition to the BSD format for MD5 ones.
1739
1740   who -l now means `who --login', not `who --lookup', per POSIX.
1741   who's -l option has been eliciting an unconditional warning about
1742   this impending change since sh-utils-2.0.12 (April 2002).
1743
1744 ** Bug fixes
1745
1746   Mistakenly renaming a file onto itself, e.g., via `mv B b' when `B' is
1747   the same directory entry as `b' no longer destroys the directory entry
1748   referenced by both `b' and `B'.  Note that this would happen only on
1749   file systems like VFAT where two different names may refer to the same
1750   directory entry, usually due to lower->upper case mapping of file names.
1751   Now, the above can happen only on file systems that perform name mapping and
1752   that support hard links (stat.st_nlink > 1).  This mitigates the problem
1753   in two ways: few file systems appear to be affected (hpfs and ntfs are),
1754   when the bug is triggered, mv no longer removes the last hard link to a file.
1755   *** ATTENTION ***: if you know how to distinguish the following two cases
1756   without writing to the file system in question, please let me know:
1757   1) B and b refer to the same directory entry on a file system like NTFS
1758        (B may well have a link count larger than 1)
1759   2) B and b are hard links to the same file
1760
1761   stat no longer overruns a buffer for format strings ending in `%'
1762
1763   fold -s -wN would infloop for N < 8 with TABs in the input.
1764   E.g., this would not terminate: printf 'a\t' | fold -w2 -s
1765
1766   `split -a0', although of questionable utility, is accepted once again.
1767
1768   `df DIR' used to hang under some conditions on OSF/1 5.1.  Now it doesn't.
1769
1770   seq's --width (-w) option now works properly even when the endpoint
1771   requiring the larger width is negative and smaller than the other endpoint.
1772
1773   seq's default step is 1, even if LAST < FIRST.
1774
1775   paste no longer mistakenly outputs 0xFF bytes for a nonempty input file
1776   without a trailing newline.
1777
1778   `tail -n0 -f FILE' and `tail -c0 -f FILE' no longer perform what amounted
1779   to a busy wait, rather than sleeping between iterations.
1780
1781   tail's long-undocumented --allow-missing option now elicits a warning
1782
1783
1784 * Major changes in release 5.0.90 (2003-07-29):
1785
1786 ** New features
1787
1788   sort is now up to 30% more CPU-efficient in some cases
1789
1790   `test' is now more compatible with Bash and POSIX:
1791
1792     `test -t', `test --help', and `test --version' now silently exit
1793     with status 0.  To test whether standard output is a terminal, use
1794     `test -t 1'.  To get help and version info for `test', use
1795     `[ --help' and `[ --version'.
1796
1797     `test' now exits with status 2 (not 1) if there is an error.
1798
1799   wc count field widths now are heuristically adjusted depending on the input
1800   size, if known.  If only one count is printed, it is guaranteed to
1801   be printed without leading spaces.
1802
1803   Previously, wc did not align the count fields if POSIXLY_CORRECT was set,
1804   but POSIX did not actually require this undesirable behavior, so it
1805   has been removed.
1806
1807 ** Bug fixes
1808
1809   kill no longer tries to operate on argv[0] (introduced in 5.0.1)
1810   Why wasn't this noticed?  Although many tests use kill, none of
1811   them made an effort to avoid using the shell's built-in kill.
1812
1813   `[' invoked with no arguments no longer evokes a segfault
1814
1815   rm without --recursive (aka -r or -R) no longer prompts regarding
1816   unwritable directories, as required by POSIX.
1817
1818   uniq -c now uses a SPACE, not a TAB between the count and the
1819   corresponding line, as required by POSIX.
1820
1821   expr now exits with status 2 if the expression is syntactically valid,
1822   and with status 3 if an error occurred.  POSIX requires this.
1823
1824   expr now reports trouble if string comparison fails due to a collation error.
1825
1826   split now generates suffixes properly on EBCDIC hosts.
1827
1828   split -a0 now works, as POSIX requires.
1829
1830   `sort --version' and `sort --help' fail, as they should
1831   when their output is redirected to /dev/full.
1832
1833   `su --version > /dev/full' now fails, as it should.
1834
1835 ** Fewer arbitrary limitations
1836
1837   cut requires 97% less memory when very large field numbers or
1838   byte offsets are specified.
1839
1840
1841 * Major changes in release 5.0.1 (2003-07-15):
1842
1843 ** New programs
1844 - new program: `[' (much like `test')
1845
1846 ** New features
1847 - head now accepts --lines=-N (--bytes=-N) to print all but the
1848   N lines (bytes) at the end of the file
1849 - md5sum --check now accepts the output of the BSD md5sum program, e.g.,
1850   MD5 (f) = d41d8cd98f00b204e9800998ecf8427e
1851 - date -d DATE can now parse a DATE string like May-23-2003
1852 - chown: `.' is no longer recognized as a separator in the OWNER:GROUP
1853   specifier on POSIX 1003.1-2001 systems.  If chown *was not* compiled
1854   on such a system, then it still accepts `.', by default.  If chown
1855   was compiled on a POSIX 1003.1-2001 system, then you may enable the
1856   old behavior by setting _POSIX2_VERSION=199209 in your environment.
1857 - chown no longer tries to preserve set-user-ID and set-group-ID bits;
1858   on some systems, the chown syscall resets those bits, and previous
1859   versions of the chown command would call chmod to restore the original,
1860   pre-chown(2) settings, but that behavior is problematic.
1861   1) There was a window whereby a malicious user, M, could subvert a
1862   chown command run by some other user and operating on files in a
1863   directory where M has write access.
1864   2) Before (and even now, on systems with chown(2) that doesn't reset
1865   those bits), an unwary admin. could use chown unwittingly to create e.g.,
1866   a set-user-ID root copy of /bin/sh.
1867
1868 ** Bug fixes
1869 - chown --dereference no longer leaks a file descriptor per symlink processed
1870 - `du /' once again prints the `/' on the last line
1871 - split's --verbose option works once again [broken in 4.5.10 and 5.0]
1872 - tail -f is no longer subject to a race condition that could make it
1873   delay displaying the last part of a file that had stopped growing.  That
1874   bug could also make tail -f give an unwarranted `file truncated' warning.
1875 - du no longer runs out of file descriptors unnecessarily
1876 - df and `readlink --canonicalize' no longer corrupt the heap on
1877   non-glibc, non-solaris systems
1878 - `env -u UNSET_VARIABLE' no longer dumps core on non-glibc systems
1879 - readlink's --canonicalize option now works on systems like Solaris that
1880   lack the canonicalize_file_name function but do have resolvepath.
1881 - mv now removes `a' in this example on all systems: touch a; ln a b; mv a b
1882   This behavior is contrary to POSIX (which requires that the mv command do
1883   nothing and exit successfully), but I suspect POSIX will change.
1884 - date's %r format directive now honors locale settings
1885 - date's `-' (no-pad) format flag now affects the space-padded-by-default
1886   conversion specifiers, %e, %k, %l
1887 - fmt now diagnoses invalid obsolescent width specifications like `-72x'
1888 - fmt now exits nonzero when unable to open an input file
1889 - tsort now fails when given an odd number of input tokens,
1890   as required by POSIX.  Before, it would act as if the final token
1891   appeared one additional time.
1892
1893 ** Fewer arbitrary limitations
1894 - tail's byte and line counts are no longer limited to OFF_T_MAX.
1895   Now the limit is UINTMAX_MAX (usually 2^64).
1896 - split can now handle --bytes=N and --lines=N with N=2^31 or more.
1897
1898 ** Portability
1899 - `kill -t' now prints signal descriptions (rather than `?') on systems
1900   like Tru64 with __sys_siglist but no strsignal function.
1901 - stat.c now compiles on Ultrix systems
1902 - sleep now works on AIX systems that lack support for clock_gettime
1903 - rm now works around Darwin6.5's broken readdir function
1904   Before `rm -rf DIR' would fail to remove all files in DIR
1905   if there were more than 338.
1906
1907 * Major changes in release 5.0 (2003-04-02):
1908 - false --help now exits nonzero
1909
1910 [4.5.12]
1911 * printf no longer treats \x specially when POSIXLY_CORRECT is set
1912 * printf avoids buffer overrun with format ending in a backslash and
1913 * printf avoids buffer overrun with incomplete conversion specifier
1914 * printf accepts multiple flags in a single conversion specifier
1915
1916 [4.5.11]
1917 * seq no longer requires that a field width be specified
1918 * seq no longer fails when given a field width of `0'
1919 * seq now accepts ` ' and `'' as valid format flag characters
1920 * df now shows a HOSTNAME: prefix for each remote-mounted file system on AIX 5.1
1921 * portability tweaks for HP-UX, AIX 5.1, DJGPP
1922
1923 [4.5.10]
1924 * printf no longer segfaults for a negative field width or precision
1925 * shred now always enables --exact for non-regular files
1926 * du no longer lists hard-linked files more than once
1927 * du no longer dumps core on some systems due to `infinite' recursion
1928   via nftw's use of the buggy replacement function in getcwd.c
1929 * portability patches for a few vendor compilers and 64-bit systems
1930 * du -S *really* now works like it did before the change in 4.5.5
1931
1932 [4.5.9]
1933 * du no longer truncates file sizes or sums to fit in 32-bit size_t
1934 * work around Linux kernel bug in getcwd (fixed in 2.4.21-pre4), so that pwd
1935   now fails if the name of the working directory is so long that getcwd
1936   truncates it.  Before it would print the truncated name and exit successfully.
1937 * `df /some/mount-point' no longer hangs on a GNU libc system when another
1938   hard-mounted NFS file system (preceding /some/mount-point in /proc/mounts)
1939   is inaccessible.
1940 * rm -rf now gives an accurate diagnostic when failing to remove a file
1941   under certain unusual conditions
1942 * mv and `cp --preserve=links' now preserve multiple hard links even under
1943   certain unusual conditions where they used to fail
1944
1945 [4.5.8]
1946 * du -S once again works like it did before the change in 4.5.5
1947 * stat accepts a new file format, %B, for the size of each block reported by %b
1948 * du accepts new option: --apparent-size
1949 * du --bytes (-b) works the same way it did in fileutils-3.16 and before
1950 * du reports proper sizes for directories (not zero) (broken in 4.5.6 or 4.5.7)
1951 * df now always displays under `Filesystem', the device file name
1952   corresponding to the listed mount point.  Before, for a block- or character-
1953   special file command line argument, df would display that argument.  E.g.,
1954   `df /dev/hda' would list `/dev/hda' as the `Filesystem', rather than say
1955   /dev/hda3 (the device on which `/' is mounted), as it does now.
1956 * test now works properly when invoked from a set user ID or set group ID
1957   context and when testing access to files subject to alternate protection
1958   mechanisms.  For example, without this change, a set-UID program that invoked
1959   `test -w F' (to see if F is writable) could mistakenly report that it *was*
1960   writable, even though F was on a read-only file system, or F had an ACL
1961   prohibiting write access, or F was marked as immutable.
1962
1963 [4.5.7]
1964 * du would fail with more than one DIR argument when any but the last did not
1965   contain a slash (due to a bug in ftw.c)
1966
1967 [4.5.6]
1968 * du no longer segfaults on Solaris systems (fixed heap-corrupting bug in ftw.c)
1969 * du --exclude=FILE works once again (this was broken by the rewrite for 4.5.5)
1970 * du no longer gets a failed assertion for certain hierarchy lay-outs
1971   involving hard-linked directories
1972 * `who -r' no longer segfaults when using non-C-locale messages
1973 * df now displays a mount point (usually `/') for non-mounted
1974   character-special and block files
1975
1976 [4.5.5]
1977 * ls --dired produces correct byte offset for file names containing
1978   nonprintable characters in a multibyte locale
1979 * du has been rewritten to use a variant of GNU libc's ftw.c
1980 * du now counts the space associated with a directory's directory entry,
1981   even if it cannot list or chdir into that subdirectory.
1982 * du -S now includes the st_size of each entry corresponding to a subdirectory
1983 * rm on FreeBSD can once again remove directories from NFS-mounted file systems
1984 * ls has a new option --dereference-command-line-symlink-to-dir, which
1985   corresponds to the new default behavior when none of -d, -l -F, -H, -L
1986   has been specified.
1987 * ls dangling-symlink now prints `dangling-symlink'.
1988   Before, it would fail with `no such file or directory'.
1989 * ls -s symlink-to-non-dir and ls -i symlink-to-non-dir now print
1990   attributes of `symlink', rather than attributes of their referents.
1991 * Fix a bug introduced in 4.5.4 that made it so that ls --color would no
1992   longer highlight the names of files with the execute bit set when not
1993   specified on the command line.
1994 * shred's --zero (-z) option no longer gobbles up any following argument.
1995   Before, `shred --zero file' would produce `shred: missing file argument',
1996   and worse, `shred --zero f1 f2 ...' would appear to work, but would leave
1997   the first file untouched.
1998 * readlink: new program
1999 * cut: new feature: when used to select ranges of byte offsets (as opposed
2000   to ranges of fields) and when --output-delimiter=STRING is specified,
2001   output STRING between ranges of selected bytes.
2002 * rm -r can no longer be tricked into mistakenly reporting a cycle.
2003 * when rm detects a directory cycle, it no longer aborts the entire command,
2004   but rather merely stops processing the affected command line argument.
2005
2006 [4.5.4]
2007 * cp no longer fails to parse options like this: --preserve=mode,ownership
2008 * `ls --color -F symlink-to-dir' works properly
2009 * ls is much more efficient on directories with valid dirent.d_type.
2010 * stty supports all baud rates defined in linux-2.4.19.
2011 * `du symlink-to-dir/' would improperly remove the trailing slash
2012 * `du ""' would evoke a bounds violation.
2013 * In the unlikely event that running `du /' resulted in `stat ("/", ...)'
2014   failing, du would give a diagnostic about `' (empty string) rather than `/'.
2015 * printf: a hexadecimal escape sequence has at most two hex. digits, not three.
2016 * The following features have been added to the --block-size option
2017   and similar environment variables of df, du, and ls.
2018   - A leading "'" generates numbers with thousands separators.
2019     For example:
2020       $ ls -l --block-size="'1" file
2021       -rw-rw-r--    1 eggert   src      47,483,707 Sep 24 23:40 file
2022   - A size suffix without a leading integer generates a suffix in the output.
2023     For example:
2024       $ ls -l --block-size="K"
2025       -rw-rw-r--    1 eggert   src          46371K Sep 24 23:40 file
2026 * ls's --block-size option now affects file sizes in all cases, not
2027   just for --block-size=human-readable and --block-size=si.  Fractional
2028   sizes are now always rounded up, for consistency with df and du.
2029 * df now displays the block size using powers of 1000 if the requested
2030   block size seems to be a multiple of a power of 1000.
2031 * nl no longer gets a segfault when run like this `yes|nl -s%n'
2032
2033 [4.5.3]
2034 * du --dereference-args (-D) no longer fails in certain cases
2035 * `ln --target-dir=DIR' no longer fails when given a single argument
2036
2037 [4.5.2]
2038 * `rm -i dir' (without --recursive (-r)) no longer recurses into dir
2039 * `tail -c N FILE' now works with files of size >= 4GB
2040 * `mkdir -p' can now create very deep (e.g. 40,000-component) directories
2041 * rmdir -p dir-with-trailing-slash/ no longer fails
2042 * printf now honors the `--' command line delimiter
2043 * od's 8-byte formats x8, o8, and u8 now work
2044 * tail now accepts fractional seconds for its --sleep-interval=S (-s) option
2045
2046 [4.5.1]
2047 * du and ls now report sizes of symbolic links (before they'd always report 0)
2048 * uniq now obeys the LC_COLLATE locale, as per POSIX 1003.1-2001 TC1.
2049
2050 ========================================================================
2051 Here are the NEWS entries made from fileutils-4.1 until the
2052 point at which the packages merged to form the coreutils:
2053
2054 [4.1.11]
2055 * `rm symlink-to-unwritable' doesn't prompt [introduced in 4.1.10]
2056 [4.1.10]
2057 * rm once again gives a reasonable diagnostic when failing to remove a file
2058     owned by someone else in a sticky directory [introduced in 4.1.9]
2059 * df now rounds all quantities up, as per POSIX.
2060 * New ls time style: long-iso, which generates YYYY-MM-DD HH:MM.
2061 * Any time style can be preceded by "posix-"; this causes "ls" to
2062   use traditional timestamp format when in the POSIX locale.
2063 * The default time style is now posix-long-iso instead of posix-iso.
2064   Set TIME_STYLE="posix-iso" to revert to the behavior of 4.1.1 thru 4.1.9.
2065 * `rm dangling-symlink' doesn't prompt [introduced in 4.1.9]
2066 * stat: remove support for --secure/-s option and related %S and %C format specs
2067 * stat: rename --link/-l to --dereference/-L.
2068     The old options will continue to work for a while.
2069 [4.1.9]
2070 * rm can now remove very deep hierarchies, in spite of any limit on stack size
2071 * new programs: link, unlink, and stat
2072 * New ls option: --author (for the Hurd).
2073 * `touch -c no-such-file' no longer fails, per POSIX
2074 [4.1.8]
2075 * mv no longer mistakenly creates links to preexisting destination files
2076     that aren't moved
2077 [4.1.7]
2078 * rm: close a hole that would allow a running rm process to be subverted
2079 [4.1.6]
2080 * New cp option: --copy-contents.
2081 * cp -r is now equivalent to cp -R.  Use cp -R -L --copy-contents to get the
2082   traditional (and rarely desirable) cp -r behavior.
2083 * ls now accepts --time-style=+FORMAT, where +FORMAT works like date's format
2084 * The obsolete usage `touch [-acm] MMDDhhmm[YY] FILE...' is no longer
2085   supported on systems conforming to POSIX 1003.1-2001.  Use touch -t instead.
2086 * cp and inter-partition mv no longer give a misleading diagnostic in some
2087     unusual cases
2088 [4.1.5]
2089 * cp -r no longer preserves symlinks
2090 * The block size notation is now compatible with SI and with IEC 60027-2.
2091   For example, --block-size=1MB now means --block-size=1000000,
2092   whereas --block-size=1MiB now means --block-size=1048576.
2093   A missing `B' (e.g. `1M') has the same meaning as before.
2094   A trailing `B' now means decimal, not binary; this is a silent change.
2095   The nonstandard `D' suffix (e.g. `1MD') is now obsolescent.
2096 * -H or --si now outputs the trailing 'B', for consistency with the above.
2097 * Programs now output trailing 'K' (not 'k') to mean 1024, as per IEC 60027-2.
2098 * New df, du short option -B is short for --block-size.
2099 * You can omit an integer `1' before a block size suffix,
2100   e.g. `df -BG' is equivalent to `df -B 1G' and to `df --block-size=1G'.
2101 * The following options are now obsolescent, as their names are
2102   incompatible with IEC 60027-2:
2103    df, du: -m or --megabytes (use -BM or --block-size=1M)
2104    df, du, ls: --kilobytes (use --block-size=1K)
2105 [4.1.4]
2106 * df --local no longer lists smbfs file systems whose name starts with //
2107 * dd now detects the Linux/tape/lseek bug at run time and warns about it.
2108 [4.1.3]
2109 * ls -R once again outputs a blank line between per-directory groups of files.
2110     This was broken by the cycle-detection change in 4.1.1.
2111 * dd once again uses `lseek' on character devices like /dev/mem and /dev/kmem.
2112     On systems with the linux kernel (at least up to 2.4.16), dd must still
2113     resort to emulating `skip=N' behavior using reads on tape devices, because
2114     lseek has no effect, yet appears to succeed.  This may be a kernel bug.
2115 [4.1.2]
2116 * cp no longer fails when two or more source files are the same;
2117     now it just gives a warning and doesn't copy the file the second time.
2118     E.g., cp a a d/ produces this:
2119     cp: warning: source file `a' specified more than once
2120 * chmod would set the wrong bit when given symbolic mode strings like
2121     these: g=o, o=g, o=u.  E.g., `chmod a=,o=w,ug=o f' would give a mode
2122     of --w-r---w- rather than --w--w--w-.
2123 [4.1.1]
2124 * mv (likewise for cp), now fails rather than silently clobbering one of
2125     the source files in the following example:
2126     rm -rf a b c; mkdir a b c; touch a/f b/f; mv a/f b/f c
2127 * ls -R detects directory cycles, per POSIX.  It warns and doesn't infloop.
2128 * cp's -P option now means the same as --no-dereference, per POSIX.
2129     Use --parents to get the old meaning.
2130 * When copying with the -H and -L options, cp can preserve logical
2131     links between source files with --preserve=links
2132 * cp accepts new options:
2133     --preserve[={mode,ownership,timestamps,links,all}]
2134     --no-preserve={mode,ownership,timestamps,links,all}
2135 * cp's -p and --preserve options remain unchanged and are equivalent
2136     to `--preserve=mode,ownership,timestamps'
2137 * mv and cp accept a new option: --reply={yes,no,query};  provides a consistent
2138     mechanism to control whether one is prompted about certain existing
2139     destination files.  Note that cp's and mv's -f options don't have the
2140     same meaning: cp's -f option no longer merely turns off `-i'.
2141 * remove portability limitations (e.g., PATH_MAX on the Hurd, fixes for
2142     64-bit systems)
2143 * mv now prompts before overwriting an existing, unwritable destination file
2144     when stdin is a tty, unless --force (-f) is specified, as per POSIX.
2145 * mv: fix the bug whereby `mv -uf source dest' would delete source,
2146     even though it's older than dest.
2147 * chown's --from=CURRENT_OWNER:CURRENT_GROUP option now works
2148 * cp now ensures that the set-user-ID and set-group-ID bits are cleared for
2149     the destination file when when copying and not preserving permissions.
2150 * `ln -f --backup k k' gives a clearer diagnostic
2151 * ls no longer truncates user names or group names that are longer
2152     than 8 characters.
2153 * ls's new --dereference-command-line option causes it to dereference
2154   symbolic links on the command-line only.  It is the default unless
2155   one of the -d, -F, or -l options are given.
2156 * ls -H now means the same as ls --dereference-command-line, as per POSIX.
2157 * ls -g now acts like ls -l, except it does not display owner, as per POSIX.
2158 * ls -n now implies -l, as per POSIX.
2159 * ls can now display dates and times in one of four time styles:
2160
2161   - The `full-iso' time style gives full ISO-style time stamps like
2162     `2001-05-14 23:45:56.477817180 -0700'.
2163   - The 'iso' time style gives ISO-style time stamps like '2001-05-14 '
2164     and '05-14 23:45'.
2165   - The 'locale' time style gives locale-dependent time stamps like
2166     'touko  14  2001' and 'touko  14 23:45' (in a Finnish locale).
2167   - The 'posix-iso' time style gives traditional POSIX-locale
2168     time stamps like 'May 14  2001' and 'May 14 23:45' unless the user
2169     specifies a non-POSIX locale, in which case it uses ISO-style dates.
2170     This is the default.
2171
2172   You can specify a time style with an option like --time-style='iso'
2173   or with an environment variable like TIME_STYLE='iso'.  GNU Emacs 21
2174   and later can parse ISO dates, but older Emacs versions cannot, so
2175   if you are using an older version of Emacs outside the default POSIX
2176   locale, you may need to set TIME_STYLE="locale".
2177
2178 * --full-time is now an alias for "-l --time-style=full-iso".
2179
2180
2181 ========================================================================
2182 Here are the NEWS entries made from sh-utils-2.0 until the
2183 point at which the packages merged to form the coreutils:
2184
2185  [2.0.15]
2186 * date no longer accepts e.g., September 31 in the MMDDhhmm syntax
2187 * fix a bug in this package's .m4 files and in configure.ac
2188  [2.0.14]
2189 * nohup's behavior is changed as follows, to conform to POSIX 1003.1-2001:
2190   - nohup no longer adjusts scheduling priority; use "nice" for that.
2191   - nohup now redirects stderr to stdout, if stderr is not a terminal.
2192   - nohup exit status is now 126 if command was found but not invoked,
2193     127 if nohup failed or if command was not found.
2194  [2.0.13]
2195 * uname and uptime work better on *BSD systems
2196 * pathchk now exits nonzero for a path with a directory component
2197     that specifies a non-directory
2198  [2.0.12]
2199 * kill: new program
2200 * who accepts new options: --all (-a), --boot (-b), --dead (-d), --login,
2201    --process (-p), --runlevel (-r), --short (-s), --time (-t), --users (-u).
2202    The -u option now produces POSIX-specified results and is the same as
2203    the long option `--users'.  --idle is no longer the same as -u.
2204 * The following changes apply on systems conforming to POSIX 1003.1-2001:
2205    - `date -I' is no longer supported.  Instead, use `date --iso-8601'.
2206    - `nice -NUM' is no longer supported.  Instead, use `nice -n NUM'.
2207   [This change was reverted in coreutils 5.3.1.]
2208 * New 'uname' options -i or --hardware-platform, and -o or --operating-system.
2209    'uname -a' now outputs -i and -o information at the end.
2210    New uname option --kernel-version is an alias for -v.
2211    Uname option --release has been renamed to --kernel-release,
2212    and --sysname has been renamed to --kernel-name;
2213    the old options will work for a while, but are no longer documented.
2214 * 'expr' now uses the LC_COLLATE locale for string comparison, as per POSIX.
2215 * 'expr' now requires '+' rather than 'quote' to quote tokens;
2216     this removes an incompatibility with POSIX.
2217 * date -d 'last friday' would print a date/time that was one hour off
2218     (e.g., 23:00 on *thursday* rather than 00:00 of the preceding friday)
2219     when run such that the current time and the target date/time fall on
2220     opposite sides of a daylight savings time transition.
2221     This problem arose only with relative date strings like `last monday'.
2222     It was not a problem with strings that include absolute dates.
2223 * factor is twice as fast, for large numbers
2224  [2.0.11]
2225 * setting the date now works properly, even when using -u
2226 * `date -f - < /dev/null' no longer dumps core
2227 * some DOS/Windows portability changes
2228  [2.0j]
2229 * `date -d DATE' now parses certain relative DATEs correctly
2230  [2.0i]
2231 * fixed a bug introduced in 2.0h that made many programs fail with a
2232  `write error' when invoked with the --version option
2233  [2.0h]
2234 * all programs fail when printing --help or --version output to a full device
2235 * printf exits nonzero upon write failure
2236 * yes now detects and terminates upon write failure
2237 * date --rfc-822 now always emits day and month names from the `C' locale
2238 * portability tweaks for Solaris8, Ultrix, and DOS
2239  [2.0g]
2240 * date now handles two-digit years with leading zeros correctly.
2241 * printf interprets unicode, \uNNNN \UNNNNNNNN, on systems with the
2242   required support;  from Bruno Haible.
2243 * stty's rprnt attribute now works on HPUX 10.20
2244 * seq's --equal-width option works more portably
2245  [2.0f]
2246 * fix build problems with ut_name vs. ut_user
2247  [2.0e]
2248 * stty: fix long-standing bug that caused test failures on at least HPUX
2249   systems when COLUMNS was set to zero
2250 * still more portability fixes
2251 * unified lib/: now that directory and most of the configuration framework
2252   is common between fileutils, textutils, and sh-utils
2253  [2.0d]
2254 * fix portability problem with sleep vs lib/strtod.c's requirement for -lm
2255  [2.0c]
2256 * fix portability problems with nanosleep.c and with the new code in sleep.c
2257  [2.0b]
2258 * Regenerate lib/Makefile.in so that nanosleep.c is distributed.
2259  [2.0a]
2260 * sleep accepts floating point arguments on command line
2261 * sleep's clock continues counting down when sleep is suspended
2262 * when a suspended sleep process is resumed, it continues sleeping if
2263   there is any time remaining
2264 * who once again prints whatever host information it has, even without --lookup
2265
2266 ========================================================================
2267 For older NEWS entries for the fileutils, textutils, and sh-utils
2268 packages, see ./old/*/NEWS.
2269
2270   This package began as the union of the following:
2271   textutils-2.1, fileutils-4.1.11, sh-utils-2.0.15.
2272
2273 ========================================================================
2274
2275 Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006 Free Software
2276 Foundation, Inc.
2277
2278 Permission is granted to copy, distribute and/or modify this document
2279 under the terms of the GNU Free Documentation License, Version 1.2 or
2280 any later version published by the Free Software Foundation; with no
2281 Invariant Sections, with no Front-Cover Texts, and with no Back-Cover
2282 Texts.  A copy of the license is included in the ``GNU Free
2283 Documentation License'' file as part of this distribution.