doc: remove extraneous new lines in some man pages
[coreutils.git] / NEWS
blobc9ba5f1965cd90435fda8133095f01ad5eb25f0d
1 GNU coreutils NEWS                                    -*- outline -*-
3 * Noteworthy changes in release ?.? (????-??-??) [?]
5 ** Bug fixes
7   `ls -Z dir` would crash.
8   [bug introduced in coreutils-9.6]
11 * Noteworthy changes in release 9.6 (2025-01-17) [stable]
13 ** Bug fixes
15   cp fixes support for --update=none-fail, which would have been
16   rejected as an invalid option.
17   [bug introduced in coreutils-9.5]
19   cp,mv --update no longer overrides --interactive or --force.
20   [bug introduced in coreutils-9.3]
22   csplit no longer creates empty files given empty input.
23   [This bug was present in "the beginning".]
25   ls and printf fix shell quoted output in the edge case of escaped
26   first and last characters, and single quotes in the string.
27   [bug introduced in coreutils-8.26]
29   ls -l no longer outputs "Permission denied" errors on NFS
30   which may happen with files without read permission, and which resulted
31   in inaccurate indication of ACLs (missing '+' flag after mode).
32   [bug introduced in coreutils-9.4]
34   ls -l no longer outputs "Not supported" errors on virtiofs.
35   [bug introduced in coreutils-9.4]
37   mv works again with macFUSE file systems.  Previously it would
38   have exited with a "Function not implemented" error.
39   [bug introduced in coreutils-8.28]
41   nproc gives more consistent results on systems with more than 1024 CPUs.
42   Previously it would have ignored the affinity mask on such systems.
43   [bug introduced with nproc in coreutils-8.1]
45   numfmt --from=iec-i now works with numbers without a suffix.
46   Previously such numbers were rejected with an error.
47   [bug introduced with numfmt in coreutils-8.21]
49   printf now diagnoses attempts to treat empty strings as numbers,
50   as per POSIX. For example, "printf '%d' ''" now issues a diagnostic
51   and fails instead of silently succeeding.
52   [This bug was present in "the beginning".]
54   pwd no longer outputs an erroneous double slash on systems
55   where the system getcwd() was completely replaced.
56   [bug introduced in coreutils-9.2]
58   'shuf' generates more-random output when the output is small.
59   [bug introduced in coreutils-8.6]
61   `tail --follow=name` no longer waits indefinitely for watched
62   file names that are moved elsewhere within the same file system.
63   [bug introduced in coreutils-8.24]
65   `tail --follow` without --retry, will consistently exit with failure status
66   where inotify is not used, when all followed files become inaccessible.
67   [This bug was present in "the beginning".]
69   `tail --follow --pid=PID` will now exit when the PID dies,
70   even in the presence of blocking inputs like unopened fifos.
71   [This bug was present in "the beginning".]
73   'tail -c 4096 /dev/zero' no longer loops forever.
74   [This bug was present in "the beginning".]
76 ** Changes in behavior
78   'factor' now buffers output more efficiently in some cases.
80   install -C now dereferences symlink sources when comparing,
81   rather than always treating as different and performing the copy.
83   kill -l and -t now list signal 0, as it's a valid signal to send.
85   ls's -f option now simply acts like -aU, instead of also ignoring
86   some earlier options.  For example 'ls -fl' and 'ls -lf' are now
87   equivalent because -f no longer ignores an earlier -l.  The new
88   behavior is more orthogonal and is compatible with FreeBSD.
90   stat -f -c%T now reports the "fuseblk" file system type as "fuse",
91   given that there is no longer a distinct "ctl" fuse variant file system.
93 ** New Features
95   cksum -a now supports the "crc32b" option, which calculates the CRC
96   of the input as defined by ITU V.42, as used by gzip for example.
97   For performance pclmul instructions are used where supported.
99   ls now supports the --sort=name option,
100   to explicitly select the default operation of sorting by file name.
102   printf now supports indexed arguments, using the POSIX:2024 specified
103   %<i>$ format, where '<i>' is an integer referencing a particular argument,
104   thus allowing repetition or reordering of printf arguments.
106   test supports the POSIX:2024 specified '<' and '>' operators with strings,
107   to compare the string locale collating order.
109   timeout now supports the POSIX:2024 specified -f, and -p short options,
110   corresponding to --foreground, and --preserve-status respectively.
112 ** Improvements
114   cksum -a crc, makes use of AVX2, AVX512, and ARMv8 SIMD extensions
115   for time reductions of up to 40%, 60%, and 80% respectively.
117   'head -c NUM', 'head -n NUM', 'nl -l NUM', 'nproc --ignore NUM',
118   'tail -c NUM', 'tail -n NUM', and 'tail --max-unchanged-stats NUM’
119   no longer fail merely because NUM stands for 2**64 or more.
121   sort operates more efficiently when used on pseudo files with
122   an apparent size of 0, like those in /proc.
124   stat and tail now know about the "bcachefs", and "pidfs" file system types.
125   stat -f -c%T now reports the file system type,
126   and tail -f uses inotify for these file systems.
128   wc now reads a minimum of 256KiB at a time.
129   This was previously 16KiB and increasing to 256KiB was seen to increase
130   wc -l performance by about 10% when reading cached files on modern systems.
133 * Noteworthy changes in release 9.5 (2024-03-28) [stable]
135 ** Bug fixes
137   chmod -R now avoids a race where an attacker may replace a traversed file
138   with a symlink, causing chmod to operate on an unintended file.
139   [This bug was present in "the beginning".]
141   cp, mv, and install no longer issue spurious diagnostics like "failed
142   to preserve ownership" when copying to GNU/Linux CIFS file systems.
143   They do this by working around some Linux CIFS bugs.
145   cp --no-preserve=mode will correctly maintain set-group-ID bits
146   for created directories.  Previously on systems that didn't support ACLs,
147   cp would have reset the set-group-ID bit on created directories.
148   [bug introduced in coreutils-8.20]
150   join and uniq now support multi-byte characters better.
151   For example, 'join -tX' now works even if X is a multi-byte character,
152   and both programs now treat multi-byte characters like U+3000
153   IDEOGRAPHIC SPACE as blanks if the current locale treats them so.
155   numfmt options like --suffix no longer have an arbitrary 127-byte limit.
156   [bug introduced with numfmt in coreutils-8.21]
158   mktemp with --suffix now better diagnoses templates with too few X's.
159   Previously it conflated the insignificant --suffix in the error.
160   [bug introduced in coreutils-8.1]
162   sort again handles thousands grouping characters in single-byte locales
163   where the grouping character is greater than CHAR_MAX.  For e.g. signed
164   character platforms with a 0xA0 (aka &nbsp) grouping character.
165   [bug introduced in coreutils-9.1]
167   split --line-bytes with a mixture of very long and short lines
168   no longer overwrites the heap (CVE-2024-0684).
169   [bug introduced in coreutils-9.2]
171   tail no longer mishandles input from files in /proc and /sys file systems,
172   on systems with a page size larger than the stdio BUFSIZ.
173   [This bug was present in "the beginning".]
175   timeout avoids a narrow race condition, where it might kill arbitrary
176   processes after a failed process fork.
177   [bug introduced with timeout in coreutils-7.0]
179   timeout avoids a narrow race condition, where it might fail to
180   kill monitored processes immediately after forking them.
181   [bug introduced with timeout in coreutils-7.0]
183   wc no longer fails to count unprintable characters as parts of words.
184   [bug introduced in textutils-2.1]
186 ** Changes in behavior
188   base32 and base64 no longer require padding when decoding.
189   Previously an error was given for non padded encoded data.
191   base32 and base64 have improved detection of corrupted encodings.
192   Previously encodings with non zero padding bits were accepted.
194   basenc --base16 -d now supports lower case hexadecimal characters.
195   Previously an error was given for lower case hex digits.
197   cp --no-clobber, and mv -n no longer exit with failure status if
198   existing files are encountered in the destination.  Instead they revert
199   to the behavior from before v9.2, silently skipping existing files.
201   ls --dired now implies long format output without hyperlinks enabled,
202   and will take precedence over previously specified formats or hyperlink mode.
204   numfmt will accept lowercase 'k' to indicate Kilo or Kibi units on input,
205   and uses lowercase 'k' when outputting such units in '--to=si' mode.
207   pinky no longer tries to canonicalize the user's login location by default,
208   rather requiring the new --lookup option to enable this often slow feature.
210   wc no longer ignores encoding errors when counting words.
211   Instead, it treats them as non white space.
213 ** New features
215   chgrp now accepts the --from=OWNER:GROUP option to restrict changes to files
216   with matching current OWNER and/or GROUP, as already supported by chown(1).
218   chmod adds support for -h, -H,-L,-P, and --dereference options, providing
219   more control over symlink handling.  This supports more secure handling of
220   CLI arguments, and is more consistent with chown, and chmod on other systems.
222   cp now accepts the --keep-directory-symlink option (like tar), to preserve
223   and follow existing symlinks to directories in the destination.
225   cp and mv now accept the --update=none-fail option, which is similar
226   to the --no-clobber option, except that existing files are diagnosed,
227   and the command exits with failure status if existing files.
228   The -n,--no-clobber option is best avoided due to platform differences.
230   env now accepts the -a,--argv0 option to override the zeroth argument
231   of the command being executed.
233   mv now accepts an --exchange option, which causes the source and
234   destination to be exchanged.  It should be combined with
235   --no-target-directory (-T) if the destination is a directory.
236   The exchange is atomic if source and destination are on a single
237   file system that supports atomic exchange; --exchange is not yet
238   supported in other situations.
240   od now supports printing IEEE half precision floating point with -t fH,
241   or brain 16 bit floating point with -t fB, where supported by the compiler.
243   tail now supports following multiple processes, with repeated --pid options.
245 ** Improvements
247   cp,mv,install,cat,split now read and write a minimum of 256KiB at a time.
248   This was previously 128KiB and increasing to 256KiB was seen to increase
249   throughput by 10-20% when reading cached files on modern systems.
251   env,kill,timeout now support unnamed signals. kill(1) for example now
252   supports sending such signals, and env(1) will list them appropriately.
254   SELinux operations in file copy operations are now more efficient,
255   avoiding unneeded MCS/MLS label translation.
257   sort no longer dynamically links to libcrypto unless -R is used.
258   This decreases startup overhead in the typical case.
260   wc is now much faster in single-byte locales and somewhat faster in
261   multi-byte locales.
264 * Noteworthy changes in release 9.4 (2023-08-29) [stable]
266 ** Bug fixes
268   On GNU/Linux s390x and alpha, programs like 'cp' and 'ls' no longer
269   fail on files with inode numbers that do not fit into 32 bits.
270   [This bug was present in "the beginning".]
272   'b2sum --check' will no longer read unallocated memory when
273   presented with malformed checksum lines.
274   [bug introduced in coreutils-9.2]
276   'cp --parents' again succeeds when preserving mode for absolute directories.
277   Previously it would have failed with a "No such file or directory" error.
278   [bug introduced in coreutils-9.1]
280   'cp --sparse=never' will avoid copy-on-write (reflinking) and copy offloading,
281   to ensure no holes present in the destination copy.
282   [bug introduced in coreutils-9.0]
284   cksum again diagnoses read errors in its default CRC32 mode.
285   [bug introduced in coreutils-9.0]
287   'cksum --check' now ensures filenames with a leading backslash character
288   are escaped appropriately in the status output.
289   This also applies to the standalone checksumming utilities.
290   [bug introduced in coreutils-8.25]
292   dd again supports more than two multipliers for numbers.
293   Previously numbers of the form '1024x1024x32' gave "invalid number" errors.
294   [bug introduced in coreutils-9.1]
296   factor, numfmt, and tsort now diagnose read errors on the input.
297   [This bug was present in "the beginning".]
299   'install --strip' now supports installing to files with a leading hyphen.
300   Previously such file names would have caused the strip process to fail.
301   [This bug was present in "the beginning".]
303   ls now shows symlinks specified on the command line that can't be traversed.
304   Previously a "Too many levels of symbolic links" diagnostic was given.
305   [This bug was present in "the beginning".]
307   pinky, uptime, users, and who no longer misbehave on 32-bit GNU/Linux
308   platforms like x86 and ARM where time_t was historically 32 bits.
309   Also see the new --enable-systemd option mentioned below.
310   [bug introduced in coreutils-9.0]
312   'pr --length=1 --double-space' no longer enters an infinite loop.
313   [This bug was present in "the beginning".]
315   shred again operates on Solaris when built for 64 bits.
316   Previously it would have exited with a "getrandom: Invalid argument" error.
317   [bug introduced in coreutils-9.0]
319   tac now handles short reads on its input.  Previously it may have exited
320   erroneously, especially with large input files with no separators.
321   [This bug was present in "the beginning".]
323   'uptime' no longer incorrectly prints "0 users" on OpenBSD,
324   and is being built again on FreeBSD and Haiku.
325   [bugs introduced in coreutils-9.2]
327   'wc -l' and 'cksum' no longer crash with an "Illegal instruction" error
328   on x86 Linux kernels that disable XSAVE YMM.  This was seen on Xen VMs.
329   [bug introduced in coreutils-9.0]
331 ** Changes in behavior
333   'cp -v' and 'mv -v' will no longer output a message for each file skipped
334   due to -i, or -u.  Instead they only output this information with --debug.
335   I.e., 'cp -u -v' etc. will have the same verbosity as before coreutils-9.3.
337   'cksum -b' no longer prints base64-encoded checksums.  Rather that
338   short option is reserved to better support emulation of the standalone
339   checksum utilities with cksum.
341   'mv dir x' now complains differently if x/dir is a nonempty directory.
342   Previously it said "mv: cannot move 'dir' to 'x/dir': Directory not empty",
343   where it was unclear whether 'dir' or 'x/dir' was the problem.
344   Now it says "mv: cannot overwrite 'x/dir': Directory not empty".
345   Similarly for other renames where the destination must be the problem.
346   [problem introduced in coreutils-6.0]
348 ** Improvements
350   cp, mv, and install now avoid copy_file_range on linux kernels before 5.3
351   irrespective of which kernel version coreutils is built against,
352   reinstating that behavior from coreutils-9.0.
354   comm, cut, join, od, and uniq will now exit immediately upon receiving a
355   write error, which is significant when reading large / unbounded inputs.
357   split now uses more tuned access patterns for its potentially large input.
358   This was seen to improve throughput by 5% when reading from SSD.
360   split now supports a configurable $TMPDIR for handling any temporary files.
362   tac now falls back to '/tmp' if a configured $TMPDIR is unavailable.
364   'who -a' now displays the boot time on Alpine Linux, OpenBSD,
365   Cygwin, Haiku, and some Android distributions
367   'uptime' now succeeds on some Android distributions, and now counts
368   VM saved/sleep time on GNU (Linux, Hurd, kFreeBSD), NetBSD, OpenBSD,
369   Minix, and Cygwin.
371   On GNU/Linux platforms where utmp-format files have 32-bit timestamps,
372   pinky, uptime, and who can now work for times after the year 2038,
373   so long as systemd is installed, you configure with a new, experimental
374   option --enable-systemd, and you use the programs without file arguments.
375   (For example, with systemd 'who /var/log/wtmp' does not work because
376   systemd does not support the equivalent of /var/log/wtmp.)
379 * Noteworthy changes in release 9.3 (2023-04-18) [stable]
381 ** Bug fixes
383   cp --reflink=auto (the default), mv, and install
384   will again fall back to a standard copy in more cases.
385   Previously copies could fail with permission errors on
386   more restricted systems like android or containers etc.
387   [bug introduced in coreutils-9.2]
389   cp --recursive --backup will again operate correctly.
390   Previously it may have issued "File exists" errors when
391   it failed to appropriately rename files being replaced.
392   [bug introduced in coreutils-9.2]
394   date --file and dircolors will now diagnose a failure to read a file.
395   Previously they would have silently ignored the failure.
396   [This bug was present in "the beginning".]
398   md5sum --check again correctly prints the status of each file checked.
399   Previously the status for files was printed as 'OK' once any file had passed.
400   This also applies to cksum, sha*sum, and b2sum.
401   [bug introduced in coreutils-9.2]
403   wc will now diagnose if any total counts have overflowed.
404   [This bug was present in "the beginning".]
406   `wc -c` will again correctly update the read offset of inputs.
407   Previously it deduced the size of inputs while leaving the offset unchanged.
408   [bug introduced in coreutils-8.27]
410   Coreutils programs no longer fail for timestamps past the year 2038
411   on obsolete configurations with 32-bit signed time_t, because the
412   build procedure now rejects these configurations.
413   [This bug was present in "the beginning".]
415 ** Changes in behavior
417   'cp -n' and 'mv -n' now issue an error diagnostic if skipping a file,
418   to correspond with -n inducing a nonzero exit status as of coreutils 9.2.
419   Similarly 'cp -v' and 'mv -v' will output a message for each file skipped
420   due to -n, -i, or -u.
422 ** New features
424   cp and mv now support --update=none to always skip existing files
425   in the destination, while not affecting the exit status.
426   This is equivalent to the --no-clobber behavior from before v9.2.
429 * Noteworthy changes in release 9.2 (2023-03-20) [stable]
431 ** Bug fixes
433   'comm --output-delimiter="" --total' now delimits columns in the total
434   line with the NUL character, consistent with NUL column delimiters in
435   the rest of the output.  Previously no delimiters were used for the
436   total line in this case.
437   [bug introduced with the --total option in coreutils-8.26]
439   'cp -p' no longer has a security hole when cloning into a dangling
440   symbolic link on macOS 10.12 and later.
441   [bug introduced in coreutils-9.1]
443   'cp -rx / /mnt' no longer complains "cannot create directory /mnt/".
444   [bug introduced in coreutils-9.1]
446   cp, mv, and install avoid allocating too much memory, and possibly
447   triggering "memory exhausted" failures, on file systems like ZFS,
448   which can return varied file system I/O block size values for files.
449   [bug introduced in coreutils-6.0]
451   cp, mv, and install now immediately acknowledge transient errors
452   when creating copy-on-write or cloned reflink files, on supporting
453   file systems like XFS, BTRFS, APFS, etc.
454   Previously they would have tried again with other copy methods
455   which may have resulted in data corruption.
456   [bug introduced in coreutils-7.5 and enabled by default in coreutils-9.0]
458   cp, mv, and install now handle ENOENT failures across CIFS file systems,
459   falling back from copy_file_range to a better supported standard copy.
460   [issue introduced in coreutils-9.0]
462   'mv --backup=simple f d/' no longer mistakenly backs up d/f to f~.
463   [bug introduced in coreutils-9.1]
465   rm now fails gracefully when memory is exhausted.
466   Previously it may have aborted with a failed assertion in some cases.
467   [This bug was present in "the beginning".]
469   rm -d (--dir) now properly handles unreadable empty directories.
470   E.g., before, this would fail to remove d: mkdir -m0 d; src/rm -d d
471   [bug introduced in v8.19 with the addition of this option]
473   runcon --compute no longer looks up the specified command in the $PATH
474   so that there is no mismatch between the inspected and executed file.
475   [bug introduced when runcon was introduced in coreutils-6.9.90]
477   'sort -g' no longer infloops when given multiple NaNs on platforms
478   like x86_64 where 'long double' has padding bits in memory.
479   Although the fix alters sort -g's NaN ordering, that ordering has
480   long been documented to be platform-dependent.
481   [bug introduced 1999-05-02 and only partly fixed in coreutils-8.14]
483   stty ispeed and ospeed options no longer accept and silently ignore
484   invalid speed arguments, or give false warnings for valid speeds.
485   Now they're validated against both the general accepted set,
486   and the system supported set of valid speeds.
487   [This bug was present in "the beginning".]
489   stty now wraps output appropriately for the terminal width.
490   Previously it may have output 1 character too wide for certain widths.
491   [bug introduced in coreutils-5.3]
493   tail --follow=name works again with non seekable files.  Previously it
494   exited with an "Illegal seek" error when such a file was replaced.
495   [bug introduced in fileutils-4.1.6]
497   'wc -c' will again efficiently determine the size of large files
498   on all systems.  It no longer redundantly reads data from certain
499   sized files larger than SIZE_MAX.
500   [bug introduced in coreutils-8.24]
502 ** Changes in behavior
504   Programs now support the new Ronna (R), and Quetta (Q) SI prefixes,
505   corresponding to 10^27 and 10^30 respectively,
506   along with their binary counterparts Ri (2^90) and Qi (2^100).
507   In some cases (e.g., 'sort -h') these new prefixes simply work;
508   in others, where they exceed integer width limits, they now elicit
509   the same integer overflow diagnostics as other large prefixes.
511   'cp --reflink=always A B' no longer leaves behind a newly created
512   empty file B merely because copy-on-write clones are not supported.
514   'cp -n' and 'mv -n' now exit with nonzero status if they skip their
515   action because the destination exists, and likewise for 'cp -i',
516   'ln -i', and 'mv -i' when the user declines.  (POSIX specifies this
517   for 'cp -i' and 'mv -i'.)
519   cp, mv, and install again read in multiples of the reported block size,
520   to support unusual devices that may have this constraint.
521   [behavior inadvertently changed in coreutils-7.2]
523   du --apparent now counts apparent sizes only of regular files and
524   symbolic links.  POSIX does not specify the meaning of apparent
525   sizes (i.e., st_size) for other file types, and counting those sizes
526   could cause confusing and unwanted size mismatches.
528   'ls -v' and 'sort -V' go back to sorting ".0" before ".A",
529   reverting to the behavior in coreutils-9.0 and earlier.
530   This behavior is now documented.
532   ls --color now matches a file extension case sensitively
533   if there are different sequences defined for separate cases.
535   printf unicode \uNNNN, \UNNNNNNNN syntax, now supports all valid
536   unicode code points.  Previously is was restricted to the C
537   universal character subset, which restricted most points <= 0x9F.
539   runcon now exits with status 125 for internal errors.  Previously upon
540   internal errors it would exit with status 1, which was less distinguishable
541   from errors from the invoked command.
543   'split -n N' now splits more evenly when the input size is not a
544   multiple of N, by creating N output files whose sizes differ by at
545   most 1 byte.  Formerly, it did this only when the input size was
546   less than N.
548   'stat -c %s' now prints sizes as unsigned, consistent with 'ls'.
550 ** New Features
552   cksum now accepts the --base64 (-b) option to print base64-encoded
553   checksums.  It also accepts/checks such checksums.
555   cksum now accepts the --raw option to output a raw binary checksum.
556   No file name or other information is output in this mode.
558   cp, mv, and install now accept the --debug option to
559   print details on how a file is being copied.
561   factor now accepts the --exponents (-h) option to print factors
562   in the form p^e, rather than repeating the prime p, e times.
564   ls now supports the --time=modification option, to explicitly
565   select the default mtime timestamp for display and sorting.
567   mv now supports the --no-copy option, which causes it to fail when
568   asked to move a file to a different file system.
570   split now accepts options like '-n SIZE' that exceed machine integer
571   range, when they can be implemented as if they were infinity.
573   split -n now accepts piped input even when not in round-robin mode,
574   by first copying input to a temporary file to determine its size.
576   wc now accepts the --total={auto,never,always,only} option
577   to give explicit control over when the total is output.
579 ** Improvements
581   cp --sparse=auto (the default), mv, and install,
582   will use the copy_file_range syscall now also with sparse files.
583   This may be more efficient, by avoiding user space copies,
584   and possibly employing copy offloading or reflinking,
585   for the non sparse portion of such sparse files.
587   On macOS, cp creates a copy-on-write clone in more cases.
588   Previously cp would only do this when preserving mode and timestamps.
590   date --debug now diagnoses if multiple --date or --set options are
591   specified, as only the last specified is significant in that case.
593   rm outputs more accurate diagnostics in the presence of errors
594   when removing directories.  For example EIO will be faithfully
595   diagnosed, rather than being conflated with ENOTEMPTY.
597   tail --follow=name now works with single non regular files even
598   when their modification time doesn't change when new data is available.
599   Previously tail would not show any new data in this case.
601   tee -p detects when all remaining outputs have become broken pipes, and
602   exits, rather than waiting for more input to induce an exit when written.
604   tee now handles non blocking outputs, which can be seen for example with
605   telnet or mpirun piping through tee to a terminal.
606   Previously tee could truncate data written to such an output and fail,
607   and also potentially output a "Resource temporarily unavailable" error.
610 * Noteworthy changes in release 9.1 (2022-04-15) [stable]
612 ** Bug fixes
614   chmod -R no longer exits with error status when encountering symlinks.
615   All files would be processed correctly, but the exit status was incorrect.
616   [bug introduced in coreutils-9.0]
618   If 'cp -Z A B' checks B's status and some other process then removes B,
619   cp no longer creates B with a too-generous SELinux security context
620   before adjusting it to the correct value.
621   [bug introduced in coreutils-8.17]
623   'cp --preserve=ownership A B' no longer ignores the umask when creating B.
624   Also, 'cp --preserve-xattr A B' is less likely to temporarily chmod u+w B.
625   [bug introduced in coreutils-6.7]
627   On macOS, 'cp A B' no longer miscopies when A is in an APFS file system
628   and B is in some other file system.
629   [bug introduced in coreutils-9.0]
631   On macOS, fmt no longer corrupts multi-byte characters
632   by misdetecting their component bytes as spaces.
633   [This bug was present in "the beginning".]
635   'id xyz' now uses the name 'xyz' to determine groups, instead of xyz's uid.
636   [bug introduced in coreutils-8.22]
638   'ls -v' and 'sort -V' no longer mishandle corner cases like "a..a" vs "a.+"
639   or lines containing NULs.  Their behavior now matches the documentation
640   for file names like ".m4" that consist entirely of an extension,
641   and the documentation has been clarified for unusual cases.
642   [bug introduced in coreutils-7.0]
644   On macOS, 'mv A B' no longer fails with "Operation not supported"
645   when A and B are in the same tmpfs file system.
646   [bug introduced in coreutils-9.0]
648   'mv -T --backup=numbered A B/' no longer miscalculates the backup number
649   for B when A is a directory, possibly inflooping.
650   [bug introduced in coreutils-6.3]
652 ** Changes in behavior
654   cat now uses the copy_file_range syscall if available, when doing
655   simple copies between regular files.  This may be more efficient, by avoiding
656   user space copies, and possibly employing copy offloading or reflinking.
658   chown and chroot now warn about usages like "chown root.root f",
659   which have the nonstandard and long-obsolete "." separator that
660   causes problems on platforms where user names contain ".".
661   Applications should use ":" instead of ".".
663   cksum no longer allows abbreviated algorithm names,
664   so that forward compatibility and robustness is improved.
666   date +'%-N' now suppresses excess trailing digits, instead of always
667   padding them with zeros to 9 digits.  It uses clock_getres and
668   clock_gettime to infer the clock resolution.
670   dd conv=fsync now synchronizes output even after a write error,
671   and similarly for dd conv=fdatasync.
673   dd now counts bytes instead of blocks if a block count ends in "B".
674   For example, 'dd count=100KiB' now copies 100 KiB of data, not
675   102,400 blocks of data.  The flags count_bytes, skip_bytes and
676   seek_bytes are therefore obsolescent and are no longer documented,
677   though they still work.
679   ls no longer colors files with capabilities by default, as file-based
680   capabilities are rarely used, and lookup increases processing per file by
681   about 30%.  It's best to use getcap [-r] to identify files with capabilities.
683   ls no longer tries to automount files, reverting to the behavior
684   before the statx() call was introduced in coreutils-8.32.
686   stat no longer tries to automount files by default, reverting to the
687   behavior before the statx() call was introduced in coreutils-8.32.
688   Only `stat --cached=never` will continue to automount files.
690   timeout --foreground --kill-after=... will now exit with status 137
691   if the kill signal was sent, which is consistent with the behavior
692   when the --foreground option is not specified.  This allows users to
693   distinguish if the command was more forcefully terminated.
695 ** New Features
697   dd now supports the aliases iseek=N for skip=N, and oseek=N for seek=N,
698   like FreeBSD and other operating systems.
700   dircolors takes a new --print-ls-colors option to display LS_COLORS
701   entries, on separate lines, colored according to the entry color code.
703   dircolors will now also match COLORTERM in addition to TERM environment
704   variables.  The default config will apply colors with any COLORTERM set.
706 ** Improvements
708   cp, mv, and install now use openat-like syscalls when copying to a directory.
709   This avoids some race conditions and should be more efficient.
711   On macOS, cp creates a copy-on-write clone if source and destination
712   are regular files on the same APFS file system, the destination does
713   not already exist, and cp is preserving mode and timestamps (e.g.,
714   'cp -p', 'cp -a').
716   The new 'date' option --resolution outputs the timestamp resolution.
718   With conv=fdatasync or conv=fsync, dd status=progress now reports
719   any extra final progress just before synchronizing output data,
720   since synchronizing can take a long time.
722   printf now supports printing the numeric value of multi-byte characters.
724   sort --debug now diagnoses issues with --field-separator characters
725   that conflict with characters possibly used in numbers.
727   'tail -f file | filter' now exits on Solaris when filter exits.
729   root invoked coreutils, that are built and run in single binary mode,
730   now adjust /proc/$pid/cmdline to be more specific to the utility
731   being run, rather than using the general "coreutils" binary name.
733 ** Build-related
735   AIX builds no longer fail because some library functions are not found.
736   [bug introduced in coreutils-8.32]
739 * Noteworthy changes in release 9.0 (2021-09-24) [stable]
741 ** Bug fixes
743   chmod -v no longer misreports modes of dangling symlinks.
744   [bug introduced in coreutils-5.3.0]
746   cp -a --attributes-only now never removes destination files,
747   even if the destination files are hardlinked, or the source
748   is a non regular file.
749   [bug introduced in coreutils-8.6]
751   csplit --suppress-matched now elides the last matched line
752   when a specific number of pattern matches are performed.
753   [bug introduced with the --suppress-matched feature in coreutils-8.22]
755   df no longer outputs duplicate remote mounts in the presence of bind mounts.
756   [bug introduced in coreutils-8.26]
758   df no longer mishandles command-line args that it pre-mounts
759   [bug introduced in coreutils-8.29]
761   du no longer crashes on XFS file systems when the directory hierarchy is
762   heavily changed during the run.
763   [bug introduced in coreutils-8.25]
765   env -S no longer crashes when given unusual whitespace characters
766   [bug introduced in coreutils-8.30]
768   expr no longer mishandles unmatched \(...\) in regular expressions.
769   [bug introduced in coreutils-6.0]
771   ls no longer crashes when printing the SELinux context for unstattable files.
772   [bug introduced in coreutils-6.9.91]
774   mkdir -m no longer mishandles modes more generous than the umask.
775   [bug introduced in coreutils-8.22]
777   nl now handles single character --section-delimiter arguments,
778   by assuming a second ':' character has been specified, as specified by POSIX.
779   [This bug was present in "the beginning".]
781   pr again adjusts tabs in input, to maintain alignment in multi column output.
782   [bug introduced in coreutils-6.9]
784   rm no longer skips an extra file when the removal of an empty directory fails.
785   [bug introduced by the rewrite to use fts in coreutils-8.0]
787   split --number=K/N will again correctly split chunk K of N to stdout.
788   Previously a chunk starting after 128KiB, output the wrong part of the file.
789   [bug introduced in coreutils-8.26]
791   tail -f no longer overruns a stack buffer when given too many files
792   to follow and ulimit -n exceeds 1024.
793   [bug introduced in coreutils-7.5]
795   tr no longer crashes when using --complement with certain
796   invalid combinations of case character classes.
797   [bug introduced in coreutils-8.6]
799   basenc --base64 --decode no longer silently discards decoded characters
800   on (1024*5) buffer boundaries
801   [bug introduced in coreutils-8.31]
803 ** Changes in behavior
805   cp and install now default to copy-on-write (COW) if available.
806   I.e., cp now uses --reflink=auto mode by default.
808   cp, install and mv now use the copy_file_range syscall if available.
809   Also, they use lseek+SEEK_HOLE rather than ioctl+FS_IOC_FIEMAP on sparse
810   files, as lseek is simpler and more portable.
812   On GNU/Linux systems, ls no longer issues an error message on a
813   directory merely because it was removed.  This reverts a change
814   that was made in release 8.32.
816   ptx -T no longer attempts to substitute old-fashioned TeX escapes
817   for 8-bit non-ASCII alphabetic characters.  TeX indexes should
818   instead use '\usepackage[latin1]{inputenc}' or equivalent.
820   stat will use decomposed (major,minor) device numbers in its default format.
821   This is less ambiguous, and more consistent with ls.
823   sum [-r] will output a file name, even if only a single name is passed.
824   This is consistent with sum -s, cksum, and other sum(1) implementations.
826 ** New Features
828   cksum now supports the -a (--algorithm) option to select any
829   of the existing sum, md5sum, b2sum, sha*sum implementations etc.
830   cksum now subsumes all of these programs, and coreutils
831   will introduce no future standalone checksum utility.
833   cksum -a now supports the 'sm3' argument, to use the SM3 digest algorithm.
835   cksum --check now supports auto detecting the digest type to use,
836   when verifying tagged format checksums.
838   expr and factor now support bignums on all platforms.
840   ls --classify now supports the "always", "auto", or "never" flags,
841   to support only outputting classifier characters if connected to a tty.
843   ls now accepts the --sort=width option, to sort by file name width.
844   This is useful to more compactly organize the default vertical column output.
846   ls now accepts the --zero option, to terminate each output line with
847   NUL instead of newline.
849   nl --line-increment can now take a negative number to decrement the count.
851   stat supports more formats for representing decomposed device numbers.
852   %Hd,%Ld and %Hr,%Lr will output major,minor device numbers and device types
853   respectively.  %d corresponds to st_dev and %r to std_rdev.
855 ** Improvements
857   cat --show-ends will now show \r\n as ^M$.  Previously the \r was taken
858   literally, thus overwriting the first character in the line with '$'.
860   cksum [-a crc] is now up to 4 times faster by using a slice by 8 algorithm,
861   and at least 8 times faster where pclmul instructions are supported.
862   A new --debug option will indicate if pclmul is being used.
864   md5sum --check now supports checksum files with CRLF line endings.
865   This also applies to cksum, sha*sum, and b2sum.
867   df now recognizes these file systems as remote:
868   acfs, coda, fhgfs, gpfs, ibrix, ocfs2, and vxfs.
870   rmdir now clarifies the error if a symlink_to_dir/ has not been traversed.
871   This is the case on GNU/Linux systems, where the trailing slash is ignored.
873   stat and tail now know about the "devmem", "exfat", "secretmem", "vboxsf",
874   and "zonefs" file system types.  stat -f -c%T now reports the file system
875   type, and tail -f uses polling for "vboxsf" and inotify for the others.
877   timeout now supports sub-second timeouts on macOS.
879   wc is up to 5 times faster when counting only new line characters,
880   where avx2 instructions are supported.
881   A new --debug option will indicate if avx2 is being used.
884 * Noteworthy changes in release 8.32 (2020-03-05) [stable]
886 ** Bug fixes
888   cp now copies /dev/fd/N correctly on platforms like Solaris where
889   it is a character-special file whose minor device number is N.
890   [bug introduced in fileutils-4.1.6]
892   dd conv=fdatasync no longer reports a "Bad file descriptor" error
893   when fdatasync is interrupted, and dd now retries interrupted calls
894   to close, fdatasync, fstat and fsync instead of incorrectly
895   reporting an "Interrupted system call" error.
896   [bugs introduced in coreutils-6.0]
898   df now correctly parses the /proc/self/mountinfo file for unusual entries
899   like ones with '\r' in a field value ("mount -t tmpfs tmpfs /foo$'\r'bar"),
900   when the source field is empty ('mount -t tmpfs "" /mnt'), and when the
901   filesystem type contains characters like a blank which need escaping.
902   [bugs introduced in coreutils-8.24 with the introduction of reading
903    the /proc/self/mountinfo file]
905   factor again outputs immediately when stdout is a tty but stdin is not.
906   [bug introduced in coreutils-8.24]
908   ln works again on old systems without O_DIRECTORY support (like Solaris 10),
909   and on systems where symlink ("x", ".") fails with errno == EINVAL
910   (like Solaris 10 and Solaris 11).
911   [bug introduced in coreutils-8.31]
913   rmdir --ignore-fail-on-non-empty now works correctly for directories
914   that fail to be removed due to permission issues.  Previously the exit status
915   was reversed, failing for non empty and succeeding for empty directories.
916   [bug introduced in coreutils-6.11]
918   'shuf -r -n 0 file' no longer mistakenly reads from standard input.
919   [bug introduced with the --repeat feature in coreutils-8.22]
921   split no longer reports a "output file suffixes exhausted" error
922   when the specified number of files is evenly divisible by 10, 16, 26,
923   for --numeric, --hex, or default alphabetic suffixes respectively.
924   [bug introduced in coreutils-8.24]
926   seq no longer prints an extra line under certain circumstances (such as
927   'seq -f "%g " 1000000 1000000').
928   [bug introduced in coreutils-6.10]
930 ** Changes in behavior
932   Several programs now check that numbers end properly.  For example,
933   'du -d 1x' now reports an error instead of silently ignoring the 'x'.
934   Affected programs and options include du -d, expr's numeric operands
935   on non-GMP builds, install -g and -o, ls's TABSIZE environment
936   variable, mknod b and c, ptx -g and -w, shuf -n, and sort --batch-size
937   and --parallel.
939   date now parses military time zones in accordance with common usage:
940     "A" to "M"  are equivalent to UTC+1 to UTC+12
941     "N" to "Y"  are equivalent to UTC-1 to UTC-12
942     "Z" is "zulu" time (UTC).
943   For example, 'date -d "09:00B" is now equivalent to 9am in UTC+2 time zone.
944   Previously, military time zones were parsed according to the obsolete
945   rfc822, with their value negated (e.g., "B" was equivalent to UTC-2).
946   [The old behavior was introduced in sh-utils 2.0.15 ca. 1999, predating
947   coreutils package.]
949   date now pads nanoseconds on the right, not the left.  For example,
950   if the time is currently 1590020079.003388470 seconds after the
951   Epoch, then "date '+%s.%-N'" formerly output "1590020079.3388470",
952   and it now outputs "1590020079.00338847".
954   ls issues an error message on a removed directory, on GNU/Linux systems.
955   Previously no error and no entries were output, and so indistinguishable
956   from an empty directory, with default ls options.
958   uniq no longer uses strcoll() to determine string equivalence,
959   and so will operate more efficiently and consistently.
961 ** New Features
963   ls now supports the --time=birth option to display and sort by
964   file creation time, where available.
966   od --skip-bytes now can use lseek even if the input is not a regular
967   file, greatly improving performance in some cases.
969   stat(1) supports a new --cached= option, used on systems with statx(2)
970   to control cache coherency of file system attributes,
971   useful on network file systems.
973 ** Improvements
975   stat and ls now use the statx() system call where available, which can
976   operate more efficiently by only retrieving requested attributes.
978   stat and tail now know about the "binderfs", "dma-buf-fs", "erofs",
979   "ppc-cmm-fs", and "z3fold" file systems.
980   stat -f -c%T now reports the file system type, and tail -f uses inotify.
982 ** Build-related
984   gzip-compressed tarballs are distributed once again
987 * Noteworthy changes in release 8.31 (2019-03-10) [stable]
989 ** Bug fixes
991   'base64 a b' now correctly diagnoses 'b' as the extra operand, not 'a'.
992   [bug introduced in coreutils-5.3.0]
994   When B already exists, 'cp -il A B' no longer immediately fails
995   after asking the user whether to proceed.
996   [This bug was present in "the beginning".]
998   df no longer corrupts displayed multibyte characters on macOS.
999   [bug introduced with coreutils-8.18]
1001   seq no longer outputs inconsistent decimal point characters
1002   for the last number, when locales are misconfigured.
1003   [bug introduced in coreutils-7.0]
1005   shred, sort, and split no longer falsely report ftruncate errors
1006   when outputting to less-common file types.  For example, the shell
1007   command 'sort /dev/null -o /dev/stdout | cat' no longer fails with
1008   an "error truncating" diagnostic.
1009   [bug was introduced with coreutils-8.18 for sort and split, and
1010    (for shared memory objects only) with fileutils-4.1 for shred]
1012   sync no longer fails for write-only file arguments.
1013   [bug introduced with argument support to sync in coreutils-8.24]
1015   'tail -f file | filter' no longer exits immediately on AIX.
1016   [bug introduced in coreutils-8.28]
1018   'tail -f file | filter' no longer goes into an infinite loop
1019   if filter exits and SIGPIPE is ignored.
1020   [bug introduced in coreutils-8.28]
1022 ** Changes in behavior
1024   cksum, dd, hostid, hostname, link, logname, sleep, tsort, unlink,
1025   uptime, users, whoami, yes: now always process --help and --version options,
1026   regardless of any other arguments present before any optional '--'
1027   end-of-options marker.
1029   nohup now processes --help and --version as first options even if other
1030   parameters follow.
1032   'yes a -- b' now outputs 'a b' instead of including the end-of-options
1033   marker as before: 'a -- b'.
1035   echo now always processes backslash escapes when the POSIXLY_CORRECT
1036   environment variable is set.
1038   When possible 'ln A B' now merely links A to B and reports an error
1039   if this fails, instead of statting A and B before linking.  This
1040   uses fewer system calls and avoids some races.  The old statting
1041   approach is still used in situations where hard links to directories
1042   are allowed (e.g., NetBSD when superuser).
1044   ls --group-directories-first will also group symlinks to directories.
1046   'test -a FILE' is not supported anymore.  Long ago, there were concerns about
1047   the high probability of humans confusing the -a primary with the -a binary
1048   operator, so POSIX changed this to 'test -e FILE'.  Scripts using it were
1049   already broken and non-portable; the -a unary operator was never documented.
1051   wc now treats non breaking space characters as word delimiters
1052   unless the POSIXLY_CORRECT environment variable is set.
1054 ** New features
1056   id now supports specifying multiple users.
1058   'date' now supports the '+' conversion specification flag,
1059   introduced in POSIX.1-2017.
1061   printf, seq, sleep, tail, and timeout now accept floating point
1062   numbers in either the current or the C locale.  For example, if the
1063   current locale's decimal point is ',', 'sleep 0,1' and 'sleep 0.1'
1064   now mean the same thing.  Previously, these commands accepted only
1065   C-locale syntax with '.' as the decimal point.  The new behavior is
1066   more compatible with other implementations in non-C locales.
1068   test now supports the '-N FILE' unary operator (like e.g. bash) to check
1069   whether FILE exists and has been modified since it was last read.
1071   env now supports '--default-signal[=SIG]', '--ignore-signal[=SIG]', and
1072   '--block-signal[=SIG], to setup signal handling before executing a program.
1074   env now supports '--list-signal-handling' to indicate non-default
1075   signal handling before executing a program.
1077 ** New programs
1079   basenc is added to complement existing base64,base32 commands,
1080   and encodes and decodes printable text using various common encodings:
1081   base64,base64url,base32,base32hex,base16,base2,z85.
1083 ** Improvements
1085   ls -l now better aligns abbreviated months containing digits,
1086   which is common in Asian locales.
1088   stat and tail now know about the "sdcardfs" file system on Android.
1089   stat -f -c%T now reports the file system type, and tail -f uses inotify.
1091   stat now prints file creation time when supported by the file system,
1092   on GNU Linux systems with glibc >= 2.28 and kernel >= 4.11.
1095 * Noteworthy changes in release 8.30 (2018-07-01) [stable]
1097 ** Bug fixes
1099   'cp --symlink SRC DST' will again correctly validate DST.
1100   If DST is a regular file and SRC is a symlink to DST,
1101   then cp will no longer allow that operation to clobber DST.
1102   Also with -d, if DST is a symlink, then it can always be replaced,
1103   even if it points to SRC on a separate device.
1104   [bugs introduced with coreutils-8.27]
1106   'cp -n -u' and 'mv -n -u' now consistently ignore the -u option.
1107   Previously, this option combination suffered from race conditions
1108   that caused -u to sometimes override -n.
1109   [bug introduced with coreutils-7.1]
1111   'cp -a --no-preserve=mode' now sets appropriate default permissions
1112   for non regular files like fifos and character device nodes etc.,
1113   and leaves mode bits of existing files unchanged.
1114   Previously it would have set executable bits on created special files,
1115   and set mode bits for existing files as if they had been created.
1116   [bug introduced with coreutils-8.20]
1118   'cp --remove-destination file symlink' now removes the symlink
1119   even if it can't be traversed.
1120   [bug introduced with --remove-destination in fileutils-4.1.1]
1122   ls no longer truncates the abbreviated month names that have a
1123   display width between 6 and 12 inclusive.  Previously this would have
1124   output ambiguous months for Arabic or Catalan locales.
1126   'ls -aA' is now equivalent to 'ls -A', since -A now overrides -a.
1127   [bug introduced in coreutils-5.3.0]
1129   'mv -n A B' no longer suffers from a race condition that can
1130   overwrite a simultaneously-created B.  This bug fix requires
1131   platform support for the renameat2 or renameatx_np syscalls, found
1132   in recent Linux and macOS kernels.  As a side effect, 'mv -n A A'
1133   now silently does nothing if A exists.
1134   [bug introduced with coreutils-7.1]
1136 ** Changes in behavior
1138   'cp --force file symlink' now removes the symlink even if
1139   it is self referential.
1141   ls --color now matches file extensions case insensitively.
1143 ** New features
1145   cp --reflink now supports --reflink=never to enforce a standard copy.
1147   env supports a new -v/--debug option to show verbose information about
1148   each processing step.
1150   env supports a new -S/--split-string=S option to split a single argument
1151   string into multiple arguments. Used to pass multiple arguments in scripts
1152   (shebang lines).
1154   md5sum accepts a new option: --zero (-z) to delimit the output lines with a
1155   NUL instead of a newline character.  This also disables file name escaping.
1156   This also applies to sha*sum and b2sum.
1158   rm --preserve-root now supports the --preserve-root=all option to
1159   reject any command line argument that is mounted to a separate file system.
1161 ** Improvements
1163   cut supports line lengths up to the max file size on 32 bit systems.
1164   Previously only offsets up to SIZE_MAX-1 were supported.
1166   stat and tail now know about the "exfs" file system, which is a
1167   version of XFS.  stat -f --format=%T now reports the file system type,
1168   and tail -f uses inotify.
1170   wc avoids redundant processing of ASCII text in multibyte locales,
1171   which is especially significant on macOS.
1174 * Noteworthy changes in release 8.29 (2017-12-27) [stable]
1176 ** Bug fixes
1178   b2sum no longer crashes when processing certain truncated check files.
1179   [bug introduced with b2sum coreutils-8.26]
1181   dd now ensures the correct cache ranges are specified for the "nocache"
1182   and "direct" flags.  Previously some pages in the page cache were not
1183   invalidated.  [bug introduced for "direct" in coreutils-7.5,
1184   and with the "nocache" implementation in coreutils-8.11]
1186   df no longer hangs when given a fifo argument.
1187   [bug introduced in coreutils-7.3]
1189   ptx -S no longer infloops for a pattern which returns zero-length matches.
1190   [the bug dates back to the initial implementation]
1192   shred --remove will again repeatedly rename files with shortening names
1193   to attempt to hide the original length of the file name.
1194   [bug introduced in coreutils-8.28]
1196   stty no longer crashes when processing settings with -F also specified.
1197   [bug introduced in fileutils-4.0]
1199   tail --bytes again supports non seekable inputs on all systems.
1200   On systems like android it always tried to process as seekable inputs.
1201   [bug introduced in coreutils-8.24]
1203   timeout will again notice its managed command exiting, even when
1204   invoked with blocked CHLD signal, or in a narrow window where
1205   this CHLD signal from the exiting child was missed.  In each case
1206   timeout would have then waited for the time limit to expire.
1207   [bug introduced in coreutils-8.27]
1209 ** New features
1211   timeout now supports the --verbose option to diagnose forced termination.
1213 ** Improvements
1215   dd now supports iflag=direct with arbitrary sized files on all file systems.
1217   tail --bytes=NUM will efficiently seek to the end of block devices,
1218   rather than reading from the start.
1220   Utilities which do not support long options (other than the default --help
1221   and --version), e.g. cksum and sleep, now use more consistent error diagnostic
1222   for unknown long options.
1224 ** Build-related
1226   Default man pages are now distributed which are used if perl is
1227   not available on the build system, or when cross compiling.
1230 * Noteworthy changes in release 8.28 (2017-09-01) [stable]
1232 ** Bug fixes
1234   cp and mv now merely warn about any failure to preserve symlink ownership.
1235   Before, cp (without -p) would exit with a failure status, and a cross-device
1236   mv would leave such symlinks behind in the source file system.
1237   [the bug dates back to the initial implementation]
1239   When creating numbered backups, cp, install, ln, and mv now avoid
1240   races that could lose backup data in unlikely circumstances.  Since
1241   the fix relies on the renameat2 system call of Linux kernel 3.15 and
1242   later, the races are still present on other platforms.
1243   [the bug dates back to the initial implementation]
1245   cp, install, ln, and mv no longer lose data when asked to copy a
1246   backup file to its original via a differently-spelled file name.
1247   E.g., 'rm -f a a~; : > a; echo data > a~; cp --backup=simple a~ ./a'
1248   now fails instead of losing the data.
1249   [the bug dates back to the initial implementation]
1251   cp, install, ln, and mv now ignore nonsensical backup suffixes.
1252   For example, --suffix='/' and --suffix='' are now no-ops.
1253   [the bug dates back to the initial implementation]
1255   date and touch no longer overwrite the heap with large
1256   user specified TZ values (CVE-2017-7476).
1257   [bug introduced in coreutils-8.27]
1259   dd status=progress now just counts seconds; e.g., it outputs "6 s"
1260   consistently rather than sometimes outputting "6.00001 s".
1261   [bug introduced in coreutils-8.24]
1263   df no longer interacts with excluded file system types, so for example
1264   specifying -x nfs no longer hangs with problematic nfs mounts.
1265   [bug introduced in coreutils-8.21]
1267   df no longer interacts with dummy file system types, so for example
1268   no longer hangs with problematic nfs mounted via system.automount(5).
1269   [bug introduced in coreutils-8.21]
1271   `groups inva:lid root` no longer exits immediately upon failure.
1272   Now, it prints a diagnostic or a line to stdout for each argument.
1273   [bug introduced in the bourne-shell-to-C rewrite for coreutils-6.11]
1275   kill now converts from number to signal name correctly on AIX.
1276   Previously it would have always returned the 'EXIT' name.
1277   [bug introduced in fileutils-4.1.9]
1279   ls now quotes symlink targets consistently.  Previously it may not
1280   have quoted the target name if the link name itself didn't need quoting.
1281   [bug introduced in coreutils-8.26]
1283   split no longer exits when invocations of a --filter return EPIPE.
1284   [bug introduced in coreutils-8.26]
1286   md5sum --check no longer incorrectly enables BSD reversed format mode when
1287   ignoring some non checksum lines.  This also affects sha*sum and b2sum.
1288   [bug introduced in coreutils-8.14]
1290   tail -F 'dir/file' is now monitored even when 'dir' is replaced.
1291   [bug introduced with inotify support added in coreutils-7.5]
1293   tail -f with --pid=PID now processes all inotify events.
1294   Previously events may have been ignored completely upon PID death,
1295   or ignored until future events on the monitored files.
1296   [bug introduced with inotify support added in coreutils-7.5]
1298   tail -f /dev/tty is now supported by not using inotify when any
1299   non regular files are specified, as inotify is ineffective with these.
1300   [bug introduced with inotify support added in coreutils-7.5]
1302   uptime no longer outputs the AM/PM component of the current time,
1303   as that's inconsistent with the 24 hour time format used.
1304   [bug introduced in coreutils-7.0]
1306   expr now returns number of characters matched (instead of incorrect
1307   number of bytes matched) with 'match'/':' operators on multibyte strings.
1309 ** New features
1311   expand and unexpand now support specifying an offset for tab stops
1312   by prefixing the last specified number like --tabs=1,+8 which is
1313   useful for visualizing diff output for example.
1315   ls supports a new --hyperlink[=when] option to output file://
1316   format links to files, supported by some terminals.
1318   split supports a new --hex-suffixes[=from] option to create files with
1319   lower case hexadecimal suffixes, similar to the --numeric-suffixes option.
1321   env now has a --chdir (-C) option to change the working directory before
1322   executing the subsidiary program.
1324   expr supports multibyte strings for all string operations.
1326 ** Changes in behavior
1328   tail -f now exits immediately if the output is piped and the reader of
1329   the pipe terminates.  That allows `tail -f file | grep -q foo` to return
1330   responsively, but does make `tail -f file | :` exit immediately without
1331   waiting for data.  Instead one should now `tail -f file | grep -q .`
1333 ** Improvements
1335   mv --verbose now distinguishes rename and copy operations.
1337   stat -f -c %l, used to output the max file name length on a file system,
1338   is now supported on FreeBSD and OpenBSD.
1340   tail -f no longer erroneously warns about being ineffective
1341   when following a single tty, as the simple blocking loop used
1342   is effective in this case.
1345 * Noteworthy changes in release 8.27 (2017-03-08) [stable]
1347 ** Bug fixes
1349   cp --parents will now set an SELinux context for created directories,
1350   as appropriate for the -a, --preserve=context, or -Z options.
1351   [bug present since SELinux support added in coreutils-6.10]
1353   date again converts from a specified time zone.  Previously output was
1354   not converted to the local time zone, and remained in the specified one.
1355   [bug introduced in coreutils-8.26]
1357   Commands like 'cp --no-dereference -l A B' are no longer quiet no-ops
1358   when A is a regular file and B is a symbolic link that points to A.
1359   [bug introduced in fileutils-4.0]
1361   factor no longer goes into an infinite loop for certain numbers like
1362   158909489063877810457 and 222087527029934481871.
1363   [bug introduced in coreutils-8.20]
1365   tail no longer prints redundant file headers with interleaved inotify events,
1366   which could be triggered especially when tail was suspended and resumed.
1367   [bug introduced with inotify support added in coreutils-7.5]
1369   timeout no longer has a race that may terminate the wrong process.
1370   The race is unlikely, as timeout(1) needs to receive a signal right
1371   after the command being monitored finishes.  Also the system needs
1372   to have reallocated that command's pid in that short time window.
1373   [bug introduced when timeout was added in coreutils-7.0]
1375   wc --bytes --files0-from now correctly reports byte counts.
1376   Previously it may have returned values that were too large,
1377   depending on the size of the first file processed.
1378   [bug introduced in coreutils-8.24]
1380 ** Improvements
1382   The new 'date' option --rfc-email is now the long form for -R.
1383   The new option spelling is intended to avoid the need to track the
1384   Internet RFC number for email dates (currently RFC 5322).  The old
1385   option spellings --rfc-2822 and --rfc-822 still work.
1387   date now outputs "-00" for a numeric time zone if the time is UTC
1388   and the time zone abbreviation begins with "-", indicating that the
1389   time zone is indeterminate.
1391   nproc now honors the OMP_THREAD_LIMIT environment variable to
1392   set the maximum returned value.  OMP_NUM_THREADS continues to
1393   set the minimum returned value, but is updated to support the
1394   nested level syntax allowed in this variable.
1396   stat and tail now know about the "rdt" file system, which is an interface
1397   to Resource Director Technology.  stat -f --format=%T now reports the
1398   file system type, and tail -f uses inotify.
1400   stty now validates arguments before interacting with the device,
1401   ensuring there are no side effects to specifying an invalid option.
1403   If the file B already exists, commands like 'ln -f A B' and
1404   'cp -fl A B' no longer remove B before creating the new link.
1405   That is, there is no longer a brief moment when B does not exist.
1407 ** New features
1409   expand and unexpand now support specifying a tab size to use
1410   after explicitly specified tab stops, by prefixing the last
1411   specified number like --tabs=2,4,/8.
1414 * Noteworthy changes in release 8.26 (2016-11-30) [stable]
1416 ** Bug fixes
1418   cp, mv, and install no longer run into undefined behavior when
1419   handling ACLs on Cygwin and Solaris platforms. [bug introduced in
1420   coreutils-8.24]
1422   cp --parents --no-preserve=mode, no longer copies permissions from source
1423   directories, instead using default permissions for created directories.
1424   [bug introduced in coreutils-5.93]
1426   chcon, chgrp, chmod, chown, du, and rm, or specifically utilities
1427   using the FTS interface, now diagnose failures returned by readdir().
1428   [this bug was inherent in the use of fts: thus, for rm the bug was
1429   introduced in coreutils-8.0.  du, chmod, chgrp and chown started using
1430   fts in 6.0.  chcon was added in coreutils-6.9.91 with fts support.  ]
1432   date, du, ls, and pr no longer mishandle time zone abbreviations on
1433   System V style platforms where this information is available only
1434   in the global variable 'tzname'. [bug introduced in coreutils-8.24]
1436   factor again outputs immediately when numbers are input interactively.
1437   [bug introduced in coreutils-8.24]
1439   head no longer tries to process non-seekable input as seekable,
1440   which resulted in failures on FreeBSD 11 at least.
1441   [bug introduced in coreutils-8.24]
1443   install -DZ and mkdir -pZ now set default SELinux context correctly even if
1444   two or more directories nested in each other are created and each of them
1445   defaults to a different SELinux context.
1447   ls --time-style no longer mishandles '%%b' in formats.
1448   [bug introduced in coreutils-7.2]
1450   md5sum --check --ignore-missing no longer treats files with checksums
1451   starting with "00" as missing.  This also affects sha*sum.
1452   [bug introduced with the --ignore-missing feature in coreutils-8.25]
1454   nl now resets numbering for each page section rather than just for each page.
1455   [This bug was present in "the beginning".]
1457   pr now handles specified separator strings containing tabs correctly.
1458   Previously it would have output random data from memory.
1459   [This bug was detected with ASAN and present in "the beginning".]
1461   sort -h -k now works even in locales that use blank as thousands separator.
1463   stty --help no longer outputs extraneous gettext header lines
1464   for translated languages. [bug introduced in coreutils-8.24]
1466   stty "sane" again sets "susp" to ^z on Solaris, and leaves "swtch" undefined.
1467   [This bug previously fixed only on some older Solaris systems]
1469   seq now immediately exits upon write errors.
1470   [This bug was present in "the beginning".]
1472   tac no longer crashes when there are issues reading from non-seekable inputs.
1473   [bug introduced in coreutils-8.15]
1475   tail -F now continues to process initially untailable files that are replaced
1476   by a tailable file.  This was handled correctly when inotify was available,
1477   and is now handled correctly in all cases.
1478   [bug introduced in fileutils-4.0h]
1480   tail -f - 'untailable file' will now terminate when there is no more data
1481   to read from stdin.  Previously it behaved as if --retry was specified.
1482   [This bug was present in "the beginning".]
1484   tail -f 'remote file' will now avoid outputting repeated data on network
1485   file systems that misreport file sizes through stale metadata.
1486   [This bug was present in "the beginning" but exacerbated in coreutils-8.24]
1488   tail -f --retry 'missing file' will now process truncations of that file.
1489   Previously truncation was ignored thus not outputting new data in the file.
1490   [bug introduced in coreutils-5.3.0]
1492   tail -f will no longer continually try to open inaccessible files,
1493   only doing so if --retry is specified.
1494   [This bug was present in "the beginning".]
1496   yes now handles short writes, rather than assuming all writes complete.
1497   [bug introduced in coreutils-8.24]
1499 ** Changes in behavior
1501   rm no longer accepts shortened variants of the --no-preserve-root option.
1503   seq no longer accepts 0 value as increment, and now also rejects NaN
1504   values for any argument.
1506   stat now outputs nanosecond information for timestamps even if
1507   they are out of localtime range.
1509   sort, tail, and uniq now support traditional usage like 'sort +2'
1510   and 'tail +10' on systems conforming to POSIX 1003.1-2008 and later.
1511   The 2008 edition of POSIX dropped the requirement that arguments
1512   like '+2' must be treated as file names.
1514 ** Improvements
1516   dd now warns about counts specified with a 0x "prefix", since dd will
1517   interpret those as a zero multiplier rather than a hex constant.
1518   The warning suggests to use 00x if a zero multiplier is really intended.
1520   df now filters the system mount list more efficiently, with 20000
1521   mount entries now being processed in about 1.1s compared to 1.7s.
1523   du, shuf, sort, and uniq no longer fail to process a specified file
1524   when their stdin is closed, which would have happened with glibc >= 2.14.
1526   install -Z now also sets the default SELinux context for created directories.
1528   ls is now fully responsive to signals until the first escape sequence is
1529   written to a terminal.
1531   ls now aligns quoted items with non quoted items, which is easier to read,
1532   and also better indicates that the quote is not part of the actual name.
1534   stat and tail now know about these file systems:
1535     "balloon-kvm-fs"    KVM dynamic RAM allocation support,
1536     "cgroup2"           Linux Control Groups V2 support,
1537     "daxfs"             Optical media file system,
1538     "m1fs"              A Plexistor file system,
1539     "prl_fs"            A parallels file system,
1540     "smb2"              Samba for SMB protocol V2,
1541     "wslfs"             Windows Subsystem for Linux,
1542     "zsmalloc"          Linux compressed swap support,
1543   stat -f --format=%T now reports the file system type, and
1544   tail -f uses polling for "prl_fs" and "smb2", and inotify for others.
1546   stat --format=%N for quoting file names now honors the
1547   same QUOTING_STYLE environment variable values as ls.
1549 ** New programs
1551   b2sum is added to support the BLAKE2 digest algorithm with
1552   a similar interface to the existing md5sum and sha1sum, etc. commands.
1554 ** New Features
1556   comm now accepts the --total option to output a summary at the end.
1558   date now accepts the --debug option, to annotate the parsed date string,
1559   display timezone information, and warn about potential misuse.
1561   date now accepts the %q format to output the quarter of the year.
1564 * Noteworthy changes in release 8.25 (2016-01-20) [stable]
1566 ** Bug fixes
1568   cp now correctly copies files with a hole at the end of the file,
1569   and extents allocated beyond the apparent size of the file.
1570   That combination resulted in the trailing hole not being reproduced.
1571   [bug introduced in coreutils-8.10]
1573   cut --fields no longer outputs extraneous characters on some uClibc configs.
1574   [bug introduced in coreutils-6.11]
1576   install -D again copies relative file names when absolute file names
1577   are also specified along with an absolute destination directory name.
1578   [bug introduced in coreutils-6.2]
1580   ls no longer prematurely wraps lines when printing short file names.
1581   [bug introduced in coreutils-5.1.0]
1583   mv no longer causes data loss due to removing a source directory specified
1584   multiple times, when that directory is also specified as the destination.
1585   [bug introduced in coreutils-8.24]
1587   shred again uses defined patterns for all iteration counts.
1588   [bug introduced in coreutils-5.93]
1590   sort --debug -b now correctly marks the matching extents for keys
1591   that specify an offset for the first field.
1592   [bug introduced with the --debug feature in coreutils-8.6]
1594   tail -F now works with initially non existent files on a remote file system.
1595   [bug introduced in coreutils-7.5]
1597 ** New programs
1599   base32 is added to complement the existing base64 command,
1600   and encodes and decodes printable text as per RFC 4648.
1602 ** New features
1604   comm,cut,head,numfmt,paste,tail now have the -z,--zero-terminated option, and
1605   tac --separator accepts an empty argument, to work with NUL delimited items.
1607   dd now summarizes sizes in --human-readable format too, not just --si.
1608   E.g., "3441325000 bytes (3.4 GB, 3.2 GiB) copied".  It omits the summaries
1609   if they would not provide useful information, e.g., "3 bytes copied".
1610   Its status=progress output now uses the same format as ordinary status,
1611   perhaps with trailing spaces to erase previous progress output.
1613   md5sum now supports the --ignore-missing option to allow
1614   verifying a subset of files given a larger list of checksums.
1615   This also affects sha1sum, sha224sum, sha256sum, sha384sum and sha512sum.
1617   printf now supports the '%q' format to print arguments in a form that
1618   is reusable by most shells, with non-printable characters escaped
1619   with the POSIX proposed $'...' syntax.
1621   stty now supports the "[-]drain" setting to control whether to wait
1622   for transmission of pending output before application of settings.
1624 ** Changes in behavior
1626   base64 no longer supports hex or oct --wrap parameters,
1627   thus better supporting decimals with leading zeros.
1629   date --iso-8601 now uses +00:00 timezone format rather than +0000.
1630   The standard states to use this "extended" format throughout a timestamp.
1632   df now prefers sources towards the root of a device when
1633   eliding duplicate bind mounted entries.
1635   ls now quotes file names unambiguously and appropriate for use in a shell,
1636   when outputting to a terminal.
1638   join, sort, uniq with --zero-terminated, now treat '\n' as a field delimiter.
1640 ** Improvements
1642   All utilities now quote user supplied arguments in error strings,
1643   which avoids confusing error messages in the presence of '\r' chars etc.
1645   Utilities that traverse directories, like chmod, cp, and rm etc., will operate
1646   more efficiently on XFS through the use of "leaf optimization".
1648   md5sum now ensures a single line per file for status on standard output,
1649   by using a '\' at the start of the line, and replacing any newlines with '\n'.
1650   This also affects sha1sum, sha224sum, sha256sum, sha384sum and sha512sum.
1652   dircolors now supports globbing of TERM entries in its database.
1653   For example "TERM *256color*" is now supported.
1655   du no longer stats all mount points at startup, only doing so
1656   upon detection of a directory cycle.
1657   [issue introduced in coreutils-8.20]
1659   ls -w0 is now interpreted as no limit on the length of the outputted line.
1661   stat -f --format=%T now reports the file system type for new Linux
1662   pseudo file systems "bpf_fs", "btrfs_test", "nsfs", "overlayfs"
1663   and "tracefs", and remote file system "acfs".
1665   wc now ensures a single line per file for counts on standard output,
1666   by quoting names containing '\n' characters; appropriate for use in a shell.
1669 * Noteworthy changes in release 8.24 (2015-07-03) [stable]
1671 ** Bug fixes
1673   dd supports more robust SIGINFO/SIGUSR1 handling for outputting statistics.
1674   Previously those signals may have inadvertently terminated the process.
1676   df --local no longer hangs with inaccessible remote mounts.
1677   [bug introduced in coreutils-8.21]
1679   du now silently ignores all directory cycles due to bind mounts.
1680   Previously it would issue a warning and exit with a failure status.
1681   [bug introduced in coreutils-8.1 and partially fixed in coreutils-8.23]
1683   chroot again calls chroot(DIR) and chdir("/"), even if DIR is "/".
1684   This handles separate bind mounted "/" trees, and environments
1685   depending on the implicit chdir("/").
1686   [bugs introduced in coreutils-8.23]
1688   cp no longer issues an incorrect warning about directory hardlinks when a
1689   source directory is specified multiple times.  Now, consistent with other
1690   file types, a warning is issued for source directories with duplicate names,
1691   or with -H the directory is copied again using the symlink name.
1693   factor avoids writing partial lines, thus supporting parallel operation.
1694   [the bug dates back to the initial implementation]
1696   head, od, split, tac, tail, and wc no longer mishandle input from files in
1697   /proc and /sys file systems that report somewhat-incorrect file sizes.
1699   mkdir --parents -Z now correctly sets the context for the last component,
1700   even if the parent directory exists and has a different default context.
1701   [bug introduced with the -Z restorecon functionality in coreutils-8.22]
1703   numfmt no longer outputs incorrect overflowed values seen with certain
1704   large numbers, or with numbers with increased precision.
1705   [bug introduced when numfmt was added in coreutils-8.21]
1707   numfmt now handles leading zeros correctly, not counting them when
1708   settings processing limits, and making them optional with floating point.
1709   [bug introduced when numfmt was added in coreutils-8.21]
1711   paste no longer truncates output for large input files.  This would happen
1712   for example with files larger than 4GiB on 32 bit systems with a '\n'
1713   character at the 4GiB position.
1714   [the bug dates back to the initial implementation]
1716   rm indicates the correct number of arguments in its confirmation prompt,
1717   on all platforms.  [bug introduced in coreutils-8.22]
1719   shuf -i with a single redundant operand, would crash instead of issuing
1720   a diagnostic.  [bug introduced in coreutils-8.22]
1722   tail releases inotify resources when unused.  Previously it could exhaust
1723   resources with many files, or with -F if files were replaced many times.
1724   [bug introduced in coreutils-7.5]
1726   tail -f again follows changes to a file after it's renamed.
1727   [bug introduced in coreutils-7.5]
1729   tail --follow no longer misses changes to files if those files were
1730   replaced before inotify watches were created.
1731   [bug introduced in coreutils-7.5]
1733   tail --follow consistently outputs all data for a truncated file.
1734   [bug introduced in the beginning]
1736   tail --follow=name correctly outputs headers for multiple files
1737   when those files are being created or renamed.
1738   [bug introduced in coreutils-7.5]
1740 ** New features
1742   chroot accepts the new --skip-chdir option to not change the working directory
1743   to "/" after changing into the chroot(2) jail, thus retaining the current wor-
1744   king directory.  The new option is only permitted if the new root directory is
1745   the old "/", and therefore is useful with the --group and --userspec options.
1747   dd accepts a new status=progress level to print data transfer statistics
1748   on stderr approximately every second.
1750   numfmt can now process multiple fields with field range specifications similar
1751   to cut, and supports setting the output precision with the --format option.
1753   split accepts a new --separator option to select a record separator character
1754   other than the default newline character.
1756   stty allows setting the "extproc" option where supported, which is
1757   a useful setting with high latency links.
1759   sync no longer ignores arguments, and syncs each specified file, or with the
1760   --file-system option, the file systems associated with each specified file.
1762   tee accepts a new --output-error option to control operation with pipes
1763   and output errors in general.
1765 ** Changes in behavior
1767   df no longer suppresses separate exports of the same remote device, as
1768   these are generally explicitly mounted.  The --total option does still
1769   suppress duplicate remote file systems.
1770   [suppression was introduced in coreutils-8.21]
1772   mv no longer supports moving a file to a hardlink, instead issuing an error.
1773   The implementation was susceptible to races in the presence of multiple mv
1774   instances, which could result in both hardlinks being deleted.  Also on case
1775   insensitive file systems like HFS, mv would just remove a hardlinked 'file'
1776   if called like `mv file File`.  The feature was added in coreutils-5.0.1.
1778   numfmt --from-unit and --to-unit options now interpret suffixes as SI units,
1779   and IEC (power of 2) units are now specified by appending 'i'.
1781   tee will exit early if there are no more writable outputs.
1783   tee does not treat the file operand '-' as meaning standard output any longer,
1784   for better conformance to POSIX.  This feature was added in coreutils-5.3.0.
1786   timeout --foreground no longer sends SIGCONT to the monitored process,
1787   which was seen to cause intermittent issues with GDB for example.
1789 ** Improvements
1791   cp,install,mv will convert smaller runs of NULs in the input to holes,
1792   and cp --sparse=always avoids speculative preallocation on XFS for example.
1794   cp will read sparse files more efficiently when the destination is a
1795   non regular file.  For example when copying a disk image to a device node.
1797   mv will try a reflink before falling back to a standard copy, which is
1798   more efficient when moving files across BTRFS subvolume boundaries.
1800   stat and tail now know about IBRIX.  stat -f --format=%T now reports the file
1801   system type, and tail -f uses polling for files on IBRIX file systems.
1803   wc -l processes short lines much more efficiently.
1805   References from --help and the man pages of utilities have been corrected
1806   in various cases, and more direct links to the corresponding online
1807   documentation are provided.
1810 * Noteworthy changes in release 8.23 (2014-07-18) [stable]
1812 ** Bug fixes
1814   chmod -Rc no longer issues erroneous warnings for files with special bits set.
1815   [bug introduced in coreutils-6.0]
1817   cp -a, mv, and install --preserve-context, once again set the correct SELinux
1818   context for existing directories in the destination.  Previously they set
1819   the context of an existing directory to that of its last copied descendant.
1820   [bug introduced in coreutils-8.22]
1822   cp -a, mv, and install --preserve-context, no longer seg fault when running
1823   with SELinux enabled, when copying from file systems that return an error
1824   when reading the SELinux context for a file.
1825   [bug introduced in coreutils-8.22]
1827   cp -a and mv now preserve xattrs of symlinks copied across file systems.
1828   [bug introduced with extended attribute preservation feature in coreutils-7.1]
1830   date could crash or go into an infinite loop when parsing a malformed TZ="".
1831   [bug introduced with the --date='TZ="" ..' parsing feature in coreutils-5.3.0]
1833   dd's ASCII and EBCDIC conversions were incompatible with common practice and
1834   with POSIX, and have been corrected as follows.  First, conv=ascii now
1835   implies conv=unblock, and conv=ebcdic and conv=ibm now imply conv=block.
1836   Second, the translation tables for dd conv=ascii and conv=ebcdic have been
1837   corrected as shown in the following table, where A is the ASCII value, W is
1838   the old, wrong EBCDIC value, and E is the new, corrected EBCDIC value; all
1839   values are in octal.
1841       A   W   E
1842      041 117 132
1843      133 112 255
1844      135 132 275
1845      136 137 232
1846      174 152 117
1847      176 241 137
1848      313 232 152
1849      325 255 112
1850      345 275 241
1852   [These dd bugs were present in "the beginning".]
1854   df has more fixes related to the newer dynamic representation of file systems:
1855   Duplicates are elided for virtual file systems like tmpfs.
1856   Details for the correct device are output for points mounted multiple times.
1857   Placeholder values are output for inaccessible file systems, rather than
1858   than error messages or values for the wrong file system.
1859   [These bugs were present in "the beginning".]
1861   df now outputs all appropriate entries in the presence of bind mounts.
1862   On some systems, entries would have been incorrectly elided due to
1863   them being considered "dummy" mounts.
1864   [bug introduced in coreutils-8.22]
1866   du now silently ignores directory cycles introduced with bind mounts.
1867   Previously it would issue a warning and exit with a failure status.
1868   [bug introduced in coreutils-8.1]
1870   head --bytes=-N and --lines=-N now handles devices more
1871   consistently, not ignoring data from virtual devices like /dev/zero,
1872   or on BSD systems data from tty devices.
1873   [bug introduced in coreutils-5.0.1]
1875   head --bytes=-N - no longer fails with a bogus diagnostic when stdin's
1876   seek pointer is not at the beginning.
1877   [bug introduced with the --bytes=-N feature in coreutils-5.0.1]
1879   head --lines=-0, when the input does not contain a trailing '\n',
1880   now copies all input to stdout.  Previously nothing was output in this case.
1881   [bug introduced with the --lines=-N feature in coreutils-5.0.1]
1883   id, when invoked with no user name argument, now prints the correct group ID.
1884   Previously, in the default output format, it would print the default group ID
1885   in the password database, which may be neither real nor effective.  For e.g.,
1886   when run set-GID, or when the database changes outside the current session.
1887   [bug introduced in coreutils-8.1]
1889   ln -sf now replaces symbolic links whose targets can't exist.  Previously
1890   it would display an error, requiring --no-dereference to avoid the issue.
1891   [bug introduced in coreutils-5.3.0]
1893   ln -sr '' F no longer segfaults.  Now works as expected.
1894   [bug introduced with the --relative feature in coreutils-8.16]
1896   numfmt now handles blanks correctly in all unibyte locales.  Previously
1897   in locales where character 0xA0 is a blank, numfmt would mishandle it.
1898   [bug introduced when numfmt was added in coreutils-8.21]
1900   ptx --format long option parsing no longer falls through into the --help case.
1901   [bug introduced in TEXTUTILS-1_22i]
1903   ptx now consistently trims whitespace when processing multiple files.
1904   [This bug was present in "the beginning".]
1906   seq again generates correct output with start or end values = -0.
1907   [bug introduced in coreutils-8.20.]
1909   shuf --repeat no longer dumps core if the input is empty.
1910   [bug introduced with the --repeat feature in coreutils-8.22]
1912   sort when using multiple threads now avoids undefined behavior with mutex
1913   destruction, which could cause deadlocks on some implementations.
1914   [bug introduced in coreutils-8.6]
1916   tail -f now uses polling mode for VXFS to cater for its clustered mode.
1917   [bug introduced with inotify support added in coreutils-7.5]
1919 ** New features
1921   od accepts a new option: --endian=TYPE to handle inputs with different byte
1922   orders, or to provide consistent output on systems with disparate endianness.
1924   configure accepts the new option --enable-single-binary to build all the
1925   selected programs in a single binary called "coreutils".  The selected
1926   programs can still be called directly using symlinks to "coreutils" or
1927   shebangs with the option --coreutils-prog= passed to this program.  The
1928   install behavior is determined by the option --enable-single-binary=symlinks
1929   or --enable-single-binary=shebangs (the default).  With the symlinks option,
1930   you can't make a second symlink to any program because that will change the
1931   name of the called program, which is used by coreutils to determine the
1932   desired program.  The shebangs option doesn't suffer from this problem, but
1933   the /proc/$pid/cmdline file might not be updated on all the platforms.  The
1934   functionality of each program is not affected but this single binary will
1935   depend on all the required dynamic libraries even to run simple programs.
1936   If you desire to build some tools outside the single binary file, you can
1937   pass the option --enable-single-binary-exceptions=PROG_LIST with the comma
1938   separated list of programs you want to build separately.  This flag
1939   considerably reduces the overall size of the installed binaries which makes
1940   it suitable for embedded system.
1942 ** Changes in behavior
1944   chroot with an argument of "/" no longer implicitly changes the current
1945   directory to "/", allowing changing only user credentials for a command.
1947   chroot --userspec will now unset supplemental groups associated with root,
1948   and instead use the supplemental groups of the specified user.
1950   cut -d$'\n' again outputs lines identified in the --fields list, having
1951   not done so in v8.21 and v8.22.  Note using this non portable functionality
1952   will result in the delayed output of lines.
1954   ls with none of LS_COLORS or COLORTERM environment variables set,
1955   will now honor an empty or unknown TERM environment variable,
1956   and not output colors even with --colors=always.
1958 ** Improvements
1960   chroot has better --userspec and --group look-ups, with numeric IDs never
1961   causing name look-up errors.  Also look-ups are first done outside the chroot,
1962   in case the look-up within the chroot fails due to library conflicts etc.
1964   install now allows the combination of the -D and -t options.
1966   numfmt supports zero padding of numbers using the standard printf
1967   syntax of a leading zero, for example --format="%010f".
1968   Also throughput was improved by up to 800% by avoiding redundant processing.
1970   shred now supports multiple passes on GNU/Linux tape devices by rewinding
1971   the tape before each pass, avoids redundant writes to empty files,
1972   uses direct I/O for all passes where possible, and attempts to clear
1973   inode storage used for small files on some file systems.
1975   split avoids unnecessary input buffering, immediately writing input to output
1976   which is significant with --filter or when writing to fifos or stdout etc.
1978   stat and tail work better with HFS+, HFSX, LogFS and ConfigFS.  stat -f
1979   --format=%T now reports the file system type, and tail -f now uses inotify,
1980   rather than the default of issuing a warning and reverting to polling.
1983 * Noteworthy changes in release 8.22 (2013-12-13) [stable]
1985 ** Bug fixes
1987   df now processes the mount list correctly in the presence of unstattable
1988   mount points.  Previously it may have failed to output some mount points.
1989   [bug introduced in coreutils-8.21]
1991   df now processes symbolic links and relative paths to special files containing
1992   a mounted file system correctly.  Previously df displayed the statistics about
1993   the file system the file is stored on rather than the one inside.
1994   [This bug was present in "the beginning".]
1996   df now processes disk device nodes correctly in the presence of bind mounts.
1997   Now df shows the base mounted file system rather than the last one mounted.
1998   [This bug was present in "the beginning".]
2000   install now removes the target file if the strip program failed for any
2001   reason.  Before, that file was left behind, sometimes even with wrong
2002   permissions.
2003   [This bug was present in "the beginning".]
2005   ln --relative now updates existing symlinks correctly.  Previously it based
2006   the relative link on the dereferenced path of an existing link.
2007   [This bug was introduced when --relative was added in coreutils-8.16.]
2009   ls --recursive will no longer exit with "serious" exit code (2), if there
2010   is an error reading a directory not specified on the command line.
2011   [Bug introduced in coreutils-5.3.0]
2013   mkdir, mkfifo, and mknod now work better when creating a file in a directory
2014   with a default ACL whose umask disagrees with the process's umask, on a
2015   system such as GNU/Linux where directory ACL umasks override process umasks.
2016   [bug introduced in coreutils-6.0]
2018   mv will now replace empty directories in the destination with directories
2019   from the source, when copying across file systems.
2020   [This bug was present in "the beginning".]
2022   od -wN with N larger than 64K on a system with 32-bit size_t would
2023   print approximately 2*N bytes of extraneous padding.
2024   [Bug introduced in coreutils-7.0]
2026   rm -I now prompts for confirmation before removing a write protected file.
2027   [Bug introduced in coreutils-6.8]
2029   shred once again uses direct I/O on systems requiring aligned buffers.
2030   Also direct I/O failures for odd sized writes at end of file are now handled.
2031   [The "last write" bug was introduced in coreutils-5.3.0 but masked
2032    by the alignment bug introduced in coreutils-6.0]
2034   tail --retry -f now waits for the files specified to appear.  Before, tail
2035   would immediately exit when such a file is initially inaccessible.
2036   [This bug was introduced when inotify support was added in coreutils-7.5]
2038   tail -F has improved handling of symlinks.  Previously tail didn't respond
2039   to the symlink target (re)appearing after being (re)created.
2040   [This bug was introduced when inotify support was added in coreutils-7.5]
2042 ** New features
2044   cp, install, mkdir, mknod, mkfifo and mv now support "restorecon"
2045   functionality through the -Z option, to set the SELinux context
2046   appropriate for the new item location in the file system.
2048   csplit accepts a new option: --suppressed-matched, to elide the lines
2049   used to identify the split points.
2051   df --output now accepts a 'file' field, to propagate a specified
2052   command line argument through to the output.
2054   du accepts a new option: --inodes to show the number of inodes instead
2055   of the blocks used.
2057   id accepts a new option: --zero (-z) to delimit the output entries by
2058   a NUL instead of a white space character.
2060   id and ls with -Z report the SMACK security context where available.
2061   mkdir, mkfifo and mknod with --context set the SMACK context where available.
2063   id can now lookup by user ID, in addition to the existing name lookup.
2065   join accepts a new option: --zero-terminated (-z). As with the sort,uniq
2066   option of the same name, this makes join consume and produce NUL-terminated
2067   lines rather than newline-terminated lines.
2069   uniq accepts a new option: --group to print all items, while separating
2070   unique groups with empty lines.
2072   shred accepts new parameters to the --remove option to give greater
2073   control over that operation, which can greatly reduce sync overhead.
2075   shuf accepts a new option: --repeat (-r), which can repeat items in
2076   the output.
2078 ** Changes in behavior
2080   cp --link now dereferences a symbolic link as source before creating the
2081   hard link in the destination unless the -P,--no-deref option is specified.
2082   Previously, it would create a hard link of the symbolic link, even when
2083   the dereferencing options -L or -H were specified.
2085   cp, install, mkdir, mknod and mkfifo no longer accept an argument to the
2086   short -Z option.  The --context equivalent still takes an optional argument.
2088   dd status=none now suppresses all non fatal diagnostic messages,
2089   not just the transfer counts.
2091   df no longer accepts the long-obsolescent --megabytes option.
2093   stdbuf now requires at least one buffering mode option to be specified,
2094   as per the documented interface.
2096 ** Improvements
2098   base64 encoding throughput for bulk data is increased by about 60%.
2100   md5sum can use libcrypto hash routines where allowed to potentially
2101   get better performance through using more system specific logic.
2102   sha1sum for example has improved throughput by 40% on an i3-2310M.
2103   This also affects sha1sum, sha224sum, sha256sum, sha384sum and sha512sum.
2105   stat and tail work better with EFIVARFS, EXOFS, F2FS, HOSTFS, SMACKFS, SNFS
2106   and UBIFS.  stat -f --format=%T now reports the file system type, and tail -f
2107   now uses inotify for files on all those except SNFS, rather than the default
2108   (for unknown file system types) of issuing a warning and reverting to polling.
2110   shuf outputs subsets of large inputs much more efficiently.
2111   Reservoir sampling is used to limit memory usage based on the number of
2112   outputs, rather than the number of inputs.
2114   shred increases the default write block size from 12KiB to 64KiB
2115   to align with other utilities and reduce the system call overhead.
2117   split --line-bytes=SIZE, now only allocates memory as needed rather
2118   than allocating SIZE bytes at program start.
2120   stty now supports configuring "stick" (mark/space) parity where available.
2122 ** Build-related
2124   factor now builds on aarch64 based systems [bug introduced in coreutils-8.20]
2127 * Noteworthy changes in release 8.21 (2013-02-14) [stable]
2129 ** New programs
2131   numfmt: reformat numbers
2133 ** New features
2135   df now accepts the --output[=FIELD_LIST] option to define the list of columns
2136   to include in the output, or all available columns if the FIELD_LIST is
2137   omitted.  Note this enables df to output both block and inode fields together.
2139   du now accepts the --threshold=SIZE option to restrict the output to entries
2140   with such a minimum SIZE (or a maximum SIZE if it is negative).
2141   du recognizes -t SIZE as equivalent, for compatibility with FreeBSD.
2143   timeout now accepts the --preserve-status option to always propagate the exit
2144   status, useful for commands that can run for an indeterminate amount of time.
2146 ** Bug fixes
2148   cp --no-preserve=mode now no longer exits non-zero.
2149   [bug introduced in coreutils-8.20]
2151   cut with a range like "N-" no longer allocates N/8 bytes.  That buffer
2152   would never be used, and allocation failure could cause cut to fail.
2153   [bug introduced in coreutils-8.10]
2155   cut no longer accepts the invalid range 0-, which made it print empty lines.
2156   Instead, cut now fails and emits an appropriate diagnostic.
2157   [This bug was present in "the beginning".]
2159   cut now handles overlapping to-EOL ranges properly.  Before, it would
2160   interpret "-b2-,3-" like "-b3-".  Now it's treated like "-b2-".
2161   [This bug was present in "the beginning".]
2163   cut no longer prints extraneous delimiters when a to-EOL range subsumes
2164   another range.  Before, "echo 123|cut --output-delim=: -b2-,3" would print
2165   "2:3".  Now it prints "23".  [bug introduced in 5.3.0]
2167   cut -f no longer inspects input line N+1 before fully outputting line N,
2168   which avoids delayed output for intermittent input.
2169   [bug introduced in TEXTUTILS-1_8b]
2171   factor no longer loops infinitely on 32 bit powerpc or sparc systems.
2172   [bug introduced in coreutils-8.20]
2174   install -m M SOURCE DEST no longer has a race condition where DEST's
2175   permissions are temporarily derived from SOURCE instead of from M.
2177   pr -n no longer crashes when passed values >= 32.  Also, line numbers are
2178   consistently padded with spaces, rather than with zeros for certain widths.
2179   [bug introduced in TEXTUTILS-1_22i]
2181   seq -w ensures that for numbers input in scientific notation,
2182   the output numbers are properly aligned and of the correct width.
2183   [This bug was present in "the beginning".]
2185   seq -w ensures correct alignment when the step value includes a precision
2186   while the start value does not, and the number sequence narrows.
2187   [This bug was present in "the beginning".]
2189   seq -s no longer prints an erroneous newline after the first number, and
2190   outputs a newline after the last number rather than a trailing separator.
2191   Also seq no longer ignores a specified step value when the end value is 1.
2192   [bugs introduced in coreutils-8.20]
2194   timeout now ensures that blocking of ALRM signals is not inherited from
2195   its parent, which would cause timeouts to be ignored.
2196   [the bug dates back to the initial implementation]
2198 ** Changes in behavior
2200   df --total now prints '-' into the target column (mount point) of the
2201   summary line, accommodating the --output option where the target field
2202   can be in any column.  If there is no source column, then df prints
2203   'total' in the target column.
2205   df now properly outputs file system information with bind mounts present on
2206   the system by skipping duplicate entries (identified by the device number).
2207   Consequently, df also elides the early-boot pseudo file system type "rootfs".
2209   cut -d$'\n' no longer outputs lines identified in the --fields list,
2210   to align with other implementations and to avoid delayed output of lines.
2212   nl no longer supports the --page-increment option, which has been
2213   deprecated since coreutils-7.5.  Use --line-increment instead.
2215 ** Improvements
2217   readlink now supports multiple arguments, and a complementary
2218   -z, --zero option to delimit output items with the NUL character.
2220   stat and tail now know about CEPH.  stat -f --format=%T now reports the file
2221   system type, and tail -f uses polling for files on CEPH file systems.
2223   stty now supports configuring DTR/DSR hardware flow control where available.
2225 ** Build-related
2227   Perl is now more of a prerequisite.  It has long been required in order
2228   to run (not skip) a significant percentage of the tests.  Now, it is
2229   also required in order to generate proper man pages, via help2man.  The
2230   generated man/*.1 man pages are no longer distributed.  Building without
2231   perl, you would create stub man pages.  Thus, while perl is not an
2232   official prerequisite (build and "make check" will still succeed), any
2233   resulting man pages would be inferior.  In addition, this fixes a bug
2234   in distributed (not from clone) Makefile.in that could cause parallel
2235   build failure when building from modified sources, as is common practice
2236   for a patched distribution package.
2238   factor now builds on x86_64 with x32 ABI, 32 bit MIPS, and all HPPA systems,
2239   by avoiding incompatible asm.  [bug introduced in coreutils-8.20]
2241   A root-only test predicate would always fail.  Its job was to determine
2242   whether our dummy user, $NON_ROOT_USERNAME, was able to run binaries from
2243   the build directory.  As a result, all dependent tests were always skipped.
2244   Now, those tests may be run once again.  [bug introduced in coreutils-8.20]
2247 * Noteworthy changes in release 8.20 (2012-10-23) [stable]
2249 ** New features
2251   dd now accepts 'status=none' to suppress all informational output.
2253   md5sum now accepts the --tag option to print BSD-style output with GNU
2254   file name escaping.  This also affects sha1sum, sha224sum, sha256sum,
2255   sha384sum and sha512sum.
2257 ** Bug fixes
2259   cp could read from freed memory and could even make corrupt copies.
2260   This could happen with a very fragmented and sparse input file,
2261   on GNU/Linux file systems supporting fiemap extent scanning.
2262   This bug also affects mv when it resorts to copying, and install.
2263   [bug introduced in coreutils-8.11]
2265   cp --no-preserve=mode now no longer preserves the original file's
2266   permissions but correctly sets mode specified by 0666 & ~umask
2268   du no longer emits a "disk-corrupted"-style diagnostic when it detects
2269   a directory cycle that is due to a bind-mounted directory.  Instead,
2270   it detects this precise type of cycle, diagnoses it as such and
2271   eventually exits nonzero.
2273   factor (when using gmp) would mistakenly declare some composite numbers
2274   to be prime, e.g., 465658903, 2242724851, 6635692801 and many more.
2275   The fix makes factor somewhat slower (~25%) for ranges of consecutive
2276   numbers, and up to 8 times slower for some worst-case individual numbers.
2277   [bug introduced in coreutils-7.0, with GNU MP support]
2279   ls now correctly colors dangling symlinks when listing their containing
2280   directories, with orphaned symlink coloring disabled in LS_COLORS.
2281   [bug introduced in coreutils-8.14]
2283   rm -i -d now prompts the user then removes an empty directory, rather
2284   than ignoring the -d option and failing with an 'Is a directory' error.
2285   [bug introduced in coreutils-8.19, with the addition of --dir (-d)]
2287   rm -r S/ (where S is a symlink-to-directory) no longer gives the invalid
2288   "Too many levels of symbolic links" diagnostic.
2289   [bug introduced in coreutils-8.6]
2291   seq now handles arbitrarily long non-negative whole numbers when the
2292   increment is 1 and when no format-changing option is specified.
2293   Before, this would infloop:
2294     b=100000000000000000000; seq $b $b
2295   [the bug dates back to the initial implementation]
2297 ** Changes in behavior
2299   nproc now diagnoses with an error, non option command line parameters.
2301 ** Improvements
2303   factor's core has been rewritten for speed and increased range.
2304   It can now factor numbers up to 2^128, even without GMP support.
2305   Its speed is from a few times better (for small numbers) to over
2306   10,000 times better (just below 2^64).  The new code also runs a
2307   deterministic primality test for each prime factor, not just a
2308   probabilistic test.
2310   seq is now up to 70 times faster than it was in coreutils-8.19 and prior,
2311   but only with non-negative whole numbers, an increment of 1, and no
2312   format-changing options.
2314   stat and tail know about ZFS, VZFS and VMHGFS.  stat -f --format=%T now
2315   reports the file system type, and tail -f now uses inotify for files on
2316   ZFS and VZFS file systems, rather than the default (for unknown file
2317   system types) of issuing a warning and reverting to polling.  tail -f
2318   still uses polling for files on VMHGFS file systems.
2320 ** Build-related
2322   root-only tests now check for permissions of our dummy user,
2323   $NON_ROOT_USERNAME, before trying to run binaries from the build directory.
2324   Before, we would get hard-to-diagnose reports of failing root-only tests.
2325   Now, those tests are skipped with a useful diagnostic when the root tests
2326   are run without following the instructions in README.
2328   We now build most directories using non-recursive make rules.  I.e.,
2329   rather than running make in man/, lib/, src/, tests/, instead, the top
2330   level Makefile.am includes a $dir/local.mk that describes how to build
2331   the targets in the corresponding directory.  Two directories remain
2332   unconverted: po/, gnulib-tests/.  One nice side-effect is that the more
2333   accurate dependencies have eliminated a nagging occasional failure that
2334   was seen when running parallel "make syntax-check".
2337 * Noteworthy changes in release 8.19 (2012-08-20) [stable]
2339 ** Bug fixes
2341   df now fails when the list of mounted file systems (/etc/mtab) cannot
2342   be read, yet the file system type information is needed to process
2343   certain options like -a, -l, -t and -x.
2344   [This bug was present in "the beginning".]
2346   sort -u could fail to output one or more result lines.
2347   For example, this command would fail to print "1":
2348   (yes 7 | head -11; echo 1) | sort --p=1 -S32b -u
2349   [bug introduced in coreutils-8.6]
2351   sort -u could read freed memory.
2352   For example, this evokes a read from freed memory:
2353   perl -le 'print "a\n"."0"x900'|valgrind sort --p=1 -S32b -u>/dev/null
2354   [bug introduced in coreutils-8.6]
2356 ** New features
2358   rm now accepts the --dir (-d) option which makes it remove empty directories.
2359   Since removing empty directories is relatively safe, this option can be
2360   used as a part of the alias rm='rm --dir'.  This improves compatibility
2361   with Mac OS X and BSD systems which also honor the -d option.
2364 * Noteworthy changes in release 8.18 (2012-08-12) [stable]
2366 ** Bug fixes
2368   cksum now prints checksums atomically so that concurrent
2369   processes will not intersperse their output.
2370   [the bug dates back to the initial implementation]
2372   date -d "$(printf '\xb0')" would print 00:00:00 with today's date
2373   rather than diagnosing the invalid input.  Now it reports this:
2374   date: invalid date '\260'
2375   [This bug was present in "the beginning".]
2377   df no longer outputs control characters present in the mount point name.
2378   Such characters are replaced with '?', so for example, scripts consuming
2379   lines output by df, can work reliably.
2380   [This bug was present in "the beginning".]
2382   df --total now exits with an appropriate diagnostic and error code, when
2383   file system --type options do not lead to a processed file system.
2384   [This bug dates back to when --total was added in coreutils-7.0]
2386   head --lines=-N (-n-N) now resets the read pointer of a seekable input file.
2387   This means that "head -n-3" no longer consumes all of its input, and lines
2388   not output by head may be processed by other programs.  For example, this
2389   command now prints the final line, 2, while before it would print nothing:
2390     seq 2 > k; (head -n-1 > /dev/null; cat) < k
2391   [This bug was present in "the beginning".]
2393   ls --color would mis-color relative-named symlinks in /
2394   [bug introduced in coreutils-8.17]
2396   split now ensures it doesn't overwrite the input file with generated output.
2397   [the bug dates back to the initial implementation]
2399   stat and df now report the correct file system usage,
2400   in all situations on GNU/Linux, by correctly determining the block size.
2401   [df bug since coreutils-5.0.91, stat bug since the initial implementation]
2403   tail -f no longer tries to use inotify on AUFS or PanFS file systems
2404   [you might say this was introduced in coreutils-7.5, along with inotify
2405    support, but even now, its magic number isn't in the usual place.]
2407 ** New features
2409   stat -f recognizes the new remote file system types: aufs, panfs.
2411 ** Changes in behavior
2413   su: this program has been removed.  We stopped installing "su" by
2414   default with the release of coreutils-6.9.90 on 2007-12-01.  Now,
2415   that the util-linux package has the union of the Suse and Fedora
2416   patches as well as enough support to build on the Hurd, we no longer
2417   have any reason to include it here.
2419 ** Improvements
2421   sort avoids redundant processing in the presence of inaccessible inputs,
2422   or unwritable output.  Sort now diagnoses certain errors at start-up,
2423   rather than after potentially expensive processing.
2425   sort now allocates no more than 75% of physical memory by default,
2426   to better share system resources, and thus operate more efficiently.
2427   [The default max memory usage changed from 50% to 100% in coreutils-8.16]
2430 * Noteworthy changes in release 8.17 (2012-05-10) [stable]
2432 ** Bug fixes
2434   id and groups, when invoked with no user name argument, would print
2435   the default group ID listed in the password database, and sometimes
2436   that ID would be neither real nor effective.  For example, when run
2437   set-GID, or in a session for which the default group has just been
2438   changed, the new group ID would be listed, even though it is not
2439   yet effective. [bug introduced in coreutils-8.1]
2441   cp S D is no longer subject to a race: if an existing D were removed
2442   between the initial stat and subsequent open-without-O_CREATE, cp would
2443   fail with a confusing diagnostic saying that the destination, D, was not
2444   found.  Now, in this unusual case, it retries the open (but with O_CREATE),
2445   and hence usually succeeds.  With NFS attribute caching, the condition
2446   was particularly easy to trigger, since there, the removal of D could
2447   precede the initial stat.  [This bug was present in "the beginning".]
2449   split --number=C /dev/null no longer appears to infloop on GNU/Hurd
2450   [bug introduced in coreutils-8.8]
2452   stat no longer reports a negative file size as a huge positive number.
2453   [bug present since 'stat' was introduced in fileutils-4.1.9]
2455 ** New features
2457   split and truncate now allow any seekable files in situations where
2458   the file size is needed, instead of insisting on regular files.
2460   fmt now accepts the --goal=WIDTH (-g) option.
2462   stat -f recognizes new file system types: bdevfs, inodefs, qnx6
2464 ** Changes in behavior
2466   cp,mv,install,cat,split: now read and write a minimum of 64KiB at a time.
2467   This was previously 32KiB and increasing to 64KiB was seen to increase
2468   throughput by about 10% when reading cached files on 64 bit GNU/Linux.
2470   cp --attributes-only no longer truncates any existing destination file,
2471   allowing for more general copying of attributes from one file to another.
2474 * Noteworthy changes in release 8.16 (2012-03-26) [stable]
2476 ** New features
2478   As a GNU extension, 'chmod', 'mkdir', and 'install' now accept operators
2479   '-', '+', '=' followed by octal modes; for example, 'chmod +40 FOO' enables
2480   and 'chmod -40 FOO' disables FOO's group-read permissions.  Operator
2481   numeric modes can be combined with symbolic modes by separating them with
2482   commas; for example, =0,u+r clears all permissions except for enabling
2483   user-read permissions.  Unlike ordinary numeric modes, operator numeric
2484   modes do not preserve directory setuid and setgid bits; for example,
2485   'chmod =0 FOO' clears all of FOO's permissions, including setuid and setgid.
2487   Also, ordinary numeric modes with five or more digits no longer preserve
2488   setuid and setgid bits, so that 'chmod 00755 FOO' now clears FOO's setuid
2489   and setgid bits.  This allows scripts to be portable to other systems which
2490   lack the GNU extension mentioned previously, and where ordinary numeric
2491   modes do not preserve directory setuid and setgid bits.
2493   dd now accepts the count_bytes, skip_bytes iflags and the seek_bytes
2494   oflag, to more easily allow processing portions of a file.
2496   dd now accepts the conv=sparse flag to attempt to create sparse
2497   output, by seeking rather than writing to the output file.
2499   ln now accepts the --relative option, to generate a relative
2500   symbolic link to a target, irrespective of how the target is specified.
2502   split now accepts an optional "from" argument to --numeric-suffixes,
2503   which changes the start number from the default of 0.
2505   split now accepts the --additional-suffix option, to append an
2506   additional static suffix to output file names.
2508   basename now supports the -a and -s options, which allow processing
2509   of more than one argument at a time.  Also the complementary
2510   -z option was added to delimit output items with the NUL character.
2512   dirname now supports more than one argument.  Also the complementary
2513   -z option was added to delimit output items with the NUL character.
2515 ** Bug fixes
2517   du --one-file-system (-x) would ignore any non-directory specified on
2518   the command line.  For example, "touch f; du -x f" would print nothing.
2519   [bug introduced in coreutils-8.15]
2521   mv now lets you move a symlink onto a same-inode destination file that
2522   has two or more hard links.  Before, it would reject that, saying that
2523   they are the same, implicitly warning you that the move would result in
2524   data loss.  In this unusual case, when not moving the symlink onto its
2525   referent, there is no risk of data loss, since the symlink will
2526   typically still point to one of the hard links.
2528   "mv A B" could succeed, yet A would remain.  This would happen only when
2529   both A and B were hard links to the same symlink, and with a kernel for
2530   which rename("A","B") does nothing and returns 0 (POSIX mandates this
2531   surprising rename no-op behavior).  Now, mv handles this case by skipping
2532   the usually-useless rename and simply unlinking A.
2534   realpath no longer mishandles a root directory.  This was most
2535   noticeable on platforms where // is a different directory than /,
2536   but could also be observed with --relative-base=/ or
2537   --relative-to=/.  [bug since the beginning, in 8.15]
2539 ** Improvements
2541   ls can be much more efficient, especially with large directories on file
2542   systems for which getfilecon-, ACL-check- and XATTR-check-induced syscalls
2543   fail with ENOTSUP or similar.
2545   'realpath --relative-base=dir' in isolation now implies '--relative-to=dir'
2546   instead of causing a usage failure.
2548   split now supports an unlimited number of split files as default behavior.
2551 * Noteworthy changes in release 8.15 (2012-01-06) [stable]
2553 ** New programs
2555   realpath: print resolved file names.
2557 ** Bug fixes
2559   du -x no longer counts root directories of other file systems.
2560   [bug introduced in coreutils-5.1.0]
2562   ls --color many-entry-directory was uninterruptible for too long
2563   [bug introduced in coreutils-5.2.1]
2565   ls's -k option no longer affects how ls -l outputs file sizes.
2566   It now affects only the per-directory block counts written by -l,
2567   and the sizes written by -s.  This is for compatibility with BSD
2568   and with POSIX 2008.  Because -k is no longer equivalent to
2569   --block-size=1KiB, a new long option --kibibyte stands for -k.
2570   [bug introduced in coreutils-4.5.4]
2572   ls -l would leak a little memory (security context string) for each
2573   nonempty directory listed on the command line, when using SELinux.
2574   [bug probably introduced in coreutils-6.10 with SELinux support]
2576   rm -rf DIR would fail with "Device or resource busy" on Cygwin with NWFS
2577   and NcFsd file systems.  This did not affect Unix/Linux-based kernels.
2578   [bug introduced in coreutils-8.0, when rm began using fts]
2580   split -n 1/2 FILE no longer fails when operating on a growing file, or
2581   (on some systems) when operating on a non-regular file like /dev/zero.
2582   It would report "/dev/zero: No such file or directory" even though
2583   the file obviously exists.  Same for -n l/2.
2584   [bug introduced in coreutils-8.8, with the addition of the -n option]
2586   stat -f now recognizes the FhGFS and PipeFS file system types.
2588   tac no longer fails to handle two or more non-seekable inputs
2589   [bug introduced in coreutils-5.3.0]
2591   tail -f no longer tries to use inotify on GPFS or FhGFS file systems
2592   [you might say this was introduced in coreutils-7.5, along with inotify
2593    support, but the new magic numbers weren't in the usual places then.]
2595 ** Changes in behavior
2597   df avoids long UUID-including file system names in the default listing.
2598   With recent enough kernel/tools, these long names would be used, pushing
2599   second and subsequent columns far to the right.  Now, when a long name
2600   refers to a symlink, and no file systems are specified, df prints the
2601   usually-short referent instead.
2603   tail -f now uses polling (not inotify) when any of its file arguments
2604   resides on a file system of unknown type.  In addition, for each such
2605   argument, tail -f prints a warning with the FS type magic number and a
2606   request to report it to the bug-reporting address.
2609 * Noteworthy changes in release 8.14 (2011-10-12) [stable]
2611 ** Bug fixes
2613   ls --dereference no longer outputs erroneous "argetm" strings for
2614   dangling symlinks when an 'ln=target' entry is in $LS_COLORS.
2615   [bug introduced in fileutils-4.0]
2617   ls -lL symlink once again properly prints "+" when the referent has an ACL.
2618   [bug introduced in coreutils-8.13]
2620   sort -g no longer infloops for certain inputs containing NaNs
2621   [bug introduced in coreutils-8.5]
2623 ** Improvements
2625   md5sum --check now supports the -r format from the corresponding BSD tool.
2626   This also affects sha1sum, sha224sum, sha384sum and sha512sum.
2628   pwd now works also on systems without openat.  On such systems, pwd
2629   would fail when run from a directory whose absolute name contained
2630   more than PATH_MAX / 3 components.  The df, stat and readlink programs
2631   are also affected due to their use of the canonicalize_* functions.
2633 ** Changes in behavior
2635   timeout now only processes the first signal received from the set
2636   it is handling (SIGTERM, SIGINT, ...).  This is to support systems that
2637   implicitly create threads for some timer functions (like GNU/kFreeBSD).
2639 ** Build-related
2641   "make dist" no longer builds .tar.gz files.
2642   xz is portable enough and in wide-enough use that distributing
2643   only .tar.xz files is enough.
2646 * Noteworthy changes in release 8.13 (2011-09-08) [stable]
2648 ** Bug fixes
2650   chown and chgrp with the -v --from= options, now output the correct owner.
2651   I.e., for skipped files, the original ownership is output, not the new one.
2652   [bug introduced in sh-utils-2.0g]
2654   cp -r could mistakenly change the permissions of an existing destination
2655   directory.  [bug introduced in coreutils-6.8]
2657   cp -u -p would fail to preserve one hard link for each up-to-date copy
2658   of a src-hard-linked name in the destination tree.  I.e., if s/a and s/b
2659   are hard-linked and dst/s/a is up to date, "cp -up s dst" would copy s/b
2660   to dst/s/b rather than simply linking dst/s/b to dst/s/a.
2661   [This bug appears to have been present in "the beginning".]
2663   fts-using tools (rm, du, chmod, chgrp, chown, chcon) no longer use memory
2664   proportional to the number of entries in each directory they process.
2665   Before, rm -rf 4-million-entry-directory would consume about 1GiB of memory.
2666   Now, it uses less than 30MB, no matter how many entries there are.
2667   [this bug was inherent in the use of fts: thus, for rm the bug was
2668   introduced in coreutils-8.0.  The prior implementation of rm did not use
2669   as much memory.  du, chmod, chgrp and chown started using fts in 6.0.
2670   chcon was added in coreutils-6.9.91 with fts support.  ]
2672   pr -T no longer ignores a specified LAST_PAGE to stop at.
2673   [bug introduced in textutils-1.19q]
2675   printf '%d' '"' no longer accesses out-of-bounds memory in the diagnostic.
2676   [bug introduced in sh-utils-1.16]
2678   split --number l/... no longer creates extraneous files in certain cases.
2679   [bug introduced in coreutils-8.8]
2681   timeout now sends signals to commands that create their own process group.
2682   timeout is no longer confused when starting off with a child process.
2683   [bugs introduced in coreutils-7.0]
2685   unexpand -a now aligns correctly when there are spaces spanning a tabstop,
2686   followed by a tab.  In that case a space was dropped, causing misalignment.
2687   We also now ensure that a space never precedes a tab.
2688   [bug introduced in coreutils-5.3.0]
2690 ** Changes in behavior
2692   chmod, chown and chgrp now output the original attributes in messages,
2693   when -v or -c specified.
2695   cp -au (where --preserve=links is implicit) may now replace newer
2696   files in the destination, to mirror hard links from the source.
2698 ** New features
2700   date now accepts ISO 8601 date-time strings with "T" as the
2701   separator.  It has long parsed dates like "2004-02-29 16:21:42"
2702   with a space between the date and time strings.  Now it also parses
2703   "2004-02-29T16:21:42" and fractional-second and time-zone-annotated
2704   variants like "2004-02-29T16:21:42.333-07:00"
2706   md5sum accepts the new --strict option.  With --check, it makes the
2707   tool exit non-zero for any invalid input line, rather than just warning.
2708   This also affects sha1sum, sha224sum, sha384sum and sha512sum.
2710   split accepts a new --filter=CMD option.  With it, split filters output
2711   through CMD.  CMD may use the $FILE environment variable, which is set to
2712   the nominal output file name for each invocation of CMD.  For example, to
2713   split a file into 3 approximately equal parts, which are then compressed:
2714     split -n3 --filter='xz > $FILE.xz' big
2715   Note the use of single quotes, not double quotes.
2716   That creates files named xaa.xz, xab.xz and xac.xz.
2718   timeout accepts a new --foreground option, to support commands not started
2719   directly from a shell prompt, where the command is interactive or needs to
2720   receive signals initiated from the terminal.
2722 ** Improvements
2724   cp -p now copies trivial NSFv4 ACLs on Solaris 10.  Before, it would
2725   mistakenly apply a non-trivial ACL to the destination file.
2727   cp and ls now support HP-UX 11.11's ACLs, thanks to improved support
2728   in gnulib.
2730   df now supports disk partitions larger than 4 TiB on MacOS X 10.5
2731   or newer and on AIX 5.2 or newer.
2733   join --check-order now prints "join: FILE:LINE_NUMBER: bad_line" for an
2734   unsorted input, rather than e.g., "join: file 1 is not in sorted order".
2736   shuf outputs small subsets of large permutations much more efficiently.
2737   For example 'shuf -i1-$((2**32-1)) -n2' no longer exhausts memory.
2739   stat -f now recognizes the GPFS, MQUEUE and PSTOREFS file system types.
2741   timeout now supports sub-second timeouts.
2743 ** Build-related
2745   Changes inherited from gnulib address a build failure on HP-UX 11.11
2746   when using /opt/ansic/bin/cc.
2748   Numerous portability and build improvements inherited via gnulib.
2751 * Noteworthy changes in release 8.12 (2011-04-26) [stable]
2753 ** Bug fixes
2755   tail's --follow=name option no longer implies --retry on systems
2756   with inotify support.  [bug introduced in coreutils-7.5]
2758 ** Changes in behavior
2760   cp's extent-based (FIEMAP) copying code is more reliable in the face
2761   of varying and undocumented file system semantics:
2762   - it no longer treats unwritten extents specially
2763   - a FIEMAP-based extent copy always uses the FIEMAP_FLAG_SYNC flag.
2764       Before, it would incur the performance penalty of that sync only
2765       for 2.6.38 and older kernels.  We thought all problems would be
2766       resolved for 2.6.39.
2767   - it now attempts a FIEMAP copy only on a file that appears sparse.
2768       Sparse files are relatively unusual, and the copying code incurs
2769       the performance penalty of the now-mandatory sync only for them.
2771 ** Portability
2773   dd once again compiles on AIX 5.1 and 5.2
2776 * Noteworthy changes in release 8.11 (2011-04-13) [stable]
2778 ** Bug fixes
2780   cp -a --link would not create a hardlink to a symlink, instead
2781   copying the symlink and then not preserving its timestamp.
2782   [bug introduced in coreutils-8.0]
2784   cp now avoids FIEMAP issues with BTRFS before Linux 2.6.38,
2785   which could result in corrupt copies of sparse files.
2786   [bug introduced in coreutils-8.10]
2788   cut could segfault when invoked with a user-specified output
2789   delimiter and an unbounded range like "-f1234567890-".
2790   [bug introduced in coreutils-5.3.0]
2792   du would infloop when given --files0-from=DIR
2793   [bug introduced in coreutils-7.1]
2795   sort no longer spawns 7 worker threads to sort 16 lines
2796   [bug introduced in coreutils-8.6]
2798   touch built on Solaris 9 would segfault when run on Solaris 10
2799   [bug introduced in coreutils-8.8]
2801   wc would dereference a NULL pointer upon an early out-of-memory error
2802   [bug introduced in coreutils-7.1]
2804 ** New features
2806   dd now accepts the 'nocache' flag to the iflag and oflag options,
2807   which will discard any cache associated with the files, or
2808   processed portion thereof.
2810   dd now warns that 'iflag=fullblock' should be used,
2811   in various cases where partial reads can cause issues.
2813 ** Changes in behavior
2815   cp now avoids syncing files when possible, when doing a FIEMAP copy.
2816   The sync is only needed on Linux kernels before 2.6.39.
2817   [The sync was introduced in coreutils-8.10]
2819   cp now copies empty extents efficiently, when doing a FIEMAP copy.
2820   It no longer reads the zero bytes from the input, and also can efficiently
2821   create a hole in the output file when --sparse=always is specified.
2823   df now aligns columns consistently, and no longer wraps entries
2824   with longer device identifiers, over two lines.
2826   install now rejects its long-deprecated --preserve_context option.
2827   Use --preserve-context instead.
2829   test now accepts "==" as a synonym for "="
2832 * Noteworthy changes in release 8.10 (2011-02-04) [stable]
2834 ** Bug fixes
2836   du would abort with a failed assertion when two conditions are met:
2837   part of the hierarchy being traversed is moved to a higher level in the
2838   directory tree, and there is at least one more command line directory
2839   argument following the one containing the moved sub-tree.
2840   [bug introduced in coreutils-5.1.0]
2842   join --header now skips the ordering check for the first line
2843   even if the other file is empty.  [bug introduced in coreutils-8.5]
2845   join -v2 now ensures the default output format prints the match field
2846   at the start of the line when it is different to the match field for
2847   the first file. [bug present in "the beginning".]
2849   rm -f no longer fails for EINVAL or EILSEQ on file systems that
2850   reject file names invalid for that file system.
2852   uniq -f NUM no longer tries to process fields after end of line.
2853   [bug introduced in coreutils-7.0]
2855 ** New features
2857   cp now copies sparse files efficiently on file systems with FIEMAP
2858   support (ext4, btrfs, xfs, ocfs2).  Before, it had to read 2^20 bytes
2859   when copying a 1MiB sparse file.  Now, it copies bytes only for the
2860   non-sparse sections of a file.  Similarly, to induce a hole in the
2861   output file, it had to detect a long sequence of zero bytes.  Now,
2862   it knows precisely where each hole in an input file is, and can
2863   reproduce them efficiently in the output file.  mv also benefits
2864   when it resorts to copying, e.g., between file systems.
2866   join now supports -o 'auto' which will automatically infer the
2867   output format from the first line in each file, to ensure
2868   the same number of fields are output for each line.
2870 ** Changes in behavior
2872   join no longer reports disorder when one of the files is empty.
2873   This allows one to use join as a field extractor like:
2874   join -a1 -o 1.3,1.1 - /dev/null
2877 * Noteworthy changes in release 8.9 (2011-01-04) [stable]
2879 ** Bug fixes
2881   split no longer creates files with a suffix length that
2882   is dependent on the number of bytes or lines per file.
2883   [bug introduced in coreutils-8.8]
2886 * Noteworthy changes in release 8.8 (2010-12-22) [stable]
2888 ** Bug fixes
2890   cp -u no longer does unnecessary copying merely because the source
2891   has finer-grained timestamps than the destination.
2893   od now prints floating-point numbers without losing information, and
2894   it no longer omits spaces between floating-point columns in some cases.
2896   sort -u with at least two threads could attempt to read through a
2897   corrupted pointer. [bug introduced in coreutils-8.6]
2899   sort with at least two threads and with blocked output would busy-loop
2900   (spinlock) all threads, often using 100% of available CPU cycles to
2901   do no work.  I.e., "sort < big-file | less" could waste a lot of power.
2902   [bug introduced in coreutils-8.6]
2904   sort with at least two threads no longer segfaults due to use of pointers
2905   into the stack of an expired thread. [bug introduced in coreutils-8.6]
2907   sort --compress no longer mishandles subprocesses' exit statuses,
2908   no longer hangs indefinitely due to a bug in waiting for subprocesses,
2909   and no longer generates many more than NMERGE subprocesses.
2911   sort -m -o f f ... f no longer dumps core when file descriptors are limited.
2913 ** Changes in behavior
2915   sort will not create more than 8 threads by default due to diminishing
2916   performance gains.  Also the --parallel option is no longer restricted
2917   to the number of available processors.
2919 ** New features
2921   split accepts the --number/-n option to generate a specific number of
2922   files, as well as the --elide-empty-files/-e and --unbuffered/-u
2923   options to fine-tune the resulting output.
2926 * Noteworthy changes in release 8.7 (2010-11-13) [stable]
2928 ** Bug fixes
2930   cp, install, mv, and touch no longer crash when setting file times
2931   on Solaris 10 Update 9 [Solaris PatchID 144488 and newer expose a
2932   latent bug introduced in coreutils 8.1, and possibly a second latent
2933   bug going at least as far back as coreutils 5.97]
2935   csplit no longer corrupts heap when writing more than 999 files,
2936   nor does it leak memory for every chunk of input processed
2937   [the bugs were present in the initial implementation]
2939   tail -F once again notices changes in a currently unavailable
2940   remote directory [bug introduced in coreutils-7.5]
2942 ** Changes in behavior
2944   cp --attributes-only now completely overrides --reflink.
2945   Previously a reflink was needlessly attempted.
2947   stat's %X, %Y, and %Z directives once again print only the integer
2948   part of seconds since the epoch.  This reverts a change from
2949   coreutils-8.6, that was deemed unnecessarily disruptive.
2950   To obtain a nanosecond-precision timestamp for %X use %.X;
2951   if you want (say) just 3 fractional digits, use %.3X.
2952   Likewise for %Y and %Z.
2954   stat's new %W format directive would print floating point seconds.
2955   However, with the above change to %X, %Y and %Z, we've made %W work
2956   the same way as the others.
2958   stat gained support for several printf-style flags, such as %'s for
2959   listing sizes with the current locale's thousands separator.
2962 * Noteworthy changes in release 8.6 (2010-10-15) [stable]
2964 ** Bug fixes
2966   du no longer multiply counts a file that is a directory or whose
2967   link count is 1, even if the file is reached multiple times by
2968   following symlinks or via multiple arguments.
2970   du -H and -L now consistently count pointed-to files instead of
2971   symbolic links, and correctly diagnose dangling symlinks.
2973   du --ignore=D now ignores directory D even when that directory is
2974   found to be part of a directory cycle.  Before, du would issue a
2975   "NOTIFY YOUR SYSTEM MANAGER" diagnostic and fail.
2977   split now diagnoses read errors rather than silently exiting.
2978   [bug introduced in coreutils-4.5.8]
2980   tac would perform a double-free when given an input line longer than 16KiB.
2981   [bug introduced in coreutils-8.3]
2983   tail -F once again notices changes in a currently unavailable directory,
2984   and works around a Linux kernel bug where inotify runs out of resources.
2985   [bugs introduced in coreutils-7.5]
2987   tr now consistently handles case conversion character classes.
2988   In some locales, valid conversion specifications caused tr to abort,
2989   while in all locales, some invalid specifications were undiagnosed.
2990   [bugs introduced in coreutils 6.9.90 and 6.9.92]
2992 ** New features
2994   cp now accepts the --attributes-only option to not copy file data,
2995   which is useful for efficiently modifying files.
2997   du recognizes -d N as equivalent to --max-depth=N, for compatibility
2998   with FreeBSD.
3000   sort now accepts the --debug option, to highlight the part of the
3001   line significant in the sort, and warn about questionable options.
3003   sort now supports -d, -f, -i, -R, and -V in any combination.
3005   stat now accepts the %m format directive to output the mount point
3006   for a file.  It also accepts the %w and %W format directives for
3007   outputting the birth time of a file, if one is available.
3009 ** Changes in behavior
3011   df now consistently prints the device name for a bind mounted file,
3012   rather than its aliased target.
3014   du now uses less than half as much memory when operating on trees
3015   with many hard-linked files.  With --count-links (-l), or when
3016   operating on trees with no hard-linked files, there is no change.
3018   ls -l now uses the traditional three field time style rather than
3019   the wider two field numeric ISO style, in locales where a style has
3020   not been specified.  The new approach has nicer behavior in some
3021   locales, including English, which was judged to outweigh the disadvantage
3022   of generating less-predictable and often worse output in poorly-configured
3023   locales where there is an onus to specify appropriate non-default styles.
3024   [The old behavior was introduced in coreutils-6.0 and had been removed
3025    for English only using a different method since coreutils-8.1]
3027   rm's -d now evokes an error;  before, it was silently ignored.
3029   sort -g now uses long doubles for greater range and precision.
3031   sort -h no longer rejects numbers with leading or trailing ".", and
3032   no longer accepts numbers with multiple ".".  It now considers all
3033   zeros to be equal.
3035   sort now uses the number of available processors to parallelize
3036   the sorting operation.  The number of sorts run concurrently can be
3037   limited with the --parallel option or with external process
3038   control like taskset for example.
3040   stat now provides translated output when no format is specified.
3042   stat no longer accepts the --context (-Z) option.  Initially it was
3043   merely accepted and ignored, for compatibility.  Starting two years
3044   ago, with coreutils-7.0, its use evoked a warning.  Printing the
3045   SELinux context of a file can be done with the %C format directive,
3046   and the default output when no format is specified now automatically
3047   includes %C when context information is available.
3049   stat no longer accepts the %C directive when the --file-system
3050   option is in effect, since security context is a file attribute
3051   rather than a file system attribute.
3053   stat now outputs the full sub-second resolution for the atime,
3054   mtime, and ctime values since the Epoch, when using the %X, %Y, and
3055   %Z directives of the --format option.  This matches the fact that
3056   %x, %y, and %z were already doing so for the human-readable variant.
3058   touch's --file option is no longer recognized.  Use --reference=F (-r)
3059   instead.  --file has not been documented for 15 years, and its use has
3060   elicited a warning since coreutils-7.1.
3062   truncate now supports setting file sizes relative to a reference file.
3063   Also errors are no longer suppressed for unsupported file types, and
3064   relative sizes are restricted to supported file types.
3067 * Noteworthy changes in release 8.5 (2010-04-23) [stable]
3069 ** Bug fixes
3071   cp and mv once again support preserving extended attributes.
3072   [bug introduced in coreutils-8.4]
3074   cp now preserves "capabilities" when also preserving file ownership.
3076   ls --color once again honors the 'NORMAL' dircolors directive.
3077   [bug introduced in coreutils-6.11]
3079   sort -M now handles abbreviated months that are aligned using blanks
3080   in the locale database.  Also locales with 8 bit characters are
3081   handled correctly, including multi byte locales with the caveat
3082   that multi byte characters are matched case sensitively.
3084   sort again handles obsolescent key formats (+POS -POS) correctly.
3085   Previously if -POS was specified, 1 field too many was used in the sort.
3086   [bug introduced in coreutils-7.2]
3088 ** New features
3090   join now accepts the --header option, to treat the first line of each
3091   file as a header line to be joined and printed unconditionally.
3093   timeout now accepts the --kill-after option which sends a kill
3094   signal to the monitored command if it's still running the specified
3095   duration after the initial signal was sent.
3097   who: the "+/-" --mesg (-T) indicator of whether a user/tty is accepting
3098   messages could be incorrectly listed as "+", when in fact, the user was
3099   not accepting messages (mesg no).  Before, who would examine only the
3100   permission bits, and not consider the group of the TTY device file.
3101   Thus, if a login tty's group would change somehow e.g., to "root",
3102   that would make it unwritable (via write(1)) by normal users, in spite
3103   of whatever the permission bits might imply.  Now, when configured
3104   using the --with-tty-group[=NAME] option, who also compares the group
3105   of the TTY device with NAME (or "tty" if no group name is specified).
3107 ** Changes in behavior
3109   ls --color no longer emits the final 3-byte color-resetting escape
3110   sequence when it would be a no-op.
3112   join -t '' no longer emits an error and instead operates on
3113   each line as a whole (even if they contain NUL characters).
3116 * Noteworthy changes in release 8.4 (2010-01-13) [stable]
3118 ** Bug fixes
3120   nproc --all is now guaranteed to be as large as the count
3121   of available processors, which may not have been the case
3122   on GNU/Linux systems with neither /proc nor /sys available.
3123   [bug introduced in coreutils-8.1]
3125 ** Build-related
3127   Work around a build failure when using buggy <sys/capability.h>.
3128   Alternatively, configure with --disable-libcap.
3130   Compilation would fail on systems using glibc-2.7..2.9 due to changes in
3131   gnulib's wchar.h that tickled a bug in at least those versions of glibc's
3132   own <wchar.h> header.  Now, gnulib works around the bug in those older
3133   glibc <wchar.h> headers.
3135   Building would fail with a link error (cp/copy.o) when XATTR headers
3136   were installed without the corresponding library.  Now, configure
3137   detects that and disables xattr support, as one would expect.
3140 * Noteworthy changes in release 8.3 (2010-01-07) [stable]
3142 ** Bug fixes
3144   cp -p, install -p, mv, and touch -c could trigger a spurious error
3145   message when using new glibc coupled with an old kernel.
3146   [bug introduced in coreutils-6.12].
3148   ls -l --color no longer prints "argetm" in front of dangling
3149   symlinks when the 'LINK target' directive was given to dircolors.
3150   [bug introduced in fileutils-4.0]
3152   pr's page header was improperly formatted for long file names.
3153   [bug introduced in coreutils-7.2]
3155   rm -r --one-file-system works once again.
3156   The rewrite to make rm use fts introduced a regression whereby
3157   a command of the above form would fail for all subdirectories.
3158   [bug introduced in coreutils-8.0]
3160   stat -f recognizes more file system types: k-afs, fuseblk, gfs/gfs2, ocfs2,
3161   and rpc_pipefs. Also Minix V3 is displayed correctly as minix3, not minux3.
3162   [bug introduced in coreutils-8.1]
3164   tail -f (inotify-enabled) once again works with remote files.
3165   The use of inotify with remote files meant that any changes to those
3166   files that was not done from the local system would go unnoticed.
3167   [bug introduced in coreutils-7.5]
3169   tail -F (inotify-enabled) would abort when a tailed file is repeatedly
3170   renamed-aside and then recreated.
3171   [bug introduced in coreutils-7.5]
3173   tail -F (inotify-enabled) could fail to follow renamed files.
3174   E.g., given a "tail -F a b" process, running "mv a b" would
3175   make tail stop tracking additions to "b".
3176   [bug introduced in coreutils-7.5]
3178   touch -a and touch -m could trigger bugs in some file systems, such
3179   as xfs or ntfs-3g, and fail to update timestamps.
3180   [bug introduced in coreutils-8.1]
3182   wc now prints counts atomically so that concurrent
3183   processes will not intersperse their output.
3184   [the issue dates back to the initial implementation]
3187 * Noteworthy changes in release 8.2 (2009-12-11) [stable]
3189 ** Bug fixes
3191   id's use of mgetgroups no longer writes beyond the end of a malloc'd buffer
3192   [bug introduced in coreutils-8.1]
3194   id no longer crashes on systems without supplementary group support.
3195   [bug introduced in coreutils-8.1]
3197   rm once again handles zero-length arguments properly.
3198   The rewrite to make rm use fts introduced a regression whereby
3199   a command like "rm a '' b" would fail to remove "a" and "b", due to
3200   the presence of the empty string argument.
3201   [bug introduced in coreutils-8.0]
3203   sort is now immune to the signal handling of its parent.
3204   Specifically sort now doesn't exit with an error message
3205   if it uses helper processes for compression and its parent
3206   ignores CHLD signals. [bug introduced in coreutils-6.9]
3208   tail without -f no longer accesses uninitialized memory
3209   [bug introduced in coreutils-7.6]
3211   timeout is now immune to the signal handling of its parent.
3212   Specifically timeout now doesn't exit with an error message
3213   if its parent ignores CHLD signals. [bug introduced in coreutils-7.6]
3215   a user running "make distcheck" in the coreutils source directory,
3216   with TMPDIR unset or set to the name of a world-writable directory,
3217   and with a malicious user on the same system
3218   was vulnerable to arbitrary code execution
3219   [bug introduced in coreutils-5.0]
3222 * Noteworthy changes in release 8.1 (2009-11-18) [stable]
3224 ** Bug fixes
3226   chcon no longer exits immediately just because SELinux is disabled.
3227   Even then, chcon may still be useful.
3228   [bug introduced in coreutils-8.0]
3230   chcon, chgrp, chmod, chown and du now diagnose an ostensible directory cycle
3231   and arrange to exit nonzero.  Before, they would silently ignore the
3232   offending directory and all "contents."
3234   env -u A=B now fails, rather than silently adding A to the
3235   environment.  Likewise, printenv A=B silently ignores the invalid
3236   name.  [the bugs date back to the initial implementation]
3238   ls --color now handles files with capabilities correctly.  Previously
3239   files with capabilities were often not colored, and also sometimes, files
3240   without capabilities were colored in error. [bug introduced in coreutils-7.0]
3242   md5sum now prints checksums atomically so that concurrent
3243   processes will not intersperse their output.
3244   This also affected sum, sha1sum, sha224sum, sha384sum and sha512sum.
3245   [the bug dates back to the initial implementation]
3247   mktemp no longer leaves a temporary file behind if it was unable to
3248   output the name of the file to stdout.
3249   [the bug dates back to the initial implementation]
3251   nice -n -1 PROGRAM now runs PROGRAM even when its internal setpriority
3252   call fails with errno == EACCES.
3253   [the bug dates back to the initial implementation]
3255   nice, nohup, and su now refuse to execute the subsidiary program if
3256   they detect write failure in printing an otherwise non-fatal warning
3257   message to stderr.
3259   stat -f recognizes more file system types: afs, cifs, anon-inode FS,
3260   btrfs, cgroupfs, cramfs-wend, debugfs, futexfs, hfs, inotifyfs, minux3,
3261   nilfs, securityfs, selinux, xenfs
3263   tail -f (inotify-enabled) now avoids a race condition.
3264   Before, any data appended in the tiny interval between the initial
3265   read-to-EOF and the inotify watch initialization would be ignored
3266   initially (until more data was appended), or forever, if the file
3267   were first renamed or unlinked or never modified.
3268   [The race was introduced in coreutils-7.5]
3270   tail -F (inotify-enabled) now consistently tails a file that has been
3271   replaced via renaming.  That operation provokes either of two sequences
3272   of inotify events.  The less common sequence is now handled as well.
3273   [The bug came with the implementation change in coreutils-7.5]
3275   timeout now doesn't exit unless the command it is monitoring does,
3276   for any specified signal. [bug introduced in coreutils-7.0].
3278 ** Changes in behavior
3280   chroot, env, nice, and su fail with status 125, rather than 1, on
3281   internal error such as failure to parse command line arguments; this
3282   is for consistency with stdbuf and timeout, and avoids ambiguity
3283   with the invoked command failing with status 1.  Likewise, nohup
3284   fails with status 125 instead of 127.
3286   du (due to a change in gnulib's fts) can now traverse NFSv4 automounted
3287   directories in which the stat'd device number of the mount point differs
3288   during a traversal.  Before, it would fail, because such a mismatch would
3289   usually represent a serious error or a subversion attempt.
3291   echo and printf now interpret \e as the Escape character (0x1B).
3293   rm -f /read-only-fs/nonexistent now succeeds and prints no diagnostic
3294   on systems with an unlinkat syscall that sets errno to EROFS in that case.
3295   Before, it would fail with a "Read-only file system" diagnostic.
3296   Also, "rm /read-only-fs/nonexistent" now reports "file not found" rather
3297   than the less precise "Read-only file system" error.
3299 ** New programs
3301   nproc: Print the number of processing units available to a process.
3303 ** New features
3305   env and printenv now accept the option --null (-0), as a means to
3306   avoid ambiguity with newlines embedded in the environment.
3308   md5sum --check now also accepts openssl-style checksums.
3309   So do sha1sum, sha224sum, sha384sum and sha512sum.
3311   mktemp now accepts the option --suffix to provide a known suffix
3312   after the substitution in the template.  Additionally, uses such as
3313   "mktemp fileXXXXXX.txt" are able to infer an appropriate --suffix.
3315   touch now accepts the option --no-dereference (-h), as a means to
3316   change symlink timestamps on platforms with enough support.
3319 * Noteworthy changes in release 8.0 (2009-10-06) [beta]
3321 ** Bug fixes
3323   cp --preserve=xattr and --archive now preserve extended attributes even
3324   when the source file doesn't have write access.
3325   [bug introduced in coreutils-7.1]
3327   touch -t [[CC]YY]MMDDhhmm[.ss] now accepts a timestamp string ending in .60,
3328   to accommodate leap seconds.
3329   [the bug dates back to the initial implementation]
3331   ls --color now reverts to the color of a base file type consistently
3332   when the color of a more specific type is disabled.
3333   [bug introduced in coreutils-5.90]
3335   ls -LR exits with status 2, not 0, when it encounters a cycle
3337   "ls -is" is now consistent with ls -lis in ignoring values returned
3338   from a failed stat/lstat.  For example ls -Lis now prints "?", not "0",
3339   for the inode number and allocated size of a dereferenced dangling symlink.
3341   tail --follow --pid now avoids a race condition where data written
3342   just before the process dies might not have been output by tail.
3343   Also, tail no longer delays at all when the specified pid is not live.
3344   [The race was introduced in coreutils-7.5,
3345    and the unnecessary delay was present since textutils-1.22o]
3347 ** Portability
3349   On Solaris 9, many commands would mistakenly treat file/ the same as
3350   file.  Now, even on such a system, path resolution obeys the POSIX
3351   rules that a trailing slash ensures that the preceding name is a
3352   directory or a symlink to a directory.
3354 ** Changes in behavior
3356   id no longer prints SELinux " context=..." when the POSIXLY_CORRECT
3357   environment variable is set.
3359   readlink -f now ignores a trailing slash when deciding if the
3360   last component (possibly via a dangling symlink) can be created,
3361   since mkdir will succeed in that case.
3363 ** New features
3365   ln now accepts the options --logical (-L) and --physical (-P),
3366   added by POSIX 2008.  The default behavior is -P on systems like
3367   GNU/Linux where link(2) creates hard links to symlinks, and -L on
3368   BSD systems where link(2) follows symlinks.
3370   stat: without -f, a command-line argument of "-" now means standard input.
3371   With --file-system (-f), an argument of "-" is now rejected.
3372   If you really must operate on a file named "-", specify it as
3373   "./-" or use "--" to separate options from arguments.
3375 ** Improvements
3377   rm: rewrite to use gnulib's fts
3378   This makes rm -rf significantly faster (400-500%) in some pathological
3379   cases, and slightly slower (20%) in at least one pathological case.
3381   rm -r deletes deep hierarchies more efficiently.  Before, execution time
3382   was quadratic in the depth of the hierarchy, now it is merely linear.
3383   However, this improvement is not as pronounced as might be expected for
3384   very deep trees, because prior to this change, for any relative name
3385   length longer than 8KiB, rm -r would sacrifice official conformance to
3386   avoid the disproportionate quadratic performance penalty.  Leading to
3387   another improvement:
3389   rm -r is now slightly more standard-conforming when operating on
3390   write-protected files with relative names longer than 8KiB.
3393 * Noteworthy changes in release 7.6 (2009-09-11) [stable]
3395 ** Bug fixes
3397   cp, mv now ignore failure to preserve a symlink timestamp, when it is
3398   due to their running on a kernel older than what was implied by headers
3399   and libraries tested at configure time.
3400   [bug introduced in coreutils-7.5]
3402   cp --reflink --preserve now preserves attributes when cloning a file.
3403   [bug introduced in coreutils-7.5]
3405   cp --preserve=xattr no longer leaks resources on each preservation failure.
3406   [bug introduced in coreutils-7.1]
3408   dd now exits with non-zero status when it encounters a write error while
3409   printing a summary to stderr.
3410   [bug introduced in coreutils-6.11]
3412   dd cbs=N conv=unblock would fail to print a final newline when the size
3413   of the input was not a multiple of N bytes.
3414   [the non-conforming behavior dates back to the initial implementation]
3416   df no longer requires that each command-line argument be readable
3417   [bug introduced in coreutils-7.3]
3419   ls -i now prints consistent inode numbers also for mount points.
3420   This makes ls -i DIR less efficient on systems with dysfunctional readdir,
3421   because ls must stat every file in order to obtain a guaranteed-valid
3422   inode number.  [bug introduced in coreutils-6.0]
3424   tail -f (inotify-enabled) now flushes any initial output before blocking.
3425   Before, this would print nothing and wait: stdbuf -o 4K tail -f /etc/passwd
3426   Note that this bug affects tail -f only when its standard output is buffered,
3427   which is relatively unusual.
3428   [bug introduced in coreutils-7.5]
3430   tail -f once again works with standard input.  inotify-enabled tail -f
3431   would fail when operating on a nameless stdin.  I.e., tail -f < /etc/passwd
3432   would say "tail: cannot watch `-': No such file or directory", yet the
3433   relatively baroque tail -f /dev/stdin < /etc/passwd would work.  Now, the
3434   offending usage causes tail to revert to its conventional sleep-based
3435   (i.e., not inotify-based) implementation.
3436   [bug introduced in coreutils-7.5]
3438 ** Portability
3440   ln, link: link f z/ would mistakenly succeed on Solaris 10, given an
3441   existing file, f, and nothing named "z".  ln -T f z/ has the same problem.
3442   Each would mistakenly create "z" as a link to "f".  Now, even on such a
3443   system, each command reports the error, e.g.,
3444   link: cannot create link `z/' to `f': Not a directory
3446 ** New features
3448   cp --reflink accepts a new "auto" parameter which falls back to
3449   a standard copy if creating a copy-on-write clone is not possible.
3451 ** Changes in behavior
3453   tail -f now ignores "-" when stdin is a pipe or FIFO.
3454   tail-with-no-args now ignores -f unconditionally when stdin is a pipe or FIFO.
3455   Before, it would ignore -f only when no file argument was specified,
3456   and then only when POSIXLY_CORRECT was set.  Now, :|tail -f - terminates
3457   immediately.  Before, it would block indefinitely.
3460 * Noteworthy changes in release 7.5 (2009-08-20) [stable]
3462 ** Bug fixes
3464   dd's oflag=direct option now works even when the size of the input
3465   is not a multiple of e.g., 512 bytes.
3467   dd now handles signals consistently even when they're received
3468   before data copying has started.
3470   install runs faster again with SELinux enabled
3471   [introduced in coreutils-7.0]
3473   ls -1U (with two or more arguments, at least one a nonempty directory)
3474   would print entry names *before* the name of the containing directory.
3475   Also fixed incorrect output of ls -1RU and ls -1sU.
3476   [introduced in coreutils-7.0]
3478   sort now correctly ignores fields whose ending position is specified
3479   before the start position. Previously in numeric mode the remaining
3480   part of the line after the start position was used as the sort key.
3481   [This bug appears to have been present in "the beginning".]
3483   truncate -s failed to skip all whitespace in the option argument in
3484   some locales.
3486 ** New programs
3488   stdbuf: A new program to run a command with modified stdio buffering
3489   for its standard streams.
3491 ** Changes in behavior
3493   ls --color: files with multiple hard links are no longer colored differently
3494   by default. That can be enabled by changing the LS_COLORS environment
3495   variable. You can control that using the MULTIHARDLINK dircolors input
3496   variable which corresponds to the 'mh' LS_COLORS item. Note these variables
3497   were renamed from 'HARDLINK' and 'hl' which were available since
3498   coreutils-7.1 when this feature was introduced.
3500 ** Deprecated options
3502   nl --page-increment: deprecated in favor of --line-increment, the new option
3503   maintains the previous semantics and the same short option, -i.
3505 ** New features
3507   chroot now accepts the options --userspec and --groups.
3509   cp accepts a new option, --reflink: create a lightweight copy
3510   using copy-on-write (COW).  This is currently only supported within
3511   a btrfs file system.
3513   cp now preserves timestamps on symbolic links, when possible
3515   sort accepts a new option, --human-numeric-sort (-h): sort numbers
3516   while honoring human readable suffixes like KiB and MB etc.
3518   tail --follow now uses inotify when possible, to be more responsive
3519   to file changes and more efficient when monitoring many files.
3522 * Noteworthy changes in release 7.4 (2009-05-07) [stable]
3524 ** Bug fixes
3526   date -d 'next mon', when run on a Monday, now prints the date
3527   7 days in the future rather than the current day.  Same for any other
3528   day-of-the-week name, when run on that same day of the week.
3529   [This bug appears to have been present in "the beginning". ]
3531   date -d tuesday, when run on a Tuesday -- using date built from the 7.3
3532   release tarball, not from git -- would print the date 7 days in the future.
3533   Now, it works properly and prints the current date.  That was due to
3534   human error (including not-committed changes in a release tarball)
3535   and the fact that there is no check to detect when the gnulib/ git
3536   submodule is dirty.
3538 ** Build-related
3540   make check: two tests have been corrected
3542 ** Portability
3544   There have been some ACL-related portability fixes for *BSD,
3545   inherited from gnulib.
3548 * Noteworthy changes in release 7.3 (2009-05-01) [stable]
3550 ** Bug fixes
3552   cp now diagnoses failure to preserve selinux/xattr attributes when
3553   --preserve=context,xattr is specified in combination with -a.
3554   Also, cp no longer suppresses attribute-preservation diagnostics
3555   when preserving SELinux context was explicitly requested.
3557   ls now aligns output correctly in the presence of abbreviated month
3558   names from the locale database that have differing widths.
3560   ls -v and sort -V now order names like "#.b#" properly
3562   mv: do not print diagnostics when failing to preserve xattr's on file
3563   systems without xattr support.
3565   sort -m no longer segfaults when its output file is also an input file.
3566   E.g., with this, touch 1; sort -m -o 1 1, sort would segfault.
3567   [introduced in coreutils-7.2]
3569 ** Changes in behavior
3571   shred, sort, shuf: now use an internal pseudorandom generator by default.
3572   This is mainly noticeable in shred where the 3 random passes it does by
3573   default should proceed at the speed of the disk.  Previously /dev/urandom
3574   was used if available, which is relatively slow on GNU/Linux systems.
3576 ** Improved robustness
3578   cp would exit successfully after copying less than the full contents
3579   of a file larger than ~4000 bytes from a linux-/proc file system to a
3580   destination file system with a fundamental block size of 4KiB or greater.
3581   Reading into a 4KiB-or-larger buffer, cp's "read" syscall would return
3582   a value smaller than 4096, and cp would interpret that as EOF (POSIX
3583   allows this).  This optimization, now removed, saved 50% of cp's read
3584   syscalls when copying small files.  Affected linux kernels: at least
3585   2.6.9 through 2.6.29.
3586   [the optimization was introduced in coreutils-6.0]
3588 ** Portability
3590   df now pre-mounts automountable directories even with automounters for
3591   which stat-like syscalls no longer provoke mounting.  Now, df uses open.
3593   'id -G $USER' now works correctly even on Darwin and NetBSD. Previously it
3594   would either truncate the group list to 10, or go into an infinite loop,
3595   due to their non-standard getgrouplist implementations.
3596   [truncation introduced in coreutils-6.11]
3597   [infinite loop introduced in coreutils-7.1]
3600 * Noteworthy changes in release 7.2 (2009-03-31) [stable]
3602 ** New features
3604   pwd now accepts the options --logical (-L) and --physical (-P).  For
3605   compatibility with existing scripts, -P is the default behavior
3606   unless POSIXLY_CORRECT is requested.
3608 ** Bug fixes
3610   cat once again immediately outputs data it has processed.
3611   Previously it would have been buffered and only output if enough
3612   data was read, or on process exit.
3613   [bug introduced in coreutils-6.0]
3615   comm's new --check-order option would fail to detect disorder on any pair
3616   of lines where one was a prefix of the other.  For example, this would
3617   fail to report the disorder: printf 'Xb\nX\n'>k; comm --check-order k k
3618   [bug introduced in coreutils-7.0]
3620   cp once again diagnoses the invalid "cp -rl dir dir" right away,
3621   rather than after creating a very deep dir/dir/dir/... hierarchy.
3622   The bug strikes only with both --recursive (-r, -R) and --link (-l).
3623   [bug introduced in coreutils-7.1]
3625   ls --sort=version (-v) sorted names beginning with "." inconsistently.
3626   Now, names that start with "." are always listed before those that don't.
3628   pr: fix the bug whereby --indent=N (-o) did not indent header lines
3629   [bug introduced in coreutils-6.9.90]
3631   sort now handles specified key ends correctly.
3632   Previously -k1,1b would have caused leading space from field 2 to be
3633   included in the sort while -k2,3.0 would have not included field 3.
3635 ** Changes in behavior
3637   cat,cp,install,mv,split: these programs now read and write a minimum
3638   of 32KiB at a time.  This was seen to double throughput when reading
3639   cached files on GNU/Linux-based systems.
3641   cp -a now tries to preserve extended attributes (xattr), but does not
3642   diagnose xattr-preservation failure.  However, cp --preserve=all still does.
3644   ls --color: hard link highlighting can be now disabled by changing the
3645   LS_COLORS environment variable. To disable it you can add something like
3646   this to your profile: eval `dircolors | sed s/hl=[^:]*:/hl=:/`
3649 * Noteworthy changes in release 7.1 (2009-02-21) [stable]
3651 ** New features
3653   Add extended attribute support available on certain filesystems like ext2
3654   and XFS.
3655     cp: Tries to copy xattrs when --preserve=xattr or --preserve=all specified
3656     mv: Always tries to copy xattrs
3657     install: Never copies xattrs
3659   cp and mv accept a new option, --no-clobber (-n): silently refrain
3660   from overwriting any existing destination file
3662   dd accepts iflag=cio and oflag=cio to open the file in CIO (concurrent I/O)
3663   mode where this feature is available.
3665   install accepts a new option, --compare (-C): compare each pair of source
3666   and destination files, and if the destination has identical content and
3667   any specified owner, group, permissions, and possibly SELinux context, then
3668   do not modify the destination at all.
3670   ls --color now highlights hard linked files, too
3672   stat -f recognizes the Lustre file system type
3674 ** Bug fixes
3676   chgrp, chmod, chown --silent (--quiet, -f) no longer print some diagnostics
3677   [bug introduced in coreutils-5.1]
3679   cp uses much less memory in some situations
3681   cp -a now correctly tries to preserve SELinux context (announced in 6.9.90),
3682   doesn't inform about failure, unlike with --preserve=all
3684   du --files0-from=FILE no longer reads all of FILE into RAM before
3685   processing the first file name
3687   seq 9223372036854775807 9223372036854775808 now prints only two numbers
3688   on systems with extended long double support and good library support.
3689   Even with this patch, on some systems, it still produces invalid output,
3690   from 3 to at least 1026 lines long. [bug introduced in coreutils-6.11]
3692   seq -w now accounts for a decimal point added to the last number
3693   to correctly print all numbers to the same width.
3695   wc --files0-from=FILE no longer reads all of FILE into RAM, before
3696   processing the first file name, unless the list of names is known
3697   to be small enough.
3699 ** Changes in behavior
3701   cp and mv: the --reply={yes,no,query} option has been removed.
3702   Using it has elicited a warning for the last three years.
3704   dd: user specified offsets that are too big are handled better.
3705   Previously, erroneous parameters to skip and seek could result
3706   in redundant reading of the file with no warnings or errors.
3708   du: -H (initially equivalent to --si) is now equivalent to
3709   --dereference-args, and thus works as POSIX requires
3711   shred: now does 3 overwrite passes by default rather than 25.
3713   ls -l now marks SELinux-only files with the less obtrusive '.',
3714   rather than '+'.  A file with any other combination of MAC and ACL
3715   is still marked with a '+'.
3718 * Noteworthy changes in release 7.0 (2008-10-05) [beta]
3720 ** New programs
3722   timeout: Run a command with bounded time.
3723   truncate: Set the size of a file to a specified size.
3725 ** New features
3727   chgrp, chmod, chown, chcon, du, rm: now all display linear performance,
3728   even when operating on million-entry directories on ext3 and ext4 file
3729   systems.  Before, they would exhibit O(N^2) performance, due to linear
3730   per-entry seek time cost when operating on entries in readdir order.
3731   Rm was improved directly, while the others inherit the improvement
3732   from the newer version of fts in gnulib.
3734   comm now verifies that the inputs are in sorted order.  This check can
3735   be turned off with the --nocheck-order option.
3737   comm accepts new option, --output-delimiter=STR, that allows specification
3738   of an output delimiter other than the default single TAB.
3740   cp and mv: the deprecated --reply=X option is now also undocumented.
3742   dd accepts iflag=fullblock to make it accumulate full input blocks.
3743   With this new option, after a short read, dd repeatedly calls read,
3744   until it fills the incomplete block, reaches EOF, or encounters an error.
3746   df accepts a new option --total, which produces a grand total of all
3747   arguments after all arguments have been processed.
3749   If the GNU MP library is available at configure time, factor and
3750   expr support arbitrarily large numbers.  Pollard's rho algorithm is
3751   used to factor large numbers.
3753   install accepts a new option --strip-program to specify the program used to
3754   strip binaries.
3756   ls now colors names of files with capabilities if libcap is available.
3758   ls -v now uses filevercmp function as sort predicate (instead of strverscmp)
3760   md5sum now accepts the new option, --quiet, to suppress the printing of
3761   'OK' messages.  sha1sum, sha224sum, sha384sum, and sha512sum accept it, too.
3763   sort accepts a new option, --files0-from=F, that specifies a file
3764   containing a null-separated list of files to sort.  This list is used
3765   instead of filenames passed on the command-line to avoid problems with
3766   maximum command-line (argv) length.
3768   sort accepts a new option --batch-size=NMERGE, where NMERGE
3769   represents the maximum number of inputs that will be merged at once.
3770   When processing more than NMERGE inputs, sort uses temporary files.
3772   sort accepts a new option --version-sort (-V, --sort=version),
3773   specifying that ordering is to be based on filevercmp.
3775 ** Bug fixes
3777   chcon --verbose now prints a newline after each message
3779   od no longer suffers from platform bugs in printf(3).  This is
3780   probably most noticeable when using 'od -tfL' to print long doubles.
3782   seq -0.1 0.1 2 now prints 2,0 when locale's decimal point is ",".
3783   Before, it would mistakenly omit the final number in that example.
3785   shuf honors the --zero-terminated (-z) option, even with --input-range=LO-HI
3787   shuf --head-count is now correctly documented.  The documentation
3788   previously claimed it was called --head-lines.
3790 ** Improvements
3792   Improved support for access control lists (ACLs): On MacOS X, Solaris 7..10,
3793   HP-UX 11, Tru64, AIX, IRIX 6.5, and Cygwin, "ls -l" now displays the presence
3794   of an ACL on a file via a '+' sign after the mode, and "cp -p" copies ACLs.
3796   join has significantly better performance due to better memory management
3798   ls now uses constant memory when not sorting and using one_per_line format,
3799   no matter how many files are in a given directory.  I.e., to list a directory
3800   with very many files, ls -1U is much more efficient.
3802   od now aligns fields across lines when printing multiple -t
3803   specifiers, and no longer prints fields that resulted entirely from
3804   padding the input out to the least common multiple width.
3806 ** Changes in behavior
3808   stat's --context (-Z) option has always been a no-op.
3809   Now it evokes a warning that it is obsolete and will be removed.
3812 * Noteworthy changes in release 6.12 (2008-05-31) [stable]
3814 ** New features
3816   cp, install, mv, and touch now preserve nanosecond resolution on
3817   file timestamps, on platforms that have the 'utimensat' and
3818   'futimens' system calls.
3820 ** Bug fixes
3822   chcon, runcon: --help output now includes the bug-reporting address
3824   cp -p copies permissions more portably.  For example, on MacOS X 10.5,
3825   "cp -p some-fifo some-file" no longer fails while trying to copy the
3826   permissions from the some-fifo argument.
3828   id with no options now prints the SELinux context only when invoked
3829   with no USERNAME argument.
3831   id and groups once again print the AFS-specific nameless group-ID (PAG).
3832   Printing of such large-numbered, kernel-only (not in /etc/group) group-IDs
3833   was suppressed in 6.11 due to ignorance that they are useful.
3835   uniq: avoid subtle field-skipping malfunction due to isblank misuse.
3836   In some locales on some systems, isblank(240) (aka &nbsp) is nonzero.
3837   On such systems, uniq --skip-fields=N would fail to skip the proper
3838   number of fields for some inputs.
3840   tac: avoid segfault with --regex (-r) and multiple files, e.g.,
3841   "echo > x; tac -r x x".  [bug present at least in textutils-1.8b, from 1992]
3843 ** Changes in behavior
3845   install once again sets SELinux context, when possible
3846   [it was deliberately disabled in 6.9.90]
3849 * Noteworthy changes in release 6.11 (2008-04-19) [stable]
3851 ** Bug fixes
3853   configure --enable-no-install-program=groups now works.
3855   "cp -fR fifo E" now succeeds with an existing E.  Before this fix, using
3856   -fR to copy a fifo or "special" file onto an existing file would fail
3857   with EEXIST.  Now, it once again unlinks the destination before trying
3858   to create the destination file.  [bug introduced in coreutils-5.90]
3860   dd once again works with unnecessary options like if=/dev/stdin and
3861   of=/dev/stdout.  [bug introduced in fileutils-4.0h]
3863   id now uses getgrouplist, when possible.  This results in
3864   much better performance when there are many users and/or groups.
3866   ls no longer segfaults on files in /proc when linked with an older version
3867   of libselinux.  E.g., ls -l /proc/sys would dereference a NULL pointer.
3869   md5sum would segfault for invalid BSD-style input, e.g.,
3870   echo 'MD5 (' | md5sum -c -  Now, md5sum ignores that line.
3871   sha1sum, sha224sum, sha384sum, and sha512sum are affected, too.
3872   [bug introduced in coreutils-5.1.0]
3874   md5sum -c would accept a NUL-containing checksum string like "abcd\0..."
3875   and would unnecessarily read and compute the checksum of the named file,
3876   and then compare that checksum to the invalid one: guaranteed to fail.
3877   Now, it recognizes that the line is not valid and skips it.
3878   sha1sum, sha224sum, sha384sum, and sha512sum are affected, too.
3879   [bug present in the original version, in coreutils-4.5.1, 1995]
3881   "mkdir -Z x dir" no longer segfaults when diagnosing invalid context "x"
3882   mkfifo and mknod would fail similarly.  Now they're fixed.
3884   mv would mistakenly unlink a destination file before calling rename,
3885   when the destination had two or more hard links.  It no longer does that.
3886   [bug introduced in coreutils-5.3.0]
3888   "paste -d'\' file" no longer overruns memory (heap since coreutils-5.1.2,
3889   stack before then) [bug present in the original version, in 1992]
3891   "pr -e" with a mix of backspaces and TABs no longer corrupts the heap
3892   [bug present in the original version, in 1992]
3894   "ptx -F'\' long-file-name" would overrun a malloc'd buffer and corrupt
3895   the heap.  That was triggered by a lone backslash (or odd number of them)
3896   at the end of the option argument to --flag-truncation=STRING (-F),
3897   --word-regexp=REGEXP (-W), or --sentence-regexp=REGEXP (-S).
3899   "rm -r DIR" would mistakenly declare to be "write protected" -- and
3900   prompt about -- full DIR-relative names longer than MIN (PATH_MAX, 8192).
3902   "rmdir --ignore-fail-on-non-empty" detects and ignores the failure
3903   in more cases when a directory is empty.
3905   "seq -f % 1" would issue the erroneous diagnostic "seq: memory exhausted"
3906   rather than reporting the invalid string format.
3907   [bug introduced in coreutils-6.0]
3909 ** New features
3911   join now verifies that the inputs are in sorted order.  This check can
3912   be turned off with the --nocheck-order option.
3914   sort accepts the new option --sort=WORD, where WORD can be one of
3915   general-numeric, month, numeric or random.  These are equivalent to the
3916   options --general-numeric-sort/-g, --month-sort/-M, --numeric-sort/-n
3917   and --random-sort/-R, resp.
3919 ** Improvements
3921   id and groups work around an AFS-related bug whereby those programs
3922   would print an invalid group number, when given no user-name argument.
3924   ls --color no longer outputs unnecessary escape sequences
3926   seq gives better diagnostics for invalid formats.
3928 ** Portability
3930   rm now works properly even on systems like BeOS and Haiku,
3931   which have negative errno values.
3933 ** Consistency
3935   install, mkdir, rmdir and split now write --verbose output to stdout,
3936   not to stderr.
3939 * Noteworthy changes in release 6.10 (2008-01-22) [stable]
3941 ** Bug fixes
3943   Fix a non-portable use of sed in configure.ac.
3944   [bug introduced in coreutils-6.9.92]
3947 * Noteworthy changes in release 6.9.92 (2008-01-12) [beta]
3949 ** Bug fixes
3951   cp --parents no longer uses uninitialized memory when restoring the
3952   permissions of a just-created destination directory.
3953   [bug introduced in coreutils-6.9.90]
3955   tr's case conversion would fail in a locale with differing numbers
3956   of lower case and upper case characters.  E.g., this would fail:
3957   env LC_CTYPE=en_US.ISO-8859-1 tr '[:upper:]' '[:lower:]'
3958   [bug introduced in coreutils-6.9.90]
3960 ** Improvements
3962   "touch -d now writable-but-owned-by-someone-else" now succeeds
3963   whenever that same command would succeed without "-d now".
3964   Before, it would work fine with no -d option, yet it would
3965   fail with the ostensibly-equivalent "-d now".
3968 * Noteworthy changes in release 6.9.91 (2007-12-15) [beta]
3970 ** Bug fixes
3972   "ls -l" would not output "+" on SELinux hosts unless -Z was also given.
3974   "rm" would fail to unlink a non-directory when run in an environment
3975   in which the user running rm is capable of unlinking a directory.
3976   [bug introduced in coreutils-6.9]
3979 * Noteworthy changes in release 6.9.90 (2007-12-01) [beta]
3981 ** New programs
3983   arch: equivalent to uname -m, not installed by default
3984   But don't install this program on Solaris systems.
3986   chcon: change the SELinux security context of a file
3988   mktemp: create a temporary file or directory (or names)
3990   runcon: run a program in a different SELinux security context
3992 ** Programs no longer installed by default
3994   hostname, su
3996 ** Changes in behavior
3998   cp, by default, refuses to copy through a dangling destination symlink
3999   Set POSIXLY_CORRECT if you require the old, risk-prone behavior.
4001   pr -F no longer suppresses the footer or the first two blank lines in
4002   the header.  This is for compatibility with BSD and POSIX.
4004   tr now warns about an unescaped backslash at end of string.
4005   The tr from coreutils-5.2.1 and earlier would fail for such usage,
4006   and Solaris' tr ignores that final byte.
4008 ** New features
4010   Add SELinux support, based on the patch from Fedora:
4011   * cp accepts new --preserve=context option.
4012   * "cp -a" works with SELinux:
4013   Now, cp -a attempts to preserve context, but failure to do so does
4014   not change cp's exit status.  However "cp --preserve=context" is
4015   similar, but failure *does* cause cp to exit with nonzero status.
4016   * install accepts new "-Z, --context=C" option.
4017   * id accepts new "-Z" option.
4018   * stat honors the new %C format directive: SELinux security context string
4019   * ls accepts a slightly modified -Z option.
4020   * ls: contrary to Fedora version, does not accept --lcontext and --scontext
4022   The following commands and options now support the standard size
4023   suffixes kB, M, MB, G, GB, and so on for T, P, Y, Z, and Y:
4024   head -c, head -n, od -j, od -N, od -S, split -b, split -C,
4025   tail -c, tail -n.
4027   cp -p tries to preserve the GID of a file even if preserving the UID
4028   is not possible.
4030   uniq accepts a new option: --zero-terminated (-z).  As with the sort
4031   option of the same name, this makes uniq consume and produce
4032   NUL-terminated lines rather than newline-terminated lines.
4034   wc no longer warns about character decoding errors in multibyte locales.
4035   This means for example that "wc /bin/sh" now produces normal output
4036   (though the word count will have no real meaning) rather than many
4037   error messages.
4039 ** New build options
4041   By default, "make install" no longer attempts to install (or even build) su.
4042   To change that, use ./configure --enable-install-program=su.
4043   If you also want to install the new "arch" program, do this:
4044   ./configure --enable-install-program=arch,su.
4046   You can inhibit the compilation and installation of selected programs
4047   at configure time.  For example, to avoid installing "hostname" and
4048   "uptime", use ./configure --enable-no-install-program=hostname,uptime
4049   Note: currently, "make check" passes, even when arch and su are not
4050   built (that's the new default).  However, if you inhibit the building
4051   and installation of other programs, don't be surprised if some parts
4052   of "make check" fail.
4054 ** Remove deprecated options
4056   df no longer accepts the --kilobytes option.
4057   du no longer accepts the --kilobytes or --megabytes options.
4058   ls no longer accepts the --kilobytes option.
4059   ptx longer accepts the --copyright option.
4060   who no longer accepts -i or --idle.
4062 ** Improved robustness
4064   ln -f can no longer silently clobber a just-created hard link.
4065   In some cases, ln could be seen as being responsible for data loss.
4066   For example, given directories a, b, c, and files a/f and b/f, we
4067   should be able to do this safely: ln -f a/f b/f c && rm -f a/f b/f
4068   However, before this change, ln would succeed, and thus cause the
4069   loss of the contents of a/f.
4071   stty no longer silently accepts certain invalid hex values
4072   in its 35-colon command-line argument
4074 ** Bug fixes
4076   chmod no longer ignores a dangling symlink.  Now, chmod fails
4077   with a diagnostic saying that it cannot operate on such a file.
4078   [bug introduced in coreutils-5.1.0]
4080   cp attempts to read a regular file, even if stat says it is empty.
4081   Before, "cp /proc/cpuinfo c" would create an empty file when the kernel
4082   reports stat.st_size == 0, while "cat /proc/cpuinfo > c" would "work",
4083   and create a nonempty one. [bug introduced in coreutils-6.0]
4085   cp --parents no longer mishandles symlinks to directories in file
4086   name components in the source, e.g., "cp --parents symlink/a/b d"
4087   no longer fails.  Also, 'cp' no longer considers a destination
4088   symlink to be the same as the referenced file when copying links
4089   or making backups.  For example, if SYM is a symlink to FILE,
4090   "cp -l FILE SYM" now reports an error instead of silently doing
4091   nothing.  The behavior of 'cp' is now better documented when the
4092   destination is a symlink.
4094   "cp -i --update older newer" no longer prompts; same for mv
4096   "cp -i" now detects read errors on standard input, and no longer consumes
4097   too much seekable input; same for ln, install, mv, and rm.
4099   cut now diagnoses a range starting with zero (e.g., -f 0-2) as invalid;
4100   before, it would treat it as if it started with 1 (-f 1-2).
4102   "cut -f 2-0" now fails; before, it was equivalent to "cut -f 2-"
4104   cut now diagnoses the '-' in "cut -f -" as an invalid range, rather
4105   than interpreting it as the unlimited range, "1-".
4107   date -d now accepts strings of the form e.g., 'YYYYMMDD +N days',
4108   in addition to the usual 'YYYYMMDD N days'.
4110   du -s now includes the size of any stat'able-but-inaccessible directory
4111   in the total size.
4113   du (without -s) prints whatever it knows of the size of an inaccessible
4114   directory.  Before, du would print nothing for such a directory.
4116   ls -x DIR would sometimes output the wrong string in place of the
4117   first entry.  [introduced in coreutils-6.8]
4119   ls --color would mistakenly color a dangling symlink as if it were
4120   a regular symlink.  This would happen only when the dangling symlink
4121   was not a command-line argument and in a directory with d_type support.
4122   [introduced in coreutils-6.0]
4124   ls --color, (with a custom LS_COLORS envvar value including the
4125   ln=target attribute) would mistakenly output the string "target"
4126   before the name of each symlink.  [introduced in coreutils-6.0]
4128   od's --skip (-j) option now works even when the kernel says that a
4129   nonempty regular file has stat.st_size = 0.  This happens at least
4130   with files in /proc and linux-2.6.22.
4132   "od -j L FILE" had a bug: when the number of bytes to skip, L, is exactly
4133   the same as the length of FILE, od would skip *no* bytes.  When the number
4134   of bytes to skip is exactly the sum of the lengths of the first N files,
4135   od would skip only the first N-1 files. [introduced in textutils-2.0.9]
4137   ./printf %.10000000f 1 could get an internal ENOMEM error and generate
4138   no output, yet erroneously exit with status 0.  Now it diagnoses the error
4139   and exits with nonzero status.  [present in initial implementation]
4141   seq no longer mishandles obvious cases like "seq 0 0.000001 0.000003",
4142   so workarounds like "seq 0 0.000001 0.0000031" are no longer needed.
4144   seq would mistakenly reject some valid format strings containing %%,
4145   and would mistakenly accept some invalid ones. e.g., %g%% and %%g, resp.
4147   "seq .1 .1" would mistakenly generate no output on some systems
4149   Obsolete sort usage with an invalid ordering-option character, e.g.,
4150   "env _POSIX2_VERSION=199209 sort +1x" no longer makes sort free an
4151   invalid pointer [introduced in coreutils-6.5]
4153   sorting very long lines (relative to the amount of available memory)
4154   no longer provokes unaligned memory access
4156   split --line-bytes=N (-C N) no longer creates an empty file
4157   [this bug is present at least as far back as textutils-1.22 (Jan, 1997)]
4159   tr -c no longer aborts when translating with Set2 larger than the
4160   complement of Set1.  [present in the original version, in 1992]
4162   tr no longer rejects an unmatched [:lower:] or [:upper:] in SET1.
4163   [present in the original version]
4166 * Noteworthy changes in release 6.9 (2007-03-22) [stable]
4168 ** Bug fixes
4170   cp -x (--one-file-system) would fail to set mount point permissions
4172   The default block size and output format for df -P are now unaffected by
4173   the DF_BLOCK_SIZE, BLOCK_SIZE, and BLOCKSIZE environment variables.  It
4174   is still affected by POSIXLY_CORRECT, though.
4176   Using pr -m -s (i.e., merging files, with TAB as the output separator)
4177   no longer inserts extraneous spaces between output columns.
4179 * Noteworthy changes in release 6.8 (2007-02-24) [not-unstable]
4181 ** Bug fixes
4183   chgrp, chmod, and chown now honor the --preserve-root option.
4184   Before, they would warn, yet continuing traversing and operating on /.
4186   chmod no longer fails in an environment (e.g., a chroot) with openat
4187   support but with insufficient /proc support.
4189   "cp --parents F/G D" no longer creates a directory D/F when F is not
4190   a directory (and F/G is therefore invalid).
4192   "cp --preserve=mode" would create directories that briefly had
4193   too-generous permissions in some cases.  For example, when copying a
4194   directory with permissions 777 the destination directory might
4195   temporarily be setgid on some file systems, which would allow other
4196   users to create subfiles with the same group as the directory.  Fix
4197   similar problems with 'install' and 'mv'.
4199   cut no longer dumps core for usage like "cut -f2- f1 f2" with two or
4200   more file arguments.  This was due to a double-free bug, introduced
4201   in coreutils-5.3.0.
4203   dd bs= operands now silently override any later ibs= and obs=
4204   operands, as POSIX and tradition require.
4206   "ls -FRL" always follows symbolic links on Linux.  Introduced in
4207   coreutils-6.0.
4209   A cross-partition "mv /etc/passwd ~" (by non-root) now prints
4210   a reasonable diagnostic.  Before, it would print this:
4211   "mv: cannot remove `/etc/passwd': Not a directory".
4213   pwd and "readlink -e ." no longer fail unnecessarily when a parent
4214   directory is unreadable.
4216   rm (without -f) could prompt when it shouldn't, or fail to prompt
4217   when it should, when operating on a full name longer than 511 bytes
4218   and getting an ENOMEM error while trying to form the long name.
4220   rm could mistakenly traverse into the wrong directory under unusual
4221   conditions: when a full name longer than 511 bytes specifies a search-only
4222   directory, and when forming that name fails with ENOMEM, rm would attempt
4223   to open a truncated-to-511-byte name with the first five bytes replaced
4224   with "[...]".  If such a directory were to actually exist, rm would attempt
4225   to remove it.
4227   "rm -rf /etc/passwd" (run by non-root) now prints a diagnostic.
4228   Before it would print nothing.
4230   "rm --interactive=never F" no longer prompts for an unwritable F
4232   "rm -rf D" would emit a misleading diagnostic when failing to
4233   remove a symbolic link within the unwritable directory, D.
4234   Introduced in coreutils-6.0.  Similarly, when a cross-partition
4235   "mv" fails because the source directory is unwritable, it now gives
4236   a reasonable diagnostic.  Before, this would print
4237     $ mkdir /tmp/x; touch /tmp/x/y; chmod -w /tmp/x;
4238     $ test $(stat -c %d /tmp/x) -ne $(stat -c %d .) && mv /tmp/x/y .
4239     mv: cannot remove `/tmp/x/y': Not a directory
4240   Now it prints this:
4241     mv: cannot remove `/tmp/x/y': Permission denied.
4243 ** New features
4245   sort's new --compress-program=PROG option specifies a compression
4246   program to use when writing and reading temporary files.
4247   This can help save both time and disk space when sorting large inputs.
4249   sort accepts the new option -C, which acts like -c except no diagnostic
4250   is printed.  Its --check option now accepts an optional argument, and
4251   --check=quiet and --check=silent are now aliases for -C, while
4252   --check=diagnose-first is an alias for -c or plain --check.
4255 * Noteworthy changes in release 6.7 (2006-12-08) [stable]
4257 ** Bug fixes
4259   When cp -p copied a file with special mode bits set, the same bits
4260   were set on the copy even when ownership could not be preserved.
4261   This could result in files that were setuid to the wrong user.
4262   To fix this, special mode bits are now set in the copy only if its
4263   ownership is successfully preserved.  Similar problems were fixed
4264   with mv when copying across file system boundaries.  This problem
4265   affects all versions of coreutils through 6.6.
4267   cp --preserve=ownership would create output files that temporarily
4268   had too-generous permissions in some cases.  For example, when
4269   copying a file with group A and mode 644 into a group-B sticky
4270   directory, the output file was briefly readable by group B.
4271   Fix similar problems with cp options like -p that imply
4272   --preserve=ownership, with install -d when combined with either -o
4273   or -g, and with mv when copying across file system boundaries.
4274   This bug affects all versions of coreutils through 6.6.
4276   du --one-file-system (-x) would skip subdirectories of any directory
4277   listed as second or subsequent command line argument.  This bug affects
4278   coreutils-6.4, 6.5 and 6.6.
4281 * Noteworthy changes in release 6.6 (2006-11-22) [stable]
4283 ** Bug fixes
4285   ls would segfault (dereference a NULL pointer) for a file with a
4286   nameless group or owner.  This bug was introduced in coreutils-6.5.
4288   A bug in the latest official m4/gettext.m4 (from gettext-0.15)
4289   made configure fail to detect gettext support, due to the unusual
4290   way in which coreutils uses AM_GNU_GETTEXT.
4292 ** Improved robustness
4294   Now, du (and the other fts clients: chmod, chgrp, chown) honor a
4295   trailing slash in the name of a symlink-to-directory even on
4296   Solaris 9, by working around its buggy fstatat implementation.
4299 * Major changes in release 6.5 (2006-11-19) [stable]
4301 ** Bug fixes
4303   du (and the other fts clients: chmod, chgrp, chown) would exit early
4304   when encountering an inaccessible directory on a system with native
4305   openat support (i.e., linux-2.6.16 or newer along with glibc-2.4
4306   or newer).  This bug was introduced with the switch to gnulib's
4307   openat-based variant of fts, for coreutils-6.0.
4309   "ln --backup f f" now produces a sensible diagnostic
4311 ** New features
4313   rm accepts a new option: --one-file-system
4316 * Major changes in release 6.4 (2006-10-22) [stable]
4318 ** Bug fixes
4320   chgrp and chown would malfunction when invoked with both -R and -H and
4321   with one or more of the following: --preserve-root, --verbose, --changes,
4322   --from=o:g (chown only).  This bug was introduced with the switch to
4323   gnulib's openat-based variant of fts, for coreutils-6.0.
4325   cp --backup dir1 dir2, would rename an existing dir2/dir1 to dir2/dir1~.
4326   This bug was introduced in coreutils-6.0.
4328   With --force (-f), rm no longer fails for ENOTDIR.
4329   For example, "rm -f existing-non-directory/anything" now exits
4330   successfully, ignoring the error about a nonexistent file.
4333 * Major changes in release 6.3 (2006-09-30) [stable]
4335 ** Improved robustness
4337   pinky no longer segfaults on Darwin 7.9.0 (MacOS X 10.3.9) due to a
4338   buggy native getaddrinfo function.
4340   rm works around a bug in Darwin 7.9.0 (MacOS X 10.3.9) that would
4341   sometimes keep it from removing all entries in a directory on an HFS+
4342   or NFS-mounted partition.
4344   sort would fail to handle very large input (around 40GB) on systems with a
4345   mkstemp function that returns a file descriptor limited to 32-bit offsets.
4347 ** Bug fixes
4349   chmod would fail unnecessarily in an unusual case: when an initially-
4350   inaccessible argument is rendered accessible by chmod's action on a
4351   preceding command line argument.  This bug also affects chgrp, but
4352   it is harder to demonstrate.  It does not affect chown.  The bug was
4353   introduced with the switch from explicit recursion to the use of fts
4354   in coreutils-5.1.0 (2003-10-15).
4356   cp -i and mv -i occasionally neglected to prompt when the copy or move
4357   action was bound to fail.  This bug dates back to before fileutils-4.0.
4359   With --verbose (-v), cp and mv would sometimes generate no output,
4360   or neglect to report file removal.
4362   For the "groups" command:
4364     "groups" no longer prefixes the output with "user :" unless more
4365     than one user is specified; this is for compatibility with BSD.
4367     "groups user" now exits nonzero when it gets a write error.
4369     "groups" now processes options like --help more compatibly.
4371   shuf would infloop, given 8KB or more of piped input
4373 ** Portability
4375   Versions of chmod, chown, chgrp, du, and rm (tools that use openat etc.)
4376   compiled for Solaris 8 now also work when run on Solaris 10.
4379 * Major changes in release 6.2 (2006-09-18) [stable candidate]
4381 ** Changes in behavior
4383   mkdir -p and install -d (or -D) now use a method that forks a child
4384   process if the working directory is unreadable and a later argument
4385   uses a relative file name.  This avoids some race conditions, but it
4386   means you may need to kill two processes to stop these programs.
4388   rm now rejects attempts to remove the root directory, e.g., 'rm -fr /'
4389   now fails without removing anything.  Likewise for any file name with
4390   a final './' or '../' component.
4392   tail now ignores the -f option if POSIXLY_CORRECT is set, no file
4393   operand is given, and standard input is any FIFO; formerly it did
4394   this only for pipes.
4396 ** Infrastructure changes
4398   Coreutils now uses gnulib via the gnulib-tool script.
4399   If you check the source out from CVS, then follow the instructions
4400   in README-cvs.  Although this represents a large change to the
4401   infrastructure, it should cause no change in how the tools work.
4403 ** Bug fixes
4405   cp --backup no longer fails when the last component of a source file
4406   name is "." or "..".
4408   "ls --color" would highlight other-writable and sticky directories
4409   no differently than regular directories on a file system with
4410   dirent.d_type support.
4412   "mv -T --verbose --backup=t A B" now prints the " (backup: B.~1~)"
4413   suffix when A and B are directories as well as when they are not.
4415   mv and "cp -r" no longer fail when invoked with two arguments
4416   where the first one names a directory and the second name ends in
4417   a slash and doesn't exist.  E.g., "mv dir B/", for nonexistent B,
4418   now succeeds, once more.  This bug was introduced in coreutils-5.3.0.
4421 * Major changes in release 6.1 (2006-08-19) [unstable]
4423 ** Changes in behavior
4425   df now considers BSD "kernfs" file systems to be dummies
4427 ** New features
4429   printf now supports the 'I' flag on hosts whose underlying printf
4430   implementations support 'I', e.g., "printf %Id 2".
4432 ** Bug fixes
4434   cp --sparse preserves sparseness at the end of a file, even when
4435   the file's apparent size is not a multiple of its block size.
4436   [introduced with the original design, in fileutils-4.0r, 2000-04-29]
4438   df (with a command line argument) once again prints its header
4439   [introduced in coreutils-6.0]
4441   ls -CF would misalign columns in some cases involving non-stat'able files
4442   [introduced in coreutils-6.0]
4444 * Major changes in release 6.0 (2006-08-15) [unstable]
4446 ** Improved robustness
4448   df: if the file system claims to have more available than total blocks,
4449   report the number of used blocks as being "total - available"
4450   (a negative number) rather than as garbage.
4452   dircolors: a new autoconf run-test for AIX's buggy strndup function
4453   prevents malfunction on that system;  may also affect cut, expand,
4454   and unexpand.
4456   fts no longer changes the current working directory, so its clients
4457   (chmod, chown, chgrp, du) no longer malfunction under extreme conditions.
4459   pwd and other programs using lib/getcwd.c work even on file systems
4460   where dirent.d_ino values are inconsistent with those from stat.st_ino.
4462   rm's core is now reentrant: rm --recursive (-r) now processes
4463   hierarchies without changing the working directory at all.
4465 ** Changes in behavior
4467   basename and dirname now treat // as different from / on platforms
4468   where the two are distinct.
4470   chmod, install, and mkdir now preserve a directory's set-user-ID and
4471   set-group-ID bits unless you explicitly request otherwise.  E.g.,
4472   'chmod 755 DIR' and 'chmod u=rwx,go=rx DIR' now preserve DIR's
4473   set-user-ID and set-group-ID bits instead of clearing them, and
4474   similarly for 'mkdir -m 755 DIR' and 'mkdir -m u=rwx,go=rx DIR'.  To
4475   clear the bits, mention them explicitly in a symbolic mode, e.g.,
4476   'mkdir -m u=rwx,go=rx,-s DIR'.  To set them, mention them explicitly
4477   in either a symbolic or a numeric mode, e.g., 'mkdir -m 2755 DIR',
4478   'mkdir -m u=rwx,go=rx,g+s' DIR.  This change is for convenience on
4479   systems where these bits inherit from parents.  Unfortunately other
4480   operating systems are not consistent here, and portable scripts
4481   cannot assume the bits are set, cleared, or preserved, even when the
4482   bits are explicitly mentioned.  For example, OpenBSD 3.9 'mkdir -m
4483   777 D' preserves D's setgid bit but 'chmod 777 D' clears it.
4484   Conversely, Solaris 10 'mkdir -m 777 D', 'mkdir -m g-s D', and
4485   'chmod 0777 D' all preserve D's setgid bit, and you must use
4486   something like 'chmod g-s D' to clear it.
4488   'cp --link --no-dereference' now works also on systems where the
4489   link system call cannot create a hard link to a symbolic link.
4490   This change has no effect on systems with a Linux-based kernel.
4492   csplit and nl now use POSIX syntax for regular expressions, not
4493   Emacs syntax.  As a result, character classes like [[:print:]] and
4494   interval expressions like A\{1,9\} now have their usual meaning,
4495   . no longer matches the null character, and \ must precede the + and
4496   ? operators.
4498   date: a command like date -d '2006-04-23 21 days ago' would print
4499   the wrong date in some time zones.  (see the test for an example)
4501   df changes:
4503     df now considers "none" and "proc" file systems to be dummies and
4504     therefore does not normally display them.  Also, inaccessible file
4505     systems (which can be caused by shadowed mount points or by
4506     chrooted bind mounts) are now dummies, too.
4508     df now fails if it generates no output, so you can inspect the
4509     exit status of a command like "df -t ext3 -t reiserfs DIR" to test
4510     whether DIR is on a file system of type "ext3" or "reiserfs".
4512   expr no longer complains about leading ^ in a regular expression
4513   (the anchor is ignored), or about regular expressions like A** (the
4514   second "*" is ignored).  expr now exits with status 2 (not 3) for
4515   errors it detects in the expression's values; exit status 3 is now
4516   used only for internal errors (such as integer overflow, which expr
4517   now checks for).
4519   install and mkdir now implement the X permission symbol correctly,
4520   e.g., 'mkdir -m a+X dir'; previously the X was ignored.
4522   install now creates parent directories with mode u=rwx,go=rx (755)
4523   instead of using the mode specified by the -m option; and it does
4524   not change the owner or group of parent directories.  This is for
4525   compatibility with BSD and closes some race conditions.
4527   ln now uses different (and we hope clearer) diagnostics when it fails.
4528   ln -v now acts more like FreeBSD, so it generates output only when
4529   successful and the output is easier to parse.
4531   ls now defaults to --time-style='locale', not --time-style='posix-long-iso'.
4532   However, the 'locale' time style now behaves like 'posix-long-iso'
4533   if your locale settings appear to be messed up.  This change
4534   attempts to have the default be the best of both worlds.
4536   mkfifo and mknod no longer set special mode bits (setuid, setgid,
4537   and sticky) with the -m option.
4539   nohup's usual diagnostic now more precisely specifies the I/O
4540   redirections, e.g., "ignoring input and appending output to
4541   nohup.out".  Also, nohup now redirects stderr to nohup.out (or
4542   $HOME/nohup.out) if stdout is closed and stderr is a tty; this is in
4543   response to Open Group XCU ERN 71.
4545   rm --interactive now takes an optional argument, although the
4546   default of using no argument still acts like -i.
4548   rm no longer fails to remove an empty, unreadable directory
4550   seq changes:
4552     seq defaults to a minimal fixed point format that does not lose
4553     information if seq's operands are all fixed point decimal numbers.
4554     You no longer need the '-f%.f' in 'seq -f%.f 1048575 1024 1050623',
4555     for example, since the default format now has the same effect.
4557     seq now lets you use %a, %A, %E, %F, and %G formats.
4559     seq now uses long double internally rather than double.
4561   sort now reports incompatible options (e.g., -i and -n) rather than
4562   silently ignoring one of them.
4564   stat's --format=FMT option now works the way it did before 5.3.0:
4565   FMT is automatically newline terminated.  The first stable release
4566   containing this change was 5.92.
4568   stat accepts the new option --printf=FMT, where FMT is *not*
4569   automatically newline terminated.
4571   stat: backslash escapes are interpreted in a format string specified
4572   via --printf=FMT, but not one specified via --format=FMT.  That includes
4573   octal (\ooo, at most three octal digits), hexadecimal (\xhh, one or
4574   two hex digits), and the standard sequences (\a, \b, \f, \n, \r, \t,
4575   \v, \", \\).
4577   With no operand, 'tail -f' now silently ignores the '-f' only if
4578   standard input is a FIFO or pipe and POSIXLY_CORRECT is set.
4579   Formerly, it ignored the '-f' when standard input was a FIFO, pipe,
4580   or socket.
4582 ** Scheduled for removal
4584   ptx's --copyright (-C) option is scheduled for removal in 2007, and
4585   now evokes a warning.  Use --version instead.
4587   rm's --directory (-d) option is scheduled for removal in 2006.  This
4588   option has been silently ignored since coreutils 5.0.  On systems
4589   that support unlinking of directories, you can use the "unlink"
4590   command to unlink a directory.
4592   Similarly, we are considering the removal of ln's --directory (-d,
4593   -F) option in 2006.  Please write to <bug-coreutils@gnu.org> if this
4594   would cause a problem for you.  On systems that support hard links
4595   to directories, you can use the "link" command to create one.
4597 ** New programs
4599   base64: base64 encoding and decoding (RFC 3548) functionality.
4600   sha224sum: print or check a SHA224 (224-bit) checksum
4601   sha256sum: print or check a SHA256 (256-bit) checksum
4602   sha384sum: print or check a SHA384 (384-bit) checksum
4603   sha512sum: print or check a SHA512 (512-bit) checksum
4604   shuf: Shuffle lines of text.
4606 ** New features
4608   chgrp now supports --preserve-root, --no-preserve-root (default),
4609   as it was documented to do, and just as chmod, chown, and rm do.
4611   New dd iflag= and oflag= flags:
4613     'directory' causes dd to fail unless the file is a directory, on
4614     hosts that support this (e.g., Linux kernels, version 2.1.126 and
4615     later).  This has limited utility but is present for completeness.
4617     'noatime' causes dd to read a file without updating its access
4618     time, on hosts that support this (e.g., Linux kernels, version
4619     2.6.8 and later).
4621     'nolinks' causes dd to fail if the file has multiple hard links,
4622     on hosts that support this (e.g., Solaris 10 and later).
4624   ls accepts the new option --group-directories-first, to make it
4625   list directories before files.
4627   rm now accepts the -I (--interactive=once) option.  This new option
4628   prompts once if rm is invoked recursively or if more than three
4629   files are being deleted, which is less intrusive than -i prompting
4630   for every file, but provides almost the same level of protection
4631   against mistakes.
4633   shred and sort now accept the --random-source option.
4635   sort now accepts the --random-sort (-R) option and 'R' ordering option.
4637   sort now supports obsolete usages like "sort +1 -2" unless
4638   POSIXLY_CORRECT is set.  However, when conforming to POSIX
4639   1003.1-2001 "sort +1" still sorts the file named "+1".
4641   wc accepts a new option --files0-from=FILE, where FILE contains a
4642   list of NUL-terminated file names.
4644 ** Bug fixes
4646   cat with any of the options, -A -v -e -E -T, when applied to a
4647   file in /proc or /sys (linux-specific), would truncate its output,
4648   usually printing nothing.
4650   cp -p would fail in a /proc-less chroot, on some systems
4652   When 'cp -RL' encounters the same directory more than once in the
4653   hierarchy beneath a single command-line argument, it no longer confuses
4654   them with hard-linked directories.
4656   fts-using tools (chmod, chown, chgrp, du) no longer fail due to
4657   a double-free bug -- it could be triggered by making a directory
4658   inaccessible while e.g., du is traversing the hierarchy under it.
4660   fts-using tools (chmod, chown, chgrp, du) no longer misinterpret
4661   a very long symlink chain as a dangling symlink.  Before, such a
4662   misinterpretation would cause these tools not to diagnose an ELOOP error.
4664   ls --indicator-style=file-type would sometimes stat a symlink
4665   unnecessarily.
4667   ls --file-type worked like --indicator-style=slash (-p),
4668   rather than like --indicator-style=file-type.
4670   mv: moving a symlink into the place of an existing non-directory is
4671   now done atomically;  before, mv would first unlink the destination.
4673   mv -T DIR EMPTY_DIR no longer fails unconditionally.  Also, mv can
4674   now remove an empty destination directory: mkdir -p a b/a; mv a b
4676   rm (on systems with openat) can no longer exit before processing
4677   all command-line arguments.
4679   rm is no longer susceptible to a few low-probability memory leaks.
4681   rm -r no longer fails to remove an inaccessible and empty directory
4683   rm -r's cycle detection code can no longer be tricked into reporting
4684   a false positive (introduced in fileutils-4.1.9).
4686   shred --remove FILE no longer segfaults on Gentoo systems
4688   sort would fail for large inputs (~50MB) on systems with a buggy
4689   mkstemp function.  sort and tac now use the replacement mkstemp
4690   function, and hence are no longer subject to limitations (of 26 or 32,
4691   on the maximum number of files from a given template) on HP-UX 10.20,
4692   SunOS 4.1.4, Solaris 2.5.1 and OSF1/Tru64 V4.0F&V5.1.
4694   tail -f once again works on a file with the append-only
4695   attribute (affects at least Linux ext2, ext3, xfs file systems)
4697 * Major changes in release 5.97 (2006-06-24) [stable]
4698 * Major changes in release 5.96 (2006-05-22) [stable]
4699 * Major changes in release 5.95 (2006-05-12) [stable]
4700 * Major changes in release 5.94 (2006-02-13) [stable]
4702 [see the b5_9x branch for details]
4704 * Major changes in release 5.93 (2005-11-06) [stable]
4706 ** Bug fixes
4708   dircolors no longer segfaults upon an attempt to use the new
4709   STICKY_OTHER_WRITABLE (OWT) attribute.
4711   du no longer overflows a counter when processing a file larger than
4712   2^31-1 on some 32-bit systems (at least some AIX 5.1 configurations).
4714   md5sum once again defaults to using the ' ' non-binary marker
4715   (rather than the '*' binary marker) by default on Unix-like systems.
4717   mkdir -p and install -d no longer exit nonzero when asked to create
4718   a directory like 'nonexistent/.'
4720   rm emits a better diagnostic when (without -r) it fails to remove
4721   a directory on e.g., Solaris 9/10 systems.
4723   tac now works when stdin is a tty, even on non-Linux systems.
4725   "tail -c 2 FILE" and "touch 0101000000" now operate as POSIX
4726   1003.1-2001 requires, even when coreutils is conforming to older
4727   POSIX standards, as the newly-required behavior is upward-compatible
4728   with the old.
4730   The documentation no longer mentions rm's --directory (-d) option.
4732 ** Build-related bug fixes
4734   installing .mo files would fail
4737 * Major changes in release 5.92 (2005-10-22) [stable]
4739 ** Bug fixes
4741   chmod now diagnoses an invalid mode string starting with an octal digit
4743   dircolors now properly quotes single-quote characters
4746 * Major changes in release 5.91 (2005-10-17) [stable candidate]
4748 ** Bug fixes
4750   "mkdir -p /a/b/c" no longer fails merely because a leading prefix
4751   directory (e.g., /a or /a/b) exists on a read-only file system.
4753 ** Removed options
4755   tail's --allow-missing option has been removed.  Use --retry instead.
4757   stat's --link and -l options have been removed.
4758   Use --dereference (-L) instead.
4760 ** Deprecated options
4762   Using ls, du, or df with the --kilobytes option now evokes a warning
4763   that the long-named option is deprecated.  Use '-k' instead.
4765   du's long-named --megabytes option now evokes a warning.
4766   Use -m instead.
4769 * Major changes in release 5.90 (2005-09-29) [unstable]
4771 ** Bring back support for 'head -NUM', 'tail -NUM', etc. even when
4772   conforming to POSIX 1003.1-2001.  The following changes apply only
4773   when conforming to POSIX 1003.1-2001; there is no effect when
4774   conforming to older POSIX versions.
4776   The following usages now behave just as when conforming to older POSIX:
4778     date -I
4779     expand -TAB1[,TAB2,...]
4780     fold -WIDTH
4781     head -NUM
4782     join -j FIELD
4783     join -j1 FIELD
4784     join -j2 FIELD
4785     join -o FIELD_NAME1 FIELD_NAME2...
4786     nice -NUM
4787     od -w
4788     pr -S
4789     split -NUM
4790     tail -[NUM][bcl][f] [FILE]
4792   The following usages no longer work, due to the above changes:
4794     date -I TIMESPEC  (use 'date -ITIMESPEC' instead)
4795     od -w WIDTH       (use 'od -wWIDTH' instead)
4796     pr -S STRING      (use 'pr -SSTRING' instead)
4798   A few usages still have behavior that depends on which POSIX standard is
4799   being conformed to, and portable applications should beware these
4800   problematic usages.  These include:
4802     Problematic       Standard-conforming replacement, depending on
4803        usage            whether you prefer the behavior of:
4804                       POSIX 1003.2-1992    POSIX 1003.1-2001
4805     sort +4           sort -k 5            sort ./+4
4806     tail +4           tail -n +4           tail ./+4
4807     tail - f          tail f               [see (*) below]
4808     tail -c 4         tail -c 10 ./4       tail -c4
4809     touch 12312359 f  touch -t 12312359 f  touch ./12312359 f
4810     uniq +4           uniq -s 4            uniq ./+4
4812     (*) "tail - f" does not conform to POSIX 1003.1-2001; to read
4813     standard input and then "f", use the command "tail -- - f".
4815   These changes are in response to decisions taken in the January 2005
4816   Austin Group standardization meeting.  For more details, please see
4817   "Utility Syntax Guidelines" in the Minutes of the January 2005
4818   Meeting <https://www.opengroup.org/austin/docs/austin_239.html>.
4820 ** Binary input and output are now implemented more consistently.
4821   These changes affect only platforms like MS-DOS that distinguish
4822   between binary and text files.
4824   The following programs now always use text input/output:
4826     expand unexpand
4828   The following programs now always use binary input/output to copy data:
4830     cp install mv shred
4832   The following programs now always use binary input/output to copy
4833   data, except for stdin and stdout when it is a terminal.
4835     head tac tail tee tr
4836     (cat behaves similarly, unless one of the options -bensAE is used.)
4838   cat's --binary or -B option has been removed.  It existed only on
4839   MS-DOS-like platforms, and didn't work as documented there.
4841   md5sum and sha1sum now obey the -b or --binary option, even if
4842   standard input is a terminal, and they no longer report files to be
4843   binary if they actually read them in text mode.
4845 ** Changes for better conformance to POSIX
4847   cp, ln, mv, rm changes:
4849     Leading white space is now significant in responses to yes-or-no questions.
4850     For example, if "rm" asks "remove regular file `foo'?" and you respond
4851     with " y" (i.e., space before "y"), it counts as "no".
4853   dd changes:
4855     On a QUIT or PIPE signal, dd now exits without printing statistics.
4857     On hosts lacking the INFO signal, dd no longer treats the USR1
4858     signal as if it were INFO when POSIXLY_CORRECT is set.
4860     If the file F is non-seekable and contains fewer than N blocks,
4861     then before copying "dd seek=N of=F" now extends F with zeroed
4862     blocks until F contains N blocks.
4864   fold changes:
4866     When POSIXLY_CORRECT is set, "fold file -3" is now equivalent to
4867     "fold file ./-3", not the obviously-erroneous "fold file ./-w3".
4869   ls changes:
4871     -p now marks only directories; it is equivalent to the new option
4872     --indicator-style=slash.  Use --file-type or
4873     --indicator-style=file-type to get -p's old behavior.
4875   nice changes:
4877     Documentation and diagnostics now refer to "nicenesses" (commonly
4878     in the range -20...19) rather than "nice values" (commonly 0...39).
4880   nohup changes:
4882     nohup now ignores the umask when creating nohup.out.
4884     nohup now closes stderr if it is a terminal and stdout is closed.
4886     nohup now exits with status 127 (not 1) when given an invalid option.
4888   pathchk changes:
4890     It now rejects the empty name in the normal case.  That is,
4891     "pathchk -p ''" now fails, and "pathchk ''" fails unless the
4892     current host (contra POSIX) allows empty file names.
4894     The new -P option checks whether a file name component has leading "-",
4895     as suggested in interpretation "Austin-039:XCU:pathchk:pathchk -p"
4896     <https://collaboration.opengroup.org/austin/interps/documents.php?action=show&gdid=6232>.
4897     It also rejects the empty name even if the current host accepts it; see
4898     <https://collaboration.opengroup.org/austin/interps/documents.php?action=show&gdid=6233>.
4900     The --portability option is now equivalent to -p -P.
4902 ** Bug fixes
4904   chmod, mkdir, mkfifo, and mknod formerly mishandled rarely-used symbolic
4905   permissions like =xX and =u, and did not properly diagnose some invalid
4906   strings like g+gr, ug,+x, and +1.  These bugs have been fixed.
4908   csplit could produce corrupt output, given input lines longer than 8KB
4910   dd now computes statistics using a realtime clock (if available)
4911   rather than the time-of-day clock, to avoid glitches if the
4912   time-of-day is changed while dd is running.  Also, it avoids
4913   using unsafe code in signal handlers; this fixes some core dumps.
4915   expr and test now correctly compare integers of unlimited magnitude.
4917   expr now detects integer overflow when converting strings to integers,
4918   rather than silently wrapping around.
4920   ls now refuses to generate timestamps containing more than 1000 bytes, to
4921   foil potential denial-of-service attacks on hosts with very large stacks.
4923   "mkdir -m =+x dir" no longer ignores the umask when evaluating "+x",
4924   and similarly for mkfifo and mknod.
4926   "mkdir -p /tmp/a/b dir" no longer attempts to create the '.'-relative
4927   directory, dir (in /tmp/a), when, after creating /tmp/a/b, it is unable
4928   to return to its initial working directory.  Similarly for "install -D
4929   file /tmp/a/b/file".
4931   "pr -D FORMAT" now accepts the same formats that "date +FORMAT" does.
4933   stat now exits nonzero if a file operand does not exist
4935 ** Improved robustness
4937   Date no longer needs to allocate virtual memory to do its job,
4938   so it can no longer fail due to an out-of-memory condition,
4939   no matter how large the result.
4941 ** Improved portability
4943   hostid now prints exactly 8 hexadecimal digits, possibly with leading zeros,
4944   and without any spurious leading "fff..." on 64-bit hosts.
4946   nice now works on Darwin 7.7.0 in spite of its invalid definition of NZERO.
4948   'rm -r' can remove all entries in a directory even when it is on a
4949   file system for which readdir is buggy and that was not checked by
4950   coreutils' old configure-time run-test.
4952   sleep no longer fails when resumed after being suspended on linux-2.6.8.1,
4953   in spite of that kernel's buggy nanosleep implementation.
4955 ** New features
4957   chmod -w now complains if its behavior differs from what chmod a-w
4958   would do, and similarly for chmod -r, chmod -x, etc.
4960   cp and mv: the --reply=X option is deprecated
4962   date accepts the new option --rfc-3339=TIMESPEC.  The old --iso-8601 (-I)
4963   option is deprecated; it still works, but new applications should avoid it.
4964   date, du, ls, and pr's time formats now support new %:z, %::z, %:::z
4965   specifiers for numeric time zone offsets like -07:00, -07:00:00, and -07.
4967   dd has new iflag= and oflag= flags "binary" and "text", which have an
4968   effect only on nonstandard platforms that distinguish text from binary I/O.
4970   dircolors now supports SETUID, SETGID, STICKY_OTHER_WRITABLE,
4971   OTHER_WRITABLE, and STICKY, with ls providing default colors for these
4972   categories if not specified by dircolors.
4974   du accepts new options: --time[=TYPE] and --time-style=STYLE
4976   join now supports a NUL field separator, e.g., "join -t '\0'".
4977   join now detects and reports incompatible options, e.g., "join -t x -t y",
4979   ls no longer outputs an extra space between the mode and the link count
4980   when none of the listed files has an ACL.
4982   md5sum --check now accepts multiple input files, and similarly for sha1sum.
4984   If stdin is a terminal, nohup now redirects it from /dev/null to
4985   prevent the command from tying up an OpenSSH session after you logout.
4987   "rm -FOO" now suggests "rm ./-FOO" if the file "-FOO" exists and
4988   "-FOO" is not a valid option.
4990   stat -f -c %S outputs the fundamental block size (used for block counts).
4991   stat -f's default output format has been changed to output this size as well.
4992   stat -f recognizes file systems of type XFS and JFS
4994   "touch -" now touches standard output, not a file named "-".
4996   uname -a no longer generates the -p and -i outputs if they are unknown.
4998 * Major changes in release 5.3.0 (2005-01-08) [unstable]
5000 ** Bug fixes
5002   Several fixes to chgrp and chown for compatibility with POSIX and BSD:
5004     Do not affect symbolic links by default.
5005     Now, operate on whatever a symbolic link points to, instead.
5006     To get the old behavior, use --no-dereference (-h).
5008     --dereference now works, even when the specified owner
5009     and/or group match those of an affected symlink.
5011     Check for incompatible options.  When -R and --dereference are
5012     both used, then either -H or -L must also be used.  When -R and -h
5013     are both used, then -P must be in effect.
5015     -H, -L, and -P have no effect unless -R is also specified.
5016     If -P and -R are both specified, -h is assumed.
5018     Do not optimize away the chown() system call when the file's owner
5019     and group already have the desired value.  This optimization was
5020     incorrect, as it failed to update the last-changed time and reset
5021     special permission bits, as POSIX requires.
5023     "chown : file", "chown '' file", and "chgrp '' file" now succeed
5024     without changing the uid or gid, instead of reporting an error.
5026     Do not report an error if the owner or group of a
5027     recursively-encountered symbolic link cannot be updated because
5028     the file system does not support it.
5030   chmod now accepts multiple mode-like options, e.g., "chmod -r -w f".
5032   chown is no longer subject to a race condition vulnerability, when
5033   used with --from=O:G and without the (-h) --no-dereference option.
5035   cut's --output-delimiter=D option works with abutting byte ranges.
5037   dircolors's documentation now recommends that shell scripts eval
5038   "`dircolors`" rather than `dircolors`, to avoid shell expansion pitfalls.
5040   du no longer segfaults when a subdirectory of an operand
5041   directory is removed while du is traversing that subdirectory.
5042   Since the bug was in the underlying fts.c module, it also affected
5043   chown, chmod, and chgrp.
5045   du's --exclude-from=FILE and --exclude=P options now compare patterns
5046   against the entire name of each file, rather than against just the
5047   final component.
5049   echo now conforms to POSIX better.  It supports the \0ooo syntax for
5050   octal escapes, and \c now terminates printing immediately.  If
5051   POSIXLY_CORRECT is set and the first argument is not "-n", echo now
5052   outputs all option-like arguments instead of treating them as options.
5054   expand and unexpand now conform to POSIX better.  They check for
5055   blanks (which can include characters other than space and tab in
5056   non-POSIX locales) instead of spaces and tabs.  Unexpand now
5057   preserves some blanks instead of converting them to tabs or spaces.
5059   "ln x d/" now reports an error if d/x is a directory and x a file,
5060   instead of incorrectly creating a link to d/x/x.
5062   ls no longer segfaults on systems for which SIZE_MAX != (size_t) -1.
5064   md5sum and sha1sum now report an error when given so many input
5065   lines that their line counter overflows, instead of silently
5066   reporting incorrect results.
5068   Fixes for "nice":
5070     If it fails to lower the niceness due to lack of permissions,
5071     it goes ahead and runs the command anyway, as POSIX requires.
5073     It no longer incorrectly reports an error if the current niceness
5074     happens to be -1.
5076     It no longer assumes that nicenesses range from -20 through 19.
5078     It now consistently adjusts out-of-range nicenesses to the
5079     closest values in range; formerly it sometimes reported an error.
5081   pathchk no longer accepts trailing options, e.g., "pathchk -p foo -b"
5082   now treats -b as a file name to check, not as an invalid option.
5084   'pr --columns=N' was not equivalent to 'pr -N' when also using
5085   either -s or -w.
5087   pr now supports page numbers up to 2**64 on most hosts, and it
5088   detects page number overflow instead of silently wrapping around.
5089   pr now accepts file names that begin with "+" so long as the rest of
5090   the file name does not look like a page range.
5092   printf has several changes:
5094     It now uses 'intmax_t' (not 'long int') to format integers, so it
5095     can now format 64-bit integers on most modern hosts.
5097     On modern hosts it now supports the C99-inspired %a, %A, %F conversion
5098     specs, the "'" and "0" flags, and the ll, j, t, and z length modifiers
5099     (this is compatible with recent Bash versions).
5101     The printf command now rejects invalid conversion specifications
5102     like %#d, instead of relying on undefined behavior in the underlying
5103     printf function.
5105   ptx now diagnoses invalid values for its --width=N (-w)
5106   and --gap-size=N (-g) options.
5108   mv (when moving between partitions) no longer fails when
5109   operating on too many command-line-specified nonempty directories.
5111   "readlink -f" is more compatible with prior implementations
5113   rm (without -f) no longer hangs when attempting to remove a symlink
5114   to a file on an off-line NFS-mounted partition.
5116   rm no longer gets a failed assertion under some unusual conditions.
5118   rm no longer requires read access to the current directory.
5120   "rm -r" would mistakenly fail to remove files under a directory
5121   for some types of errors (e.g., read-only file system, I/O error)
5122   when first encountering the directory.
5124   "sort" fixes:
5126     "sort -o -" now writes to a file named "-" instead of to standard
5127     output; POSIX requires this.
5129     An unlikely race condition has been fixed where "sort" could have
5130     mistakenly removed a temporary file belonging to some other process.
5132     "sort" no longer has O(N**2) behavior when it creates many temporary files.
5134   tac can now handle regular, nonseekable files like Linux's
5135   /proc/modules.  Before, it would produce no output for such a file.
5137   tac would exit immediately upon I/O or temp-file creation failure.
5138   Now it continues on, processing any remaining command line arguments.
5140   "tail -f" no longer mishandles pipes and fifos.  With no operands,
5141   tail now ignores -f if standard input is a pipe, as POSIX requires.
5142   When conforming to POSIX 1003.2-1992, tail now supports the SUSv2 b
5143   modifier (e.g., "tail -10b file") and it handles some obscure cases
5144   more correctly, e.g., "tail +cl" now reads the file "+cl" rather
5145   than reporting an error, "tail -c file" no longer reports an error,
5146   and "tail - file" no longer reads standard input.
5148   tee now exits when it gets a SIGPIPE signal, as POSIX requires.
5149   To get tee's old behavior, use the shell command "(trap '' PIPE; tee)".
5150   Also, "tee -" now writes to standard output instead of to a file named "-".
5152   "touch -- MMDDhhmm[yy] file" is now equivalent to
5153   "touch MMDDhhmm[yy] file" even when conforming to pre-2001 POSIX.
5155   tr no longer mishandles a second operand with leading "-".
5157   who now prints user names in full instead of truncating them after 8 bytes.
5159   The following commands now reject unknown options instead of
5160   accepting them as operands, so that users are properly warned that
5161   options may be added later.  Formerly they accepted unknown options
5162   as operands; e.g., "basename -a a" acted like "basename -- -a a".
5164     basename dirname factor hostname link nohup sync unlink yes
5166 ** New features
5168   For efficiency, 'sort -m' no longer copies input to a temporary file
5169   merely because the input happens to come from a pipe.  As a result,
5170   some relatively-contrived examples like 'cat F | sort -m -o F - G'
5171   are no longer safe, as 'sort' might start writing F before 'cat' is
5172   done reading it.  This problem cannot occur unless '-m' is used.
5174   When outside the default POSIX locale, the 'who' and 'pinky'
5175   commands now output timestamps like "2004-06-21 13:09" instead of
5176   the traditional "Jun 21 13:09".
5178   pwd now works even when run from a working directory whose name
5179   is longer than PATH_MAX.
5181   cp, install, ln, and mv have a new --no-target-directory (-T) option,
5182   and -t is now a short name for their --target-directory option.
5184   cp -pu and mv -u (when copying) now don't bother to update the
5185   destination if the resulting timestamp would be no newer than the
5186   preexisting timestamp.  This saves work in the common case when
5187   copying or moving multiple times to the same destination in a file
5188   system with a coarse timestamp resolution.
5190   cut accepts a new option, --complement, to complement the set of
5191   selected bytes, characters, or fields.
5193   dd now also prints the number of bytes transferred, the time, and the
5194   transfer rate.  The new "status=noxfer" operand suppresses this change.
5196   dd has new conversions for the conv= option:
5198     nocreat   do not create the output file
5199     excl      fail if the output file already exists
5200     fdatasync physically write output file data before finishing
5201     fsync     likewise, but also write metadata
5203   dd has new iflag= and oflag= options with the following flags:
5205     append    append mode (makes sense for output file only)
5206     direct    use direct I/O for data
5207     dsync     use synchronized I/O for data
5208     sync      likewise, but also for metadata
5209     nonblock  use non-blocking I/O
5210     nofollow  do not follow symlinks
5211     noctty    do not assign controlling terminal from file
5213   stty now provides support (iutf8) for setting UTF-8 input mode.
5215   With stat, a specified format is no longer automatically newline terminated.
5216   If you want a newline at the end of your output, append '\n' to the format
5217   string.
5219   'df', 'du', and 'ls' now take the default block size from the
5220   BLOCKSIZE environment variable if the BLOCK_SIZE, DF_BLOCK_SIZE,
5221   DU_BLOCK_SIZE, and LS_BLOCK_SIZE environment variables are not set.
5222   Unlike the other variables, though, BLOCKSIZE does not affect
5223   values like 'ls -l' sizes that are normally displayed as bytes.
5224   This new behavior is for compatibility with BSD.
5226   du accepts a new option --files0-from=FILE, where FILE contains a
5227   list of NUL-terminated file names.
5229   Date syntax as used by date -d, date -f, and touch -d has been
5230   changed as follows:
5232     Dates like 'January 32' with out-of-range components are now rejected.
5234     Dates can have fractional timestamps like 2004-02-27 14:19:13.489392193.
5236     Dates can be entered via integer counts of seconds since 1970 when
5237     prefixed by '@'.  For example, '@321' represents 1970-01-01 00:05:21 UTC.
5239     Time zone corrections can now separate hours and minutes with a colon,
5240     and can follow standard abbreviations like "UTC".  For example,
5241     "UTC +0530" and "+05:30" are supported, and are both equivalent to "+0530".
5243     Date values can now have leading TZ="..." assignments that override
5244     the environment only while that date is being processed.  For example,
5245     the following shell command converts from Paris to New York time:
5247       TZ="America/New_York" date --date='TZ="Europe/Paris" 2004-10-31 06:30'
5249   'date' has a new option --iso-8601=ns that outputs
5250   nanosecond-resolution timestamps.
5252   echo -e '\xHH' now outputs a byte whose hexadecimal value is HH,
5253   for compatibility with bash.
5255   ls now exits with status 1 on minor problems, 2 if serious trouble.
5257   ls has a new --hide=PATTERN option that behaves like
5258   --ignore=PATTERN, except that it is overridden by -a or -A.
5259   This can be useful for aliases, e.g., if lh is an alias for
5260   "ls --hide='*~'", then "lh -A" lists the file "README~".
5262   In the following cases POSIX allows the default GNU behavior,
5263   so when POSIXLY_CORRECT is set:
5265     false, printf, true, unlink, and yes all support --help and --option.
5266     ls supports TABSIZE.
5267     pr no longer depends on LC_TIME for the date format in non-POSIX locales.
5268     printf supports \u, \U, \x.
5269     tail supports two or more files when using the obsolete option syntax.
5271   The usual '--' operand is now supported by chroot, hostid, hostname,
5272   pwd, sync, and yes.
5274   'od' now conforms to POSIX better, and is more compatible with BSD:
5276     The older syntax "od [-abcdfilosx]... [FILE] [[+]OFFSET[.][b]]" now works
5277     even without --traditional.  This is a change in behavior if there
5278     are one or two operands and the last one begins with +, or if
5279     there are two operands and the latter one begins with a digit.
5280     For example, "od foo 10" and "od +10" now treat the last operand as
5281     an offset, not as a file name.
5283     -h is no longer documented, and may be withdrawn in future versions.
5284     Use -x or -t x2 instead.
5286     -i is now equivalent to -t dI (not -t d2), and
5287     -l is now equivalent to -t dL (not -t d4).
5289     -s is now equivalent to -t d2.  The old "-s[NUM]" or "-s NUM"
5290     option has been renamed to "-S NUM".
5292     The default output format is now -t oS, not -t o2, i.e., short int
5293     rather than two-byte int.  This makes a difference only on hosts like
5294     Cray systems where the C short int type requires more than two bytes.
5296   readlink accepts new options: --canonicalize-existing (-e)
5297   and --canonicalize-missing (-m).
5299   The stat option --filesystem has been renamed to --file-system, for
5300   consistency with POSIX "file system" and with cp and du --one-file-system.
5302 ** Removed features
5304   md5sum and sha1sum's undocumented --string option has been removed.
5306   tail's undocumented --max-consecutive-size-changes option has been removed.
5308 * Major changes in release 5.2.1 (2004-03-12) [stable]
5310 ** Bug fixes
5312   mv could mistakenly fail to preserve hard links when moving two
5313   or more arguments between partitions.
5315   'cp --sparse=always F /dev/hdx' no longer tries to use lseek to create
5316   holes in the destination.
5318   nohup now sets the close-on-exec flag for its copy of the stderr file
5319   descriptor.  This avoids some nohup-induced hangs.  For example, before
5320   this change, if you ran 'ssh localhost', then 'nohup sleep 600 </dev/null &',
5321   and then exited that remote shell, the ssh session would hang until the
5322   10-minute sleep terminated.  With the fixed nohup, the ssh session
5323   terminates immediately.
5325   'expr' now conforms to POSIX better:
5327     Integers like -0 and 00 are now treated as zero.
5329     The '|' operator now returns 0, not its first argument, if both
5330     arguments are null or zero.  E.g., 'expr "" \| ""' now returns 0,
5331     not the empty string.
5333     The '|' and '&' operators now use short-circuit evaluation, e.g.,
5334     'expr 1 \| 1 / 0' no longer reports a division by zero.
5336 ** New features
5338   'chown user.group file' now has its traditional meaning even when
5339   conforming to POSIX 1003.1-2001, so long as no user has a name
5340   containing '.' that happens to equal 'user.group'.
5343 * Major changes in release 5.2.0 (2004-02-19) [stable]
5345 ** Bug fixes
5347   none
5350 * Major changes in release 5.1.3 (2004-02-08): candidate to become stable 5.2.0
5352 ** Bug fixes
5354   'cp -d' now works as required even on systems like OSF V5.1 that
5355   declare stat and lstat as 'static inline' functions.
5357   timestamps output by stat now include actual fractional seconds,
5358   when available -- or .0000000 for files without that information.
5360   seq no longer infloops when printing 2^31 or more numbers.
5361   For reference, seq `echo 2^31|bc` > /dev/null takes about one hour
5362   on a 1.6 GHz Athlon 2000 XP.  Now it can output 2^53-1 numbers before
5363   misbehaving.
5365 * Major changes in release 5.1.2 (2004-01-25):
5367 ** Bug fixes
5369   rmdir -p exits with status 1 on error; formerly it sometimes exited
5370   with status 0 when given more than one argument.
5372   nohup now always exits with status 127 when it finds an error,
5373   as POSIX requires; formerly it sometimes exited with status 1.
5375   Several programs (including cut, date, dd, env, hostname, nl, pr,
5376   stty, and tr) now always exit with status 1 when they find an error;
5377   formerly they sometimes exited with status 2.
5379   factor no longer reports a usage error if stdin has the wrong format.
5381   paste no longer infloops on ppc systems (bug introduced in 5.1.1)
5384 * Major changes in release 5.1.1 (2004-01-17):
5386 ** Configuration option
5388   You can select the default level of POSIX conformance at configure-time,
5389   e.g., by ./configure DEFAULT_POSIX2_VERSION=199209
5391 ** Bug fixes
5393   fold -s works once again on systems with differing sizes for int
5394   and size_t (bug introduced in 5.1.0)
5396 ** New features
5398   touch -r now specifies the origin for any relative times in the -d
5399   operand, if both options are given.  For example, "touch -r FOO -d
5400   '-5 seconds' BAR" sets BAR's modification time to be five seconds
5401   before FOO's.
5403   join: The obsolete options "-j1 FIELD", "-j2 FIELD", and
5404   "-o LIST1 LIST2..." are no longer supported on POSIX 1003.1-2001 systems.
5405   Portable scripts should use "-1 FIELD", "-2 FIELD", and
5406   "-o LIST1,LIST2..." respectively.  If join was compiled on a
5407   POSIX 1003.1-2001 system, you may enable the old behavior
5408   by setting _POSIX2_VERSION=199209 in your environment.
5409   [This change was reverted in coreutils 5.3.1.]
5412 * Major changes in release 5.1.0 (2003-12-21):
5414 ** New features
5416   chgrp, chmod, and chown can now process (with -R) hierarchies of virtually
5417   unlimited depth.  Before, they would fail to operate on any file they
5418   encountered with a relative name of length PATH_MAX (often 4096) or longer.
5420   chgrp, chmod, chown, and rm accept the new options:
5421   --preserve-root, --no-preserve-root (default)
5423   chgrp and chown now accept POSIX-mandated -L, -H, and -P options
5425   du can now process hierarchies of virtually unlimited depth.
5426   Before, du was limited by the user's stack size and it would get a
5427   stack overflow error (often a segmentation fault) when applied to
5428   a hierarchy of depth around 30,000 or larger.
5430   du works even when run from an inaccessible directory
5432   du -D now dereferences all symlinks specified on the command line,
5433   not just the ones that reference directories
5435   du now accepts -P (--no-dereference), for compatibility with du
5436   of NetBSD and for consistency with e.g., chown and chgrp
5438   du's -H option will soon have the meaning required by POSIX
5439   (--dereference-args, aka -D) rather then the current meaning of --si.
5440   Now, using -H elicits a warning to that effect.
5442   When given -l and similar options, ls now adjusts the output column
5443   widths to fit the data, so that output lines are shorter and have
5444   columns that line up better.  This may adversely affect shell
5445   scripts that expect fixed-width columns, but such shell scripts were
5446   not portable anyway, even with old GNU ls where the columns became
5447   ragged when a datum was too wide.
5449   du accepts a new option, -0/--null, to make it produce NUL-terminated
5450   output lines
5452 ** Bug fixes
5454   printf, seq, tail, and sleep now parse floating-point operands
5455   and options in the C locale.  POSIX requires this for printf.
5457   od -c -w9999999 no longer segfaults
5459   csplit no longer reads from freed memory (dumping core on some systems)
5461   csplit would mistakenly exhaust virtual memory in some cases
5463   ls --width=N (for very large N) is no longer subject to an address
5464   arithmetic bug that could result in bounds violations.
5466   ls --width=N (with -x or -C) no longer allocates more space
5467   (potentially much more) than necessary for a given directory.
5469   dd 'unblock' and 'sync' may now be combined (e.g., dd conv=unblock,sync)
5471 * Major changes in release 5.0.91 (2003-09-08):
5473 ** New features
5475   date accepts a new option --rfc-2822, an alias for --rfc-822.
5477   split accepts a new option -d or --numeric-suffixes.
5479   cp, install, mv, and touch now preserve microsecond resolution on
5480   file timestamps, on platforms that have the 'utimes' system call.
5481   Unfortunately there is no system call yet to preserve file
5482   timestamps to their full nanosecond resolution; microsecond
5483   resolution is the best we can do right now.
5485   sort now supports the zero byte (NUL) as a field separator; use -t '\0'.
5486   The -t '' option, which formerly had no effect, is now an error.
5488   sort option order no longer matters for the options -S, -d, -i, -o, and -t.
5489   Stronger options override weaker, and incompatible options are diagnosed.
5491   'sha1sum --check' now accepts the BSD format for SHA1 message digests
5492   in addition to the BSD format for MD5 ones.
5494   who -l now means 'who --login', not 'who --lookup', per POSIX.
5495   who's -l option has been eliciting an unconditional warning about
5496   this impending change since sh-utils-2.0.12 (April 2002).
5498 ** Bug fixes
5500   Mistakenly renaming a file onto itself, e.g., via 'mv B b' when 'B' is
5501   the same directory entry as 'b' no longer destroys the directory entry
5502   referenced by both 'b' and 'B'.  Note that this would happen only on
5503   file systems like VFAT where two different names may refer to the same
5504   directory entry, usually due to lower->upper case mapping of file names.
5505   Now, the above can happen only on file systems that perform name mapping and
5506   that support hard links (stat.st_nlink > 1).  This mitigates the problem
5507   in two ways: few file systems appear to be affected (hpfs and ntfs are),
5508   when the bug is triggered, mv no longer removes the last hard link to a file.
5509   *** ATTENTION ***: if you know how to distinguish the following two cases
5510   without writing to the file system in question, please let me know:
5511   1) B and b refer to the same directory entry on a file system like NTFS
5512        (B may well have a link count larger than 1)
5513   2) B and b are hard links to the same file
5515   stat no longer overruns a buffer for format strings ending in '%'
5517   fold -s -wN would infloop for N < 8 with TABs in the input.
5518   E.g., this would not terminate: printf 'a\t' | fold -w2 -s
5520   'split -a0', although of questionable utility, is accepted once again.
5522   'df DIR' used to hang under some conditions on OSF/1 5.1.  Now it doesn't.
5524   seq's --width (-w) option now works properly even when the endpoint
5525   requiring the larger width is negative and smaller than the other endpoint.
5527   seq's default step is 1, even if LAST < FIRST.
5529   paste no longer mistakenly outputs 0xFF bytes for a nonempty input file
5530   without a trailing newline.
5532   'tail -n0 -f FILE' and 'tail -c0 -f FILE' no longer perform what amounted
5533   to a busy wait, rather than sleeping between iterations.
5535   tail's long-undocumented --allow-missing option now elicits a warning
5538 * Major changes in release 5.0.90 (2003-07-29):
5540 ** New features
5542   sort is now up to 30% more CPU-efficient in some cases
5544   'test' is now more compatible with Bash and POSIX:
5546     'test -t', 'test --help', and 'test --version' now silently exit
5547     with status 0.  To test whether standard output is a terminal, use
5548     'test -t 1'.  To get help and version info for 'test', use
5549     '[ --help' and '[ --version'.
5551     'test' now exits with status 2 (not 1) if there is an error.
5553   wc count field widths now are heuristically adjusted depending on the input
5554   size, if known.  If only one count is printed, it is guaranteed to
5555   be printed without leading spaces.
5557   Previously, wc did not align the count fields if POSIXLY_CORRECT was set,
5558   but POSIX did not actually require this undesirable behavior, so it
5559   has been removed.
5561 ** Bug fixes
5563   kill no longer tries to operate on argv[0] (introduced in 5.0.1)
5564   Why wasn't this noticed?  Although many tests use kill, none of
5565   them made an effort to avoid using the shell's built-in kill.
5567   '[' invoked with no arguments no longer evokes a segfault
5569   rm without --recursive (aka -r or -R) no longer prompts regarding
5570   unwritable directories, as required by POSIX.
5572   uniq -c now uses a SPACE, not a TAB between the count and the
5573   corresponding line, as required by POSIX.
5575   expr now exits with status 2 if the expression is syntactically valid,
5576   and with status 3 if an error occurred.  POSIX requires this.
5578   expr now reports trouble if string comparison fails due to a collation error.
5580   split now generates suffixes properly on EBCDIC hosts.
5582   split -a0 now works, as POSIX requires.
5584   'sort --version' and 'sort --help' fail, as they should
5585   when their output is redirected to /dev/full.
5587   'su --version > /dev/full' now fails, as it should.
5589 ** Fewer arbitrary limitations
5591   cut requires 97% less memory when very large field numbers or
5592   byte offsets are specified.
5595 * Major changes in release 5.0.1 (2003-07-15):
5597 ** New programs
5598 - new program: '[' (much like 'test')
5600 ** New features
5601 - head now accepts --lines=-N (--bytes=-N) to print all but the
5602   N lines (bytes) at the end of the file
5603 - md5sum --check now accepts the output of the BSD md5sum program, e.g.,
5604   MD5 (f) = d41d8cd98f00b204e9800998ecf8427e
5605 - date -d DATE can now parse a DATE string like May-23-2003
5606 - chown: '.' is no longer recognized as a separator in the OWNER:GROUP
5607   specifier on POSIX 1003.1-2001 systems.  If chown *was not* compiled
5608   on such a system, then it still accepts '.', by default.  If chown
5609   was compiled on a POSIX 1003.1-2001 system, then you may enable the
5610   old behavior by setting _POSIX2_VERSION=199209 in your environment.
5611 - chown no longer tries to preserve set-user-ID and set-group-ID bits;
5612   on some systems, the chown syscall resets those bits, and previous
5613   versions of the chown command would call chmod to restore the original,
5614   pre-chown(2) settings, but that behavior is problematic.
5615   1) There was a window whereby a malicious user, M, could subvert a
5616   chown command run by some other user and operating on files in a
5617   directory where M has write access.
5618   2) Before (and even now, on systems with chown(2) that doesn't reset
5619   those bits), an unwary admin. could use chown unwittingly to create e.g.,
5620   a set-user-ID root copy of /bin/sh.
5622 ** Bug fixes
5623 - chown --dereference no longer leaks a file descriptor per symlink processed
5624 - 'du /' once again prints the '/' on the last line
5625 - split's --verbose option works once again [broken in 4.5.10 and 5.0]
5626 - tail -f is no longer subject to a race condition that could make it
5627   delay displaying the last part of a file that had stopped growing.  That
5628   bug could also make tail -f give an unwarranted 'file truncated' warning.
5629 - du no longer runs out of file descriptors unnecessarily
5630 - df and 'readlink --canonicalize' no longer corrupt the heap on
5631   non-glibc, non-solaris systems
5632 - 'env -u UNSET_VARIABLE' no longer dumps core on non-glibc systems
5633 - readlink's --canonicalize option now works on systems like Solaris that
5634   lack the canonicalize_file_name function but do have resolvepath.
5635 - mv now removes 'a' in this example on all systems: touch a; ln a b; mv a b
5636   This behavior is contrary to POSIX (which requires that the mv command do
5637   nothing and exit successfully), but I suspect POSIX will change.
5638 - date's %r format directive now honors locale settings
5639 - date's '-' (no-pad) format flag now affects the space-padded-by-default
5640   conversion specifiers, %e, %k, %l
5641 - fmt now diagnoses invalid obsolescent width specifications like '-72x'
5642 - fmt now exits nonzero when unable to open an input file
5643 - tsort now fails when given an odd number of input tokens,
5644   as required by POSIX.  Before, it would act as if the final token
5645   appeared one additional time.
5647 ** Fewer arbitrary limitations
5648 - tail's byte and line counts are no longer limited to OFF_T_MAX.
5649   Now the limit is UINTMAX_MAX (usually 2^64).
5650 - split can now handle --bytes=N and --lines=N with N=2^31 or more.
5652 ** Portability
5653 - 'kill -t' now prints signal descriptions (rather than '?') on systems
5654   like Tru64 with __sys_siglist but no strsignal function.
5655 - stat.c now compiles on Ultrix systems
5656 - sleep now works on AIX systems that lack support for clock_gettime
5657 - rm now works around Darwin6.5's broken readdir function
5658   Before 'rm -rf DIR' would fail to remove all files in DIR
5659   if there were more than 338.
5661 * Major changes in release 5.0 (2003-04-02):
5662 - false --help now exits nonzero
5664 [4.5.12]
5665 * printf no longer treats \x specially when POSIXLY_CORRECT is set
5666 * printf avoids buffer overrun with format ending in a backslash and
5667 * printf avoids buffer overrun with incomplete conversion specifier
5668 * printf accepts multiple flags in a single conversion specifier
5670 [4.5.11]
5671 * seq no longer requires that a field width be specified
5672 * seq no longer fails when given a field width of '0'
5673 * seq now accepts " " and "'" as valid format flag characters
5674 * df now shows a HOSTNAME: prefix for each remote-mounted file system on AIX 5.1
5675 * portability tweaks for HP-UX, AIX 5.1, DJGPP
5677 [4.5.10]
5678 * printf no longer segfaults for a negative field width or precision
5679 * shred now always enables --exact for non-regular files
5680 * du no longer lists hard-linked files more than once
5681 * du no longer dumps core on some systems due to "infinite" recursion
5682   via nftw's use of the buggy replacement function in getcwd.c
5683 * portability patches for a few vendor compilers and 64-bit systems
5684 * du -S *really* now works like it did before the change in 4.5.5
5686 [4.5.9]
5687 * du no longer truncates file sizes or sums to fit in 32-bit size_t
5688 * work around Linux kernel bug in getcwd (fixed in 2.4.21-pre4), so that pwd
5689   now fails if the name of the working directory is so long that getcwd
5690   truncates it.  Before it would print the truncated name and exit successfully.
5691 * 'df /some/mount-point' no longer hangs on a GNU libc system when another
5692   hard-mounted NFS file system (preceding /some/mount-point in /proc/mounts)
5693   is inaccessible.
5694 * rm -rf now gives an accurate diagnostic when failing to remove a file
5695   under certain unusual conditions
5696 * mv and 'cp --preserve=links' now preserve multiple hard links even under
5697   certain unusual conditions where they used to fail
5699 [4.5.8]
5700 * du -S once again works like it did before the change in 4.5.5
5701 * stat accepts a new file format, %B, for the size of each block reported by %b
5702 * du accepts new option: --apparent-size
5703 * du --bytes (-b) works the same way it did in fileutils-3.16 and before
5704 * du reports proper sizes for directories (not zero) (broken in 4.5.6 or 4.5.7)
5705 * df now always displays under 'Filesystem', the device file name
5706   corresponding to the listed mount point.  Before, for a block- or character-
5707   special file command line argument, df would display that argument.  E.g.,
5708   'df /dev/hda' would list '/dev/hda' as the 'Filesystem', rather than say
5709   /dev/hda3 (the device on which '/' is mounted), as it does now.
5710 * test now works properly when invoked from a set user ID or set group ID
5711   context and when testing access to files subject to alternate protection
5712   mechanisms.  For example, without this change, a set-UID program that invoked
5713   'test -w F' (to see if F is writable) could mistakenly report that it *was*
5714   writable, even though F was on a read-only file system, or F had an ACL
5715   prohibiting write access, or F was marked as immutable.
5717 [4.5.7]
5718 * du would fail with more than one DIR argument when any but the last did not
5719   contain a slash (due to a bug in ftw.c)
5721 [4.5.6]
5722 * du no longer segfaults on Solaris systems (fixed heap-corrupting bug in ftw.c)
5723 * du --exclude=FILE works once again (this was broken by the rewrite for 4.5.5)
5724 * du no longer gets a failed assertion for certain hierarchy lay-outs
5725   involving hard-linked directories
5726 * 'who -r' no longer segfaults when using non-C-locale messages
5727 * df now displays a mount point (usually '/') for non-mounted
5728   character-special and block files
5730 [4.5.5]
5731 * ls --dired produces correct byte offset for file names containing
5732   nonprintable characters in a multibyte locale
5733 * du has been rewritten to use a variant of GNU libc's ftw.c
5734 * du now counts the space associated with a directory's directory entry,
5735   even if it cannot list or chdir into that subdirectory.
5736 * du -S now includes the st_size of each entry corresponding to a subdirectory
5737 * rm on FreeBSD can once again remove directories from NFS-mounted file systems
5738 * ls has a new option --dereference-command-line-symlink-to-dir, which
5739   corresponds to the new default behavior when none of -d, -l -F, -H, -L
5740   has been specified.
5741 * ls dangling-symlink now prints 'dangling-symlink'.
5742   Before, it would fail with 'no such file or directory'.
5743 * ls -s symlink-to-non-dir and ls -i symlink-to-non-dir now print
5744   attributes of 'symlink', rather than attributes of their referents.
5745 * Fix a bug introduced in 4.5.4 that made it so that ls --color would no
5746   longer highlight the names of files with the execute bit set when not
5747   specified on the command line.
5748 * shred's --zero (-z) option no longer gobbles up any following argument.
5749   Before, 'shred --zero file' would produce 'shred: missing file argument',
5750   and worse, 'shred --zero f1 f2 ...' would appear to work, but would leave
5751   the first file untouched.
5752 * readlink: new program
5753 * cut: new feature: when used to select ranges of byte offsets (as opposed
5754   to ranges of fields) and when --output-delimiter=STRING is specified,
5755   output STRING between ranges of selected bytes.
5756 * rm -r can no longer be tricked into mistakenly reporting a cycle.
5757 * when rm detects a directory cycle, it no longer aborts the entire command,
5758   but rather merely stops processing the affected command line argument.
5760 [4.5.4]
5761 * cp no longer fails to parse options like this: --preserve=mode,ownership
5762 * 'ls --color -F symlink-to-dir' works properly
5763 * ls is much more efficient on directories with valid dirent.d_type.
5764 * stty supports all baud rates defined in linux-2.4.19.
5765 * 'du symlink-to-dir/' would improperly remove the trailing slash
5766 * 'du ""' would evoke a bounds violation.
5767 * In the unlikely event that running 'du /' resulted in 'stat ("/", ...)'
5768   failing, du would give a diagnostic about '' (empty string) rather than '/'.
5769 * printf: a hexadecimal escape sequence has at most two hex. digits, not three.
5770 * The following features have been added to the --block-size option
5771   and similar environment variables of df, du, and ls.
5772   - A leading "'" generates numbers with thousands separators.
5773     For example:
5774       $ ls -l --block-size="'1" file
5775       -rw-rw-r--    1 eggert   src      47,483,707 Sep 24 23:40 file
5776   - A size suffix without a leading integer generates a suffix in the output.
5777     For example:
5778       $ ls -l --block-size="K"
5779       -rw-rw-r--    1 eggert   src          46371K Sep 24 23:40 file
5780 * ls's --block-size option now affects file sizes in all cases, not
5781   just for --block-size=human-readable and --block-size=si.  Fractional
5782   sizes are now always rounded up, for consistency with df and du.
5783 * df now displays the block size using powers of 1000 if the requested
5784   block size seems to be a multiple of a power of 1000.
5785 * nl no longer gets a segfault when run like this 'yes|nl -s%n'
5787 [4.5.3]
5788 * du --dereference-args (-D) no longer fails in certain cases
5789 * 'ln --target-dir=DIR' no longer fails when given a single argument
5791 [4.5.2]
5792 * 'rm -i dir' (without --recursive (-r)) no longer recurses into dir
5793 * 'tail -c N FILE' now works with files of size >= 4GB
5794 * 'mkdir -p' can now create very deep (e.g. 40,000-component) directories
5795 * rmdir -p dir-with-trailing-slash/ no longer fails
5796 * printf now honors the '--' command line delimiter
5797 * od's 8-byte formats x8, o8, and u8 now work
5798 * tail now accepts fractional seconds for its --sleep-interval=S (-s) option
5800 [4.5.1]
5801 * du and ls now report sizes of symbolic links (before they'd always report 0)
5802 * uniq now obeys the LC_COLLATE locale, as per POSIX 1003.1-2001 TC1.
5804 ========================================================================
5805 Here are the NEWS entries made from fileutils-4.1 until the
5806 point at which the packages merged to form the coreutils:
5808 [4.1.11]
5809 * 'rm symlink-to-unwritable' doesn't prompt [introduced in 4.1.10]
5810 [4.1.10]
5811 * rm once again gives a reasonable diagnostic when failing to remove a file
5812     owned by someone else in a sticky directory [introduced in 4.1.9]
5813 * df now rounds all quantities up, as per POSIX.
5814 * New ls time style: long-iso, which generates YYYY-MM-DD HH:MM.
5815 * Any time style can be preceded by "posix-"; this causes "ls" to
5816   use traditional timestamp format when in the POSIX locale.
5817 * The default time style is now posix-long-iso instead of posix-iso.
5818   Set TIME_STYLE="posix-iso" to revert to the behavior of 4.1.1 through 4.1.9.
5819 * 'rm dangling-symlink' doesn't prompt [introduced in 4.1.9]
5820 * stat: remove support for --secure/-s option and related %S and %C format specs
5821 * stat: rename --link/-l to --dereference/-L.
5822     The old options will continue to work for a while.
5823 [4.1.9]
5824 * rm can now remove very deep hierarchies, in spite of any limit on stack size
5825 * new programs: link, unlink, and stat
5826 * New ls option: --author (for the Hurd).
5827 * 'touch -c no-such-file' no longer fails, per POSIX
5828 [4.1.8]
5829 * mv no longer mistakenly creates links to preexisting destination files
5830     that aren't moved
5831 [4.1.7]
5832 * rm: close a hole that would allow a running rm process to be subverted
5833 [4.1.6]
5834 * New cp option: --copy-contents.
5835 * cp -r is now equivalent to cp -R.  Use cp -R -L --copy-contents to get the
5836   traditional (and rarely desirable) cp -r behavior.
5837 * ls now accepts --time-style=+FORMAT, where +FORMAT works like date's format
5838 * The obsolete usage 'touch [-acm] MMDDhhmm[YY] FILE...' is no longer
5839   supported on systems conforming to POSIX 1003.1-2001.  Use touch -t instead.
5840 * cp and inter-partition mv no longer give a misleading diagnostic in some
5841     unusual cases
5842 [4.1.5]
5843 * cp -r no longer preserves symlinks
5844 * The block size notation is now compatible with SI and with IEC 60027-2.
5845   For example, --block-size=1MB now means --block-size=1000000,
5846   whereas --block-size=1MiB now means --block-size=1048576.
5847   A missing 'B' (e.g. '1M') has the same meaning as before.
5848   A trailing 'B' now means decimal, not binary; this is a silent change.
5849   The nonstandard 'D' suffix (e.g. '1MD') is now obsolescent.
5850 * -H or --si now outputs the trailing 'B', for consistency with the above.
5851 * Programs now output trailing 'K' (not 'k') to mean 1024, as per IEC 60027-2.
5852 * New df, du short option -B is short for --block-size.
5853 * You can omit an integer '1' before a block size suffix,
5854   e.g. 'df -BG' is equivalent to 'df -B 1G' and to 'df --block-size=1G'.
5855 * The following options are now obsolescent, as their names are
5856   incompatible with IEC 60027-2:
5857    df, du: -m or --megabytes (use -BM or --block-size=1M)
5858    df, du, ls: --kilobytes (use --block-size=1K)
5859 [4.1.4]
5860 * df --local no longer lists smbfs file systems whose name starts with //
5861 * dd now detects the Linux/tape/lseek bug at run time and warns about it.
5862 [4.1.3]
5863 * ls -R once again outputs a blank line between per-directory groups of files.
5864     This was broken by the cycle-detection change in 4.1.1.
5865 * dd once again uses 'lseek' on character devices like /dev/mem and /dev/kmem.
5866     On systems with the linux kernel (at least up to 2.4.16), dd must still
5867     resort to emulating 'skip=N' behavior using reads on tape devices, because
5868     lseek has no effect, yet appears to succeed.  This may be a kernel bug.
5869 [4.1.2]
5870 * cp no longer fails when two or more source files are the same;
5871     now it just gives a warning and doesn't copy the file the second time.
5872     E.g., cp a a d/ produces this:
5873     cp: warning: source file `a' specified more than once
5874 * chmod would set the wrong bit when given symbolic mode strings like
5875     these: g=o, o=g, o=u.  E.g., 'chmod a=,o=w,ug=o f' would give a mode
5876     of --w-r---w- rather than --w--w--w-.
5877 [4.1.1]
5878 * mv (likewise for cp), now fails rather than silently clobbering one of
5879     the source files in the following example:
5880     rm -rf a b c; mkdir a b c; touch a/f b/f; mv a/f b/f c
5881 * ls -R detects directory cycles, per POSIX.  It warns and doesn't infloop.
5882 * cp's -P option now means the same as --no-dereference, per POSIX.
5883     Use --parents to get the old meaning.
5884 * When copying with the -H and -L options, cp can preserve logical
5885     links between source files with --preserve=links
5886 * cp accepts new options:
5887     --preserve[={mode,ownership,timestamps,links,all}]
5888     --no-preserve={mode,ownership,timestamps,links,all}
5889 * cp's -p and --preserve options remain unchanged and are equivalent
5890     to '--preserve=mode,ownership,timestamps'
5891 * mv and cp accept a new option: --reply={yes,no,query};  provides a consistent
5892     mechanism to control whether one is prompted about certain existing
5893     destination files.  Note that cp's and mv's -f options don't have the
5894     same meaning: cp's -f option no longer merely turns off '-i'.
5895 * remove portability limitations (e.g., PATH_MAX on the Hurd, fixes for
5896     64-bit systems)
5897 * mv now prompts before overwriting an existing, unwritable destination file
5898     when stdin is a tty, unless --force (-f) is specified, as per POSIX.
5899 * mv: fix the bug whereby 'mv -uf source dest' would delete source,
5900     even though it's older than dest.
5901 * chown's --from=CURRENT_OWNER:CURRENT_GROUP option now works
5902 * cp now ensures that the set-user-ID and set-group-ID bits are cleared for
5903     the destination file when when copying and not preserving permissions.
5904 * 'ln -f --backup k k' gives a clearer diagnostic
5905 * ls no longer truncates user names or group names that are longer
5906     than 8 characters.
5907 * ls's new --dereference-command-line option causes it to dereference
5908   symbolic links on the command-line only.  It is the default unless
5909   one of the -d, -F, or -l options are given.
5910 * ls -H now means the same as ls --dereference-command-line, as per POSIX.
5911 * ls -g now acts like ls -l, except it does not display owner, as per POSIX.
5912 * ls -n now implies -l, as per POSIX.
5913 * ls can now display dates and times in one of four time styles:
5915   - The 'full-iso' time style gives full ISO-style timestamps like
5916     '2001-05-14 23:45:56.477817180 -0700'.
5917   - The 'iso' time style gives ISO-style timestamps like '2001-05-14 '
5918     and '05-14 23:45'.
5919   - The 'locale' time style gives locale-dependent timestamps like
5920     'touko  14  2001' and 'touko  14 23:45' (in a Finnish locale).
5921   - The 'posix-iso' time style gives traditional POSIX-locale
5922     timestamps like 'May 14  2001' and 'May 14 23:45' unless the user
5923     specifies a non-POSIX locale, in which case it uses ISO-style dates.
5924     This is the default.
5926   You can specify a time style with an option like --time-style='iso'
5927   or with an environment variable like TIME_STYLE='iso'.  GNU Emacs 21
5928   and later can parse ISO dates, but older Emacs versions cannot, so
5929   if you are using an older version of Emacs outside the default POSIX
5930   locale, you may need to set TIME_STYLE="locale".
5932 * --full-time is now an alias for "-l --time-style=full-iso".
5935 ========================================================================
5936 Here are the NEWS entries made from sh-utils-2.0 until the
5937 point at which the packages merged to form the coreutils:
5939  [2.0.15]
5940 * date no longer accepts e.g., September 31 in the MMDDhhmm syntax
5941 * fix a bug in this package's .m4 files and in configure.ac
5942  [2.0.14]
5943 * nohup's behavior is changed as follows, to conform to POSIX 1003.1-2001:
5944   - nohup no longer adjusts scheduling priority; use "nice" for that.
5945   - nohup now redirects stderr to stdout, if stderr is not a terminal.
5946   - nohup exit status is now 126 if command was found but not invoked,
5947     127 if nohup failed or if command was not found.
5948  [2.0.13]
5949 * uname and uptime work better on *BSD systems
5950 * pathchk now exits nonzero for a path with a directory component
5951     that specifies a non-directory
5952  [2.0.12]
5953 * kill: new program
5954 * who accepts new options: --all (-a), --boot (-b), --dead (-d), --login,
5955    --process (-p), --runlevel (-r), --short (-s), --time (-t), --users (-u).
5956    The -u option now produces POSIX-specified results and is the same as
5957    the long option '--users'.  --idle is no longer the same as -u.
5958 * The following changes apply on systems conforming to POSIX 1003.1-2001:
5959    - 'date -I' is no longer supported.  Instead, use 'date --iso-8601'.
5960    - 'nice -NUM' is no longer supported.  Instead, use 'nice -n NUM'.
5961   [This change was reverted in coreutils 5.3.1.]
5962 * New 'uname' options -i or --hardware-platform, and -o or --operating-system.
5963    'uname -a' now outputs -i and -o information at the end.
5964    New uname option --kernel-version is an alias for -v.
5965    Uname option --release has been renamed to --kernel-release,
5966    and --sysname has been renamed to --kernel-name;
5967    the old options will work for a while, but are no longer documented.
5968 * 'expr' now uses the LC_COLLATE locale for string comparison, as per POSIX.
5969 * 'expr' now requires '+' rather than 'quote' to quote tokens;
5970     this removes an incompatibility with POSIX.
5971 * date -d 'last friday' would print a date/time that was one hour off
5972     (e.g., 23:00 on *thursday* rather than 00:00 of the preceding friday)
5973     when run such that the current time and the target date/time fall on
5974     opposite sides of a daylight savings time transition.
5975     This problem arose only with relative date strings like 'last monday'.
5976     It was not a problem with strings that include absolute dates.
5977 * factor is twice as fast, for large numbers
5978  [2.0.11]
5979 * setting the date now works properly, even when using -u
5980 * 'date -f - < /dev/null' no longer dumps core
5981 * some DOS/Windows portability changes
5982  [2.0j]
5983 * 'date -d DATE' now parses certain relative DATEs correctly
5984  [2.0i]
5985 * fixed a bug introduced in 2.0h that made many programs fail with a
5986  'write error' when invoked with the --version option
5987  [2.0h]
5988 * all programs fail when printing --help or --version output to a full device
5989 * printf exits nonzero upon write failure
5990 * yes now detects and terminates upon write failure
5991 * date --rfc-822 now always emits day and month names from the 'C' locale
5992 * portability tweaks for Solaris8, Ultrix, and DOS
5993  [2.0g]
5994 * date now handles two-digit years with leading zeros correctly.
5995 * printf interprets unicode, \uNNNN \UNNNNNNNN, on systems with the
5996   required support;  from Bruno Haible.
5997 * stty's rprnt attribute now works on HPUX 10.20
5998 * seq's --equal-width option works more portably
5999  [2.0f]
6000 * fix build problems with ut_name vs. ut_user
6001  [2.0e]
6002 * stty: fix long-standing bug that caused test failures on at least HPUX
6003   systems when COLUMNS was set to zero
6004 * still more portability fixes
6005 * unified lib/: now that directory and most of the configuration framework
6006   is common between fileutils, textutils, and sh-utils
6007  [2.0d]
6008 * fix portability problem with sleep vs lib/strtod.c's requirement for -lm
6009  [2.0c]
6010 * fix portability problems with nanosleep.c and with the new code in sleep.c
6011  [2.0b]
6012 * Regenerate lib/Makefile.in so that nanosleep.c is distributed.
6013  [2.0a]
6014 * sleep accepts floating point arguments on command line
6015 * sleep's clock continues counting down when sleep is suspended
6016 * when a suspended sleep process is resumed, it continues sleeping if
6017   there is any time remaining
6018 * who once again prints whatever host information it has, even without --lookup
6020 ========================================================================
6021 For older NEWS entries for the fileutils, textutils, and sh-utils
6022 packages, see ./old/*/NEWS.
6024   This package began as the union of the following:
6025   textutils-2.1, fileutils-4.1.11, sh-utils-2.0.15.
6027 ========================================================================
6029 Copyright (C) 2001-2025 Free Software Foundation, Inc.
6031 Permission is granted to copy, distribute and/or modify this document
6032 under the terms of the GNU Free Documentation License, Version 1.3 or
6033 any later version published by the Free Software Foundation; with no
6034 Invariant Sections, with no Front-Cover Texts, and with no Back-Cover
6035 Texts.  A copy of the license is included in the "GNU Free
6036 Documentation License" file as part of this distribution.