tr: pacify -fsanitizer=leak
[coreutils.git] / NEWS
blob711f7811a05aca4b6803e73c40371c930acfac39
1 GNU coreutils NEWS                                    -*- outline -*-
3 * Noteworthy changes in release ?.? (????-??-??) [?]
5 ** Bug fixes
7   chmod -R no longer exits with error status when encountering symlinks.
8   All files would be processed correctly, but the exit status was incorrect.
9   [bug introduced in coreutils-9.0]
11   If 'cp -Z A B' checks B's status and some other process then removes B,
12   cp no longer creates B with a too-generous SELinux security context
13   before adjusting it to the correct value.
14   [bug introduced in coreutils-8.17]
16   'cp --preserve=ownership A B' no longer ignores the umask when creating B.
17   Also, 'cp --preserve-xattr A B' is less likely to temporarily chmod u+w B.
18   [bug introduced in coreutils-6.7]
20   On macOS, 'cp A B' no longer miscopies when A is in an APFS file system
21   and B is in some other file system.
22   [bug introduced in coreutils-9.0]
24   On macOS, 'mv A B' no longer fails with "Operation not supported"
25   when A and B are in the same tmpfs file system.
26   [bug introduced in coreutils-9.0]
28   'mv -T --backup=numbered A B/' no longer miscalculates the backup number
29   for B when A is a directory, possibly inflooping.
30   [bug introduced in coreutils-6.3]
32   AIX builds no longer fail because some library functions are not found.
33   [bug introduced in coreutils-8.32]
35 ** Changes in behavior
37   cat now uses the copy_file_range syscall if available, when doing
38   simple copies between regular files.  This may be more efficient, by avoiding
39   user space copies, and possibly employing copy offloading or reflinking.
41   date +'%-N' now suppresses excess trailing digits, instead of always
42   padding them with zeros to 9 digits.  It uses clock_getres and
43   clock_gettime to infer the clock resolution.
45   dd conv=fsync now synchronizes output even after a write error,
46   and similarly for dd conv=fdatasync.
48   timeout --foreground --kill-after=... will now exit with status 137
49   if the kill signal was sent, which is consistent with the behavior
50   when the --foreground option is not specified.  This allows users to
51   distinguish if the command was more forcefully terminated.
53 ** Improvements
55   cp, mv, and install now use openat-like syscalls when copying to a directory.
56   This avoids some race conditions and should be more efficient.
58   On macOS, cp creates a copy-on-write clone if source and destination
59   are regular files on the same APFS file system, the destination does
60   not already exist, and cp is preserving mode and timestamps (e.g.,
61   'cp -p', 'cp -a').
63   The new 'date' option --resolution outputs the timestamp resolution.
65   With conv=fdatasync or conv=fsync, dd status=progress now reports
66   any extra final progress just before synchronizing output data,
67   since synchronizing can take a long time.
69   sort --debug now diagnoses issues with --field-separator characters
70   that conflict with characters possibly used in numbers.
72   root invoked coreutils, that are built and run in single binary mode,
73   now adjust /proc/$pid/cmdline to be more specific to the utility
74   being run, rather than using the general "coreutils" binary name.
77 * Noteworthy changes in release 9.0 (2021-09-24) [stable]
79 ** Bug fixes
81   chmod -v no longer misreports modes of dangling symlinks.
82   [bug introduced in coreutils-5.3.0]
84   cp -a --attributes-only now never removes destination files,
85   even if the destination files are hardlinked, or the source
86   is a non regular file.
87   [bug introduced in coreutils-8.6]
89   csplit --suppress-matched now elides the last matched line
90   when a specific number of pattern matches are performed.
91   [bug introduced with the --suppress-matched feature in coreutils-8.22]
93   df no longer outputs duplicate remote mounts in the presence of bind mounts.
94   [bug introduced in coreutils-8.26]
96   df no longer mishandles command-line args that it pre-mounts
97   [bug introduced in coreutils-8.29]
99   du no longer crashes on XFS file systems when the directory hierarchy is
100   heavily changed during the run.
101   [bug introduced in coreutils-8.25]
103   env -S no longer crashes when given unusual whitespace characters
104   [bug introduced in coreutils-8.30]
106   expr no longer mishandles unmatched \(...\) in regular expressions.
107   [bug introduced in coreutils-6.0]
109   ls no longer crashes when printing the SELinux context for unstatable files.
110   [bug introduced in coreutils-6.9.91]
112   mkdir -m no longer mishandles modes more generous than the umask.
113   [bug introduced in coreutils-8.22]
115   nl now handles single character --section-delimiter arguments,
116   by assuming a second ':' character has been specified, as specified by POSIX.
117   [This bug was present in "the beginning".]
119   pr again adjusts tabs in input, to maintain alignment in multi column output.
120   [bug introduced in coreutils-6.9]
122   rm no longer skips an extra file when the removal of an empty directory fails.
123   [bug introduced by the rewrite to use fts in coreutils-8.0]
125   split --number=K/N will again correctly split chunk K of N to stdout.
126   Previously a chunk starting after 128KiB, output the wrong part of the file.
127   [bug introduced in coreutils-8.26]
129   tail -f no longer overruns a stack buffer when given too many files
130   to follow and ulimit -n exceeds 1024.
131   [bug introduced in coreutils-7.5]
133   tr no longer crashes when using --complement with certain
134   invalid combinations of case character classes.
135   [bug introduced in coreutils-8.6]
137   basenc --base64 --decode no longer silently discards decoded characters
138   on (1024*5) buffer boundaries
139   [bug introduced in coreutils-8.31]
141 ** Changes in behavior
143   cp and install now default to copy-on-write (COW) if available.
145   cp, install and mv now use the copy_file_range syscall if available.
146   Also, they use lseek+SEEK_HOLE rather than ioctl+FS_IOC_FIEMAP on sparse
147   files, as lseek is simpler and more portable.
149   On GNU/Linux systems, ls no longer issues an error message on a
150   directory merely because it was removed.  This reverts a change
151   that was made in release 8.32.
153   ptx -T no longer attempts to substitute old-fashioned TeX escapes
154   for 8-bit non-ASCII alphabetic characters.  TeX indexes should
155   instead use '\usepackage[latin1]{inputenc}' or equivalent.
157   stat will use decomposed (major,minor) device numbers in its default format.
158   This is less ambiguous, and more consistent with ls.
160   sum [-r] will output a file name, even if only a single name is passed.
161   This is consistent with sum -s, cksum, and other sum(1) implementations.
163 ** New Features
165   cksum now supports the -a (--algorithm) option to select any
166   of the existing sum, md5sum, b2sum, sha*sum implementations etc.
167   cksum now subsumes all of these programs, and coreutils
168   will introduce no future standalone checksum utility.
170   cksum -a now supports the 'sm3' argument, to use the SM3 digest algorithm.
172   cksum --check now supports auto detecting the digest type to use,
173   when verifying tagged format checksums.
175   expr and factor now support bignums on all platforms.
177   ls --classify now supports the "always", "auto", or "never" flags,
178   to support only outputting classifier characters if connected to a tty.
180   ls now accepts the --sort=width option, to sort by file name width.
181   This is useful to more compactly organize the default vertical column output.
183   ls now accepts the --zero option, to terminate each output line with
184   NUL instead of newline.
186   nl --line-increment can now take a negative number to decrement the count.
188   stat supports more formats for representing decomposed device numbers.
189   %Hd,%Ld and %Hr,%Lr will output major,minor device numbers and device types
190   respectively.  %d corresponds to st_dev and %r to std_rdev.
192 ** Improvements
194   cat --show-ends will now show \r\n as ^M$.  Previously the \r was taken
195   literally, thus overwriting the first character in the line with '$'.
197   cksum [-a crc] is now up to 4 times faster by using a slice by 8 algorithm,
198   and at least 8 times faster where pclmul instructions are supported.
199   A new --debug option will indicate if pclmul is being used.
201   md5sum --check now supports checksum files with CRLF line endings.
202   This also applies to cksum, sha*sum, and b2sum.
204   df now recognizes these file systems as remote:
205   acfs, coda, fhgfs, gpfs, ibrix, ocfs2, and vxfs.
207   rmdir now clarifies the error if a symlink_to_dir/ has not been traversed.
208   This is the case on GNU/Linux systems, where the trailing slash is ignored.
210   stat and tail now know about the "devmem", "exfat", "secretmem", "vboxsf",
211   and "zonefs" file system types.  stat -f -c%T now reports the file system
212   type, and tail -f uses polling for "vboxsf" and inotify for the others.
214   timeout now supports sub-second timeouts on macOS.
216   wc is up to 5 times faster when counting only new line characters,
217   where avx2 instructions are supported.
218   A new --debug option will indicate if avx2 is being used.
221 * Noteworthy changes in release 8.32 (2020-03-05) [stable]
223 ** Bug fixes
225   cp now copies /dev/fd/N correctly on platforms like Solaris where
226   it is a character-special file whose minor device number is N.
227   [bug introduced in fileutils-4.1.6]
229   dd conv=fdatasync no longer reports a "Bad file descriptor" error
230   when fdatasync is interrupted, and dd now retries interrupted calls
231   to close, fdatasync, fstat and fsync instead of incorrectly
232   reporting an "Interrupted system call" error.
233   [bugs introduced in coreutils-6.0]
235   df now correctly parses the /proc/self/mountinfo file for unusual entries
236   like ones with '\r' in a field value ("mount -t tmpfs tmpfs /foo$'\r'bar"),
237   when the source field is empty ('mount -t tmpfs "" /mnt'), and when the
238   filesystem type contains characters like a blank which need escaping.
239   [bugs introduced in coreutils-8.24 with the introduction of reading
240    the /proc/self/mountinfo file]
242   factor again outputs immediately when stdout is a tty but stdin is not.
243   [bug introduced in coreutils-8.24]
245   ln works again on old systems without O_DIRECTORY support (like Solaris 10),
246   and on systems where symlink ("x", ".") fails with errno == EINVAL
247   (like Solaris 10 and Solaris 11).
248   [bug introduced in coreutils-8.31]
250   rmdir --ignore-fail-on-non-empty now works correctly for directories
251   that fail to be removed due to permission issues.  Previously the exit status
252   was reversed, failing for non empty and succeeding for empty directories.
253   [bug introduced in coreutils-6.11]
255   'shuf -r -n 0 file' no longer mistakenly reads from standard input.
256   [bug introduced with the --repeat feature in coreutils-8.22]
258   split no longer reports a "output file suffixes exhausted" error
259   when the specified number of files is evenly divisible by 10, 16, 26,
260   for --numeric, --hex, or default alphabetic suffixes respectively.
261   [bug introduced in coreutils-8.24]
263   seq no longer prints an extra line under certain circumstances (such as
264   'seq -f "%g " 1000000 1000000').
265   [bug introduced in coreutils-6.10]
267 ** Changes in behavior
269   Several programs now check that numbers end properly.  For example,
270   'du -d 1x' now reports an error instead of silently ignoring the 'x'.
271   Affected programs and options include du -d, expr's numeric operands
272   on non-GMP builds, install -g and -o, ls's TABSIZE environment
273   variable, mknod b and c, ptx -g and -w, shuf -n, and sort --batch-size
274   and --parallel.
276   date now parses military time zones in accordance with common usage:
277     "A" to "M"  are equivalent to UTC+1 to UTC+12
278     "N" to "Y"  are equivalent to UTC-1 to UTC-12
279     "Z" is "zulu" time (UTC).
280   For example, 'date -d "09:00B" is now equivalent to 9am in UTC+2 time zone.
281   Previously, military time zones were parsed according to the obsolete
282   rfc822, with their value negated (e.g., "B" was equivalent to UTC-2).
283   [The old behavior was introduced in sh-utils 2.0.15 ca. 1999, predating
284   coreutils package.]
286   date now pads nanoseconds on the right, not the left.  For example,
287   if the time is currently 1590020079.003388470 seconds after the
288   Epoch, then "date '+%s.%-N'" formerly output "1590020079.3388470",
289   and it now outputs "1590020079.00338847".
291   ls issues an error message on a removed directory, on GNU/Linux systems.
292   Previously no error and no entries were output, and so indistinguishable
293   from an empty directory, with default ls options.
295   uniq no longer uses strcoll() to determine string equivalence,
296   and so will operate more efficiently and consistently.
298 ** New Features
300   ls now supports the --time=birth option to display and sort by
301   file creation time, where available.
303   od --skip-bytes now can use lseek even if the input is not a regular
304   file, greatly improving performance in some cases.
306   stat(1) supports a new --cached= option, used on systems with statx(2)
307   to control cache coherency of file system attributes,
308   useful on network file systems.
310 ** Improvements
312   stat and ls now use the statx() system call where available, which can
313   operate more efficiently by only retrieving requested attributes.
315   stat and tail now know about the "binderfs", "dma-buf-fs", "erofs",
316   "ppc-cmm-fs", and "z3fold" file systems.
317   stat -f -c%T now reports the file system type, and tail -f uses inotify.
319 ** Build-related
321   gzip-compressed tarballs are distributed once again
324 * Noteworthy changes in release 8.31 (2019-03-10) [stable]
326 ** Bug fixes
328   'base64 a b' now correctly diagnoses 'b' as the extra operand, not 'a'.
329   [bug introduced in coreutils-5.3.0]
331   When B already exists, 'cp -il A B' no longer immediately fails
332   after asking the user whether to proceed.
333   [This bug was present in "the beginning".]
335   df no longer corrupts displayed multibyte characters on macOS.
336   [bug introduced with coreutils-8.18]
338   seq no longer outputs inconsistent decimal point characters
339   for the last number, when locales are misconfigured.
340   [bug introduced in coreutils-7.0]
342   shred, sort, and split no longer falsely report ftruncate errors
343   when outputting to less-common file types.  For example, the shell
344   command 'sort /dev/null -o /dev/stdout | cat' no longer fails with
345   an "error truncating" diagnostic.
346   [bug was introduced with coreutils-8.18 for sort and split, and
347    (for shared memory objects only) with fileutils-4.1 for shred]
349   sync no longer fails for write-only file arguments.
350   [bug introduced with argument support to sync in coreutils-8.24]
352   'tail -f file | filter' no longer exits immediately on AIX.
353   [bug introduced in coreutils-8.28]
355   'tail -f file | filter' no longer goes into an infinite loop
356   if filter exits and SIGPIPE is ignored.
357   [bug introduced in coreutils-8.28]
359 ** Changes in behavior
361   cksum, dd, hostid, hostname, link, logname, sleep, tsort, unlink,
362   uptime, users, whoami, yes: now always process --help and --version options,
363   regardless of any other arguments present before any optional '--'
364   end-of-options marker.
366   nohup now processes --help and --version as first options even if other
367   parameters follow.
369   'yes a -- b' now outputs 'a b' instead of including the end-of-options
370   marker as before: 'a -- b'.
372   echo now always processes backslash escapes when the POSIXLY_CORRECT
373   environment variable is set.
375   When possible 'ln A B' now merely links A to B and reports an error
376   if this fails, instead of statting A and B before linking.  This
377   uses fewer system calls and avoids some races.  The old statting
378   approach is still used in situations where hard links to directories
379   are allowed (e.g., NetBSD when superuser).
381   ls --group-directories-first will also group symlinks to directories.
383   'test -a FILE' is not supported anymore.  Long ago, there were concerns about
384   the high probability of humans confusing the -a primary with the -a binary
385   operator, so POSIX changed this to 'test -e FILE'.  Scripts using it were
386   already broken and non-portable; the -a unary operator was never documented.
388   wc now treats non breaking space characters as word delimiters
389   unless the POSIXLY_CORRECT environment variable is set.
391 ** New features
393   id now supports specifying multiple users.
395   'date' now supports the '+' conversion specification flag,
396   introduced in POSIX.1-2017.
398   printf, seq, sleep, tail, and timeout now accept floating point
399   numbers in either the current or the C locale.  For example, if the
400   current locale's decimal point is ',', 'sleep 0,1' and 'sleep 0.1'
401   now mean the same thing.  Previously, these commands accepted only
402   C-locale syntax with '.' as the decimal point.  The new behavior is
403   more compatible with other implementations in non-C locales.
405   test now supports the '-N FILE' unary operator (like e.g. bash) to check
406   whether FILE exists and has been modified since it was last read.
408   env now supports '--default-signal[=SIG]', '--ignore-signal[=SIG]', and
409   '--block-signal[=SIG], to setup signal handling before executing a program.
411   env now supports '--list-signal-handling' to indicate non-default
412   signal handling before executing a program.
414 ** New commands
416   basenc is added to complement existing base64,base32 commands,
417   and encodes and decodes printable text using various common encodings:
418   base64,base64url,base32,base32hex,base16,base2,z85.
420 ** Improvements
422   ls -l now better aligns abbreviated months containing digits,
423   which is common in Asian locales.
425   stat and tail now know about the "sdcardfs" file system on Android.
426   stat -f -c%T now reports the file system type, and tail -f uses inotify.
428   stat now prints file creation time when supported by the file system,
429   on GNU Linux systems with glibc >= 2.28 and kernel >= 4.11.
432 * Noteworthy changes in release 8.30 (2018-07-01) [stable]
434 ** Bug fixes
436   'cp --symlink SRC DST' will again correctly validate DST.
437   If DST is a regular file and SRC is a symlink to DST,
438   then cp will no longer allow that operation to clobber DST.
439   Also with -d, if DST is a symlink, then it can always be replaced,
440   even if it points to SRC on a separate device.
441   [bugs introduced with coreutils-8.27]
443   'cp -n -u' and 'mv -n -u' now consistently ignore the -u option.
444   Previously, this option combination suffered from race conditions
445   that caused -u to sometimes override -n.
446   [bug introduced with coreutils-7.1]
448   'cp -a --no-preserve=mode' now sets appropriate default permissions
449   for non regular files like fifos and character device nodes etc.,
450   and leaves mode bits of existing files unchanged.
451   Previously it would have set executable bits on created special files,
452   and set mode bits for existing files as if they had been created.
453   [bug introduced with coreutils-8.20]
455   'cp --remove-destination file symlink' now removes the symlink
456   even if it can't be traversed.
457   [bug introduced with --remove-destination in fileutils-4.1.1]
459   ls no longer truncates the abbreviated month names that have a
460   display width between 6 and 12 inclusive.  Previously this would have
461   output ambiguous months for Arabic or Catalan locales.
463   'ls -aA' is now equivalent to 'ls -A', since -A now overrides -a.
464   [bug introduced in coreutils-5.3.0]
466   'mv -n A B' no longer suffers from a race condition that can
467   overwrite a simultaneously-created B.  This bug fix requires
468   platform support for the renameat2 or renameatx_np syscalls, found
469   in recent Linux and macOS kernels.  As a side effect, 'mv -n A A'
470   now silently does nothing if A exists.
471   [bug introduced with coreutils-7.1]
473 ** Changes in behavior
475   'cp --force file symlink' now removes the symlink even if
476   it is self referential.
478   ls --color now matches file extensions case insensitively.
480 ** New features
482   cp --reflink now supports --reflink=never to enforce a standard copy.
484   env supports a new -v/--debug option to show verbose information about
485   each processing step.
487   env supports a new -S/--split-string=S option to split a single argument
488   string into multiple arguments. Used to pass multiple arguments in scripts
489   (shebang lines).
491   md5sum accepts a new option: --zero (-z) to delimit the output lines with a
492   NUL instead of a newline character.  This also disables file name escaping.
493   This also applies to sha*sum and b2sum.
495   rm --preserve-root now supports the --preserve-root=all option to
496   reject any command line argument that is mounted to a separate file system.
498 ** Improvements
500   cut supports line lengths up to the max file size on 32 bit systems.
501   Previously only offsets up to SIZE_MAX-1 were supported.
503   stat and tail now know about the "exfs" file system, which is a
504   version of XFS.  stat -f --format=%T now reports the file system type,
505   and tail -f uses inotify.
507   wc avoids redundant processing of ASCII text in multibyte locales,
508   which is especially significant on macOS.
511 * Noteworthy changes in release 8.29 (2017-12-27) [stable]
513 ** Bug fixes
515   b2sum no longer crashes when processing certain truncated check files.
516   [bug introduced with b2sum coreutils-8.26]
518   dd now ensures the correct cache ranges are specified for the "nocache"
519   and "direct" flags.  Previously some pages in the page cache were not
520   invalidated.  [bug introduced for "direct" in coreutils-7.5,
521   and with the "nocache" implementation in coreutils-8.11]
523   df no longer hangs when given a fifo argument.
524   [bug introduced in coreutils-7.3]
526   ptx -S no longer infloops for a pattern which returns zero-length matches.
527   [the bug dates back to the initial implementation]
529   shred --remove will again repeatedly rename files with shortening names
530   to attempt to hide the original length of the file name.
531   [bug introduced in coreutils-8.28]
533   stty no longer crashes when processing settings with -F also specified.
534   [bug introduced in fileutils-4.0]
536   tail --bytes again supports non seekable inputs on all systems.
537   On systems like android it always tried to process as seekable inputs.
538   [bug introduced in coreutils-8.24]
540   timeout will again notice its managed command exiting, even when
541   invoked with blocked CHLD signal, or in a narrow window where
542   this CHLD signal from the exiting child was missed.  In each case
543   timeout would have then waited for the time limit to expire.
544   [bug introduced in coreutils-8.27]
546 ** New features
548   timeout now supports the --verbose option to diagnose forced termination.
550 ** Improvements
552   dd now supports iflag=direct with arbitrary sized files on all file systems.
554   tail --bytes=NUM will efficiently seek to the end of block devices,
555   rather than reading from the start.
557   Utilities which do not support long options (other than the default --help
558   and --version), e.g. cksum and sleep, now use more consistent error diagnostic
559   for unknown long options.
561 ** Build-related
563   Default man pages are now distributed which are used if perl is
564   not available on the build system, or when cross compiling.
567 * Noteworthy changes in release 8.28 (2017-09-01) [stable]
569 ** Bug fixes
571   cp and mv now merely warn about any failure to preserve symlink ownership.
572   Before, cp (without -p) would exit with a failure status, and a cross-device
573   mv would leave such symlinks behind in the source file system.
574   [the bug dates back to the initial implementation]
576   When creating numbered backups, cp, install, ln, and mv now avoid
577   races that could lose backup data in unlikely circumstances.  Since
578   the fix relies on the renameat2 system call of Linux kernel 3.15 and
579   later, the races are still present on other platforms.
580   [the bug dates back to the initial implementation]
582   cp, install, ln, and mv no longer lose data when asked to copy a
583   backup file to its original via a differently-spelled file name.
584   E.g., 'rm -f a a~; : > a; echo data > a~; cp --backup=simple a~ ./a'
585   now fails instead of losing the data.
586   [the bug dates back to the initial implementation]
588   cp, install, ln, and mv now ignore nonsensical backup suffixes.
589   For example, --suffix='/' and --suffix='' are now no-ops.
590   [the bug dates back to the initial implementation]
592   date and touch no longer overwrite the heap with large
593   user specified TZ values (CVE-2017-7476).
594   [bug introduced in coreutils-8.27]
596   dd status=progress now just counts seconds; e.g., it outputs "6 s"
597   consistently rather than sometimes outputting "6.00001 s".
598   [bug introduced in coreutils-8.24]
600   df no longer interacts with excluded file system types, so for example
601   specifying -x nfs no longer hangs with problematic nfs mounts.
602   [bug introduced in coreutils-8.21]
604   df no longer interacts with dummy file system types, so for example
605   no longer hangs with problematic nfs mounted via system.automount(5).
606   [bug introduced in coreutils-8.21]
608   `groups inva:lid root` no longer exits immediately upon failure.
609   Now, it prints a diagnostic or a line to stdout for each argument.
610   [bug introduced in the bourne-shell-to-C rewrite for coreutils-6.11]
612   kill now converts from number to signal name correctly on AIX.
613   Previously it would have always returned the 'EXIT' name.
614   [bug introduced in fileutils-4.1.9]
616   ls now quotes symlink targets consistently.  Previously it may not
617   have quoted the target name if the link name itself didn't need quoting.
618   [bug introduced in coreutils-8.26]
620   split no longer exits when invocations of a --filter return EPIPE.
621   [bug introduced in coreutils-8.26]
623   md5sum --check no longer incorrectly enables BSD reversed format mode when
624   ignoring some non checksum lines.  This also affects sha*sum and b2sum.
625   [bug introduced in coreutils-8.14]
627   tail -F 'dir/file' is now monitored even when 'dir' is replaced.
628   [bug introduced with inotify support added in coreutils-7.5]
630   tail -f with --pid=PID now processes all inotify events.
631   Previously events may have been ignored completely upon PID death,
632   or ignored until future events on the monitored files.
633   [bug introduced with inotify support added in coreutils-7.5]
635   tail -f /dev/tty is now supported by not using inotify when any
636   non regular files are specified, as inotify is ineffective with these.
637   [bug introduced with inotify support added in coreutils-7.5]
639   uptime no longer outputs the AM/PM component of the current time,
640   as that's inconsistent with the 24 hour time format used.
641   [bug introduced in coreutils-7.0]
643   expr now returns number of characters matched (instead of incorrect
644   number of bytes matched) with 'match'/':' operators on multibyte strings.
646 ** New features
648   expand and unexpand now support specifying an offset for tab stops
649   by prefixing the last specified number like --tabs=1,+8 which is
650   useful for visualizing diff output for example.
652   ls supports a new --hyperlink[=when] option to output file://
653   format links to files, supported by some terminals.
655   split supports a new --hex-suffixes[=from] option to create files with
656   lower case hexadecimal suffixes, similar to the --numeric-suffixes option.
658   env now has a --chdir (-C) option to change the working directory before
659   executing the subsidiary program.
661   expr supports multibyte strings for all string operations.
663 ** Changes in behavior
665   tail -f now exits immediately if the output is piped and the reader of
666   the pipe terminates.  That allows `tail -f file | grep -q foo` to return
667   responsively, but does make `tail -f file | :` exit immediately without
668   waiting for data.  Instead one should now `tail -f file | grep -q .`
670 ** Improvements
672   mv --verbose now distinguishes rename and copy operations.
674   stat -f -c %l, used to output the max file name length on a file system,
675   is now supported on FreeBSD and OpenBSD.
677   tail -f no longer erroneously warns about being ineffective
678   when following a single tty, as the simple blocking loop used
679   is effective in this case.
682 * Noteworthy changes in release 8.27 (2017-03-08) [stable]
684 ** Bug fixes
686   cp --parents will now set an SELinux context for created directories,
687   as appropriate for the -a, --preseve=context, or -Z options.
688   [bug present since SELinux support added in coreutils-6.10]
690   date again converts from a specified time zone.  Previously output was
691   not converted to the local time zone, and remained in the specified one.
692   [bug introduced in coreutils-8.26]
694   Commands like 'cp --no-dereference -l A B' are no longer quiet no-ops
695   when A is a regular file and B is a symbolic link that points to A.
696   [bug introduced in fileutils-4.0]
698   factor no longer goes into an infinite loop for certain numbers like
699   158909489063877810457 and 222087527029934481871.
700   [bug introduced in coreutils-8.20]
702   tail no longer prints redundant file headers with interleaved inotify events,
703   which could be triggered especially when tail was suspended and resumed.
704   [bug introduced with inotify support added in coreutils-7.5]
706   timeout no longer has a race that may terminate the wrong process.
707   The race is unlikely, as timeout(1) needs to receive a signal right
708   after the command being monitored finishes.  Also the system needs
709   to have reallocated that command's pid in that short time window.
710   [bug introduced when timeout was added in coreutils-7.0]
712   wc --bytes --files0-from now correctly reports byte counts.
713   Previously it may have returned values that were too large,
714   depending on the size of the first file processed.
715   [bug introduced in coreutils-8.24]
717 ** Improvements
719   The new 'date' option --rfc-email is now the long form for -R.
720   The new option spelling is intended to avoid the need to track the
721   Internet RFC number for email dates (currently RFC 5322).  The old
722   option spellings --rfc-2822 and --rfc-822 still work.
724   date now outputs "-00" for a numeric time zone if the time is UTC
725   and the time zone abbreviation begins with "-", indicating that the
726   time zone is indeterminate.
728   nproc now honors the OMP_THREAD_LIMIT environment variable to
729   set the maximum returned value.  OMP_NUM_THREADS continues to
730   set the minimum returned value, but is updated to support the
731   nested level syntax allowed in this variable.
733   stat and tail now know about the "rdt" file system, which is an interface
734   to Resource Director Technology.  stat -f --format=%T now reports the
735   file system type, and tail -f uses inotify.
737   stty now validates arguments before interacting with the device,
738   ensuring there are no side effects to specifying an invalid option.
740   If the file B already exists, commands like 'ln -f A B' and
741   'cp -fl A B' no longer remove B before creating the new link.
742   That is, there is no longer a brief moment when B does not exist.
744 ** New features
746   expand and unexpand now support specifying a tab size to use
747   after explicitly specified tab stops, by prefixing the last
748   specified number like --tabs=2,4,/8.
751 * Noteworthy changes in release 8.26 (2016-11-30) [stable]
753 ** Bug fixes
755   cp, mv, and install no longer run into undefined behavior when
756   handling ACLs on Cygwin and Solaris platforms. [bug introduced in
757   coreutils-8.24]
759   cp --parents --no-preserve=mode, no longer copies permissions from source
760   directories, instead using default permissions for created directories.
761   [bug introduced in coreutils-5.93]
763   chcon, chgrp, chmod, chown, du, and rm, or specifically utilities
764   using the FTS interface, now diagnose failures returned by readdir().
765   [this bug was inherent in the use of fts: thus, for rm the bug was
766   introduced in coreutils-8.0.  du, chmod, chgrp and chown started using
767   fts in 6.0.  chcon was added in coreutils-6.9.91 with fts support.  ]
769   date, du, ls, and pr no longer mishandle time zone abbreviations on
770   System V style platforms where this information is available only
771   in the global variable 'tzname'. [bug introduced in coreutils-8.24]
773   factor again outputs immediately when numbers are input interactively.
774   [bug introduced in coreutils-8.24]
776   head no longer tries to process non-seekable input as seekable,
777   which resulted in failures on FreeBSD 11 at least.
778   [bug introduced in coreutils-8.24]
780   install -DZ and mkdir -pZ now set default SELinux context correctly even if
781   two or more directories nested in each other are created and each of them
782   defaults to a different SELinux context.
784   ls --time-style no longer mishandles '%%b' in formats.
785   [bug introduced in coreutils-7.2]
787   md5sum --check --ignore-missing no longer treats files with checksums
788   starting with "00" as missing.  This also affects sha*sum.
789   [bug introduced with the --ignore-missing feature in coreutils-8.25]
791   nl now resets numbering for each page section rather than just for each page.
792   [This bug was present in "the beginning".]
794   pr now handles specified separator strings containing tabs correctly.
795   Previously it would have output random data from memory.
796   [This bug was detected with ASAN and present in "the beginning".]
798   sort -h -k now works even in locales that use blank as thousands separator.
800   stty --help no longer outputs extraneous gettext header lines
801   for translated languages. [bug introduced in coreutils-8.24]
803   stty "sane" again sets "susp" to ^z on Solaris, and leaves "swtch" undefined.
804   [This bug previously fixed only on some older Solaris systems]
806   seq now immediately exits upon write errors.
807   [This bug was present in "the beginning".]
809   tac no longer crashes when there are issues reading from non-seekable inputs.
810   [bug introduced in coreutils-8.15]
812   tail -F now continues to process initially untailable files that are replaced
813   by a tailable file.  This was handled correctly when inotify was available,
814   and is now handled correctly in all cases.
815   [bug introduced in fileutils-4.0h]
817   tail -f - 'untailable file' will now terminate when there is no more data
818   to read from stdin.  Previously it behaved as if --retry was specified.
819   [This bug was present in "the beginning".]
821   tail -f 'remote file' will now avoid outputting repeated data on network
822   file systems that misreport file sizes through stale metadata.
823   [This bug was present in "the beginning" but exacerbated in coreutils-8.24]
825   tail -f --retry 'missing file' will now process truncations of that file.
826   Previously truncation was ignored thus not outputting new data in the file.
827   [bug introduced in coreutils-5.3.0]
829   tail -f will no longer continually try to open inaccessible files,
830   only doing so if --retry is specified.
831   [This bug was present in "the beginning".]
833   yes now handles short writes, rather than assuming all writes complete.
834   [bug introduced in coreutils-8.24]
836 ** Changes in behavior
838   rm no longer accepts shortened variants of the --no-preserve-root option.
840   seq no longer accepts 0 value as increment, and now also rejects NaN
841   values for any argument.
843   stat now outputs nanosecond information for timestamps even if
844   they are out of localtime range.
846   sort, tail, and uniq now support traditional usage like 'sort +2'
847   and 'tail +10' on systems conforming to POSIX 1003.1-2008 and later.
848   The 2008 edition of POSIX dropped the requirement that arguments
849   like '+2' must be treated as file names.
851 ** Improvements
853   dd now warns about counts specified with a 0x "prefix", since dd will
854   interpret those as a zero multiplier rather than a hex constant.
855   The warning suggests to use 00x if a zero multiplier is really intended.
857   df now filters the system mount list more efficiently, with 20000
858   mount entries now being processed in about 1.1s compared to 1.7s.
860   du, shuf, sort, and uniq no longer fail to process a specified file
861   when their stdin is closed, which would have happened with glibc >= 2.14.
863   install -Z now also sets the default SELinux context for created directories.
865   ls is now fully responsive to signals until the first escape sequence is
866   written to a terminal.
868   ls now aligns quoted items with non quoted items, which is easier to read,
869   and also better indicates that the quote is not part of the actual name.
871   stat and tail now know about these file systems:
872     "balloon-kvm-fs"    KVM dynamic RAM allocation support,
873     "cgroup2"           Linux Control Groups V2 support,
874     "daxfs"             Optical media file system,
875     "m1fs"              A Plexistor file system,
876     "prl_fs"            A parallels file system,
877     "smb2"              Samba for SMB protocol V2,
878     "wslfs"             Windows Subsystem for Linux,
879     "zsmalloc"          Linux compressed swap support,
880   stat -f --format=%T now reports the file system type, and
881   tail -f uses polling for "prl_fs" and "smb2", and inotify for others.
883   stat --format=%N for quoting file names now honors the
884   same QUOTING_STYLE environment variable values as ls.
886 ** New programs
888   b2sum is added to support the BLAKE2 digest algorithm with
889   a similar interface to the existing md5sum and sha1sum, etc. commands.
891 ** New Features
893   comm now accepts the --total option to output a summary at the end.
895   date now accepts the --debug option, to annotate the parsed date string,
896   display timezone information, and warn about potential misuse.
898   date now accepts the %q format to output the quarter of the year.
901 * Noteworthy changes in release 8.25 (2016-01-20) [stable]
903 ** Bug fixes
905   cp now correctly copies files with a hole at the end of the file,
906   and extents allocated beyond the apparent size of the file.
907   That combination resulted in the trailing hole not being reproduced.
908   [bug introduced in coreutils-8.10]
910   cut --fields no longer outputs extraneous characters on some uClibc configs.
911   [bug introduced in coreutils-6.11]
913   install -D again copies relative file names when absolute file names
914   are also specified along with an absolute destination directory name.
915   [bug introduced in coreutils-6.2]
917   ls no longer prematurely wraps lines when printing short file names.
918   [bug introduced in coreutils-5.1.0]
920   mv no longer causes data loss due to removing a source directory specified
921   multiple times, when that directory is also specified as the destination.
922   [bug introduced in coreutils-8.24]
924   shred again uses defined patterns for all iteration counts.
925   [bug introduced in coreutils-5.93]
927   sort --debug -b now correctly marks the matching extents for keys
928   that specify an offset for the first field.
929   [bug introduced with the --debug feature in coreutils-8.6]
931   tail -F now works with initially non existent files on a remote file system.
932   [bug introduced in coreutils-7.5]
934 ** New commands
936   base32 is added to complement the existing base64 command,
937   and encodes and decodes printable text as per RFC 4648.
939 ** New features
941   comm,cut,head,numfmt,paste,tail now have the -z,--zero-terminated option, and
942   tac --separator accepts an empty argument, to work with NUL delimited items.
944   dd now summarizes sizes in --human-readable format too, not just --si.
945   E.g., "3441325000 bytes (3.4 GB, 3.2 GiB) copied".  It omits the summaries
946   if they would not provide useful information, e.g., "3 bytes copied".
947   Its status=progress output now uses the same format as ordinary status,
948   perhaps with trailing spaces to erase previous progress output.
950   md5sum now supports the --ignore-missing option to allow
951   verifying a subset of files given a larger list of checksums.
952   This also affects sha1sum, sha224sum, sha256sum, sha384sum and sha512sum.
954   printf now supports the '%q' format to print arguments in a form that
955   is reusable by most shells, with non-printable characters escaped
956   with the POSIX proposed $'...' syntax.
958   stty now supports the "[-]drain" setting to control whether to wait
959   for transmission of pending output before application of settings.
961 ** Changes in behavior
963   base64 no longer supports hex or oct --wrap parameters,
964   thus better supporting decimals with leading zeros.
966   date --iso-8601 now uses +00:00 timezone format rather than +0000.
967   The standard states to use this "extended" format throughout a timestamp.
969   df now prefers sources towards the root of a device when
970   eliding duplicate bind mounted entries.
972   ls now quotes file names unambiguously and appropriate for use in a shell,
973   when outputting to a terminal.
975   join, sort, uniq with --zero-terminated, now treat '\n' as a field delimiter.
977 ** Improvements
979   All utilities now quote user supplied arguments in error strings,
980   which avoids confusing error messages in the presence of '\r' chars etc.
982   Utilities that traverse directories, like chmod, cp, and rm etc., will operate
983   more efficiently on XFS through the use of "leaf optimization".
985   md5sum now ensures a single line per file for status on standard output,
986   by using a '\' at the start of the line, and replacing any newlines with '\n'.
987   This also affects sha1sum, sha224sum, sha256sum, sha384sum and sha512sum.
989   dircolors now supports globbing of TERM entries in its database.
990   For example "TERM *256color*" is now supported.
992   du no longer stats all mount points at startup, only doing so
993   upon detection of a directory cycle.
994   [issue introduced in coreutils-8.20]
996   ls -w0 is now interpreted as no limit on the length of the outputted line.
998   stat -f --format=%T now reports the file system type for new Linux
999   pseudo file systems "bpf_fs", "btrfs_test", "nsfs", "overlayfs"
1000   and "tracefs", and remote file system "acfs".
1002   wc now ensures a single line per file for counts on standard output,
1003   by quoting names containing '\n' characters; appropriate for use in a shell.
1006 * Noteworthy changes in release 8.24 (2015-07-03) [stable]
1008 ** Bug fixes
1010   dd supports more robust SIGINFO/SIGUSR1 handling for outputting statistics.
1011   Previously those signals may have inadvertently terminated the process.
1013   df --local no longer hangs with inaccessible remote mounts.
1014   [bug introduced in coreutils-8.21]
1016   du now silently ignores all directory cycles due to bind mounts.
1017   Previously it would issue a warning and exit with a failure status.
1018   [bug introduced in coreutils-8.1 and partially fixed in coreutils-8.23]
1020   chroot again calls chroot(DIR) and chdir("/"), even if DIR is "/".
1021   This handles separate bind mounted "/" trees, and environments
1022   depending on the implicit chdir("/").
1023   [bugs introduced in coreutils-8.23]
1025   cp no longer issues an incorrect warning about directory hardlinks when a
1026   source directory is specified multiple times.  Now, consistent with other
1027   file types, a warning is issued for source directories with duplicate names,
1028   or with -H the directory is copied again using the symlink name.
1030   factor avoids writing partial lines, thus supporting parallel operation.
1031   [the bug dates back to the initial implementation]
1033   head, od, split, tac, tail, and wc no longer mishandle input from files in
1034   /proc and /sys file systems that report somewhat-incorrect file sizes.
1036   mkdir --parents -Z now correctly sets the context for the last component,
1037   even if the parent directory exists and has a different default context.
1038   [bug introduced with the -Z restorecon functionality in coreutils-8.22]
1040   numfmt no longer outputs incorrect overflowed values seen with certain
1041   large numbers, or with numbers with increased precision.
1042   [bug introduced when numfmt was added in coreutils-8.21]
1044   numfmt now handles leading zeros correctly, not counting them when
1045   settings processing limits, and making them optional with floating point.
1046   [bug introduced when numfmt was added in coreutils-8.21]
1048   paste no longer truncates output for large input files.  This would happen
1049   for example with files larger than 4GiB on 32 bit systems with a '\n'
1050   character at the 4GiB position.
1051   [the bug dates back to the initial implementation]
1053   rm indicates the correct number of arguments in its confirmation prompt,
1054   on all platforms.  [bug introduced in coreutils-8.22]
1056   shuf -i with a single redundant operand, would crash instead of issuing
1057   a diagnostic.  [bug introduced in coreutils-8.22]
1059   tail releases inotify resources when unused.  Previously it could exhaust
1060   resources with many files, or with -F if files were replaced many times.
1061   [bug introduced in coreutils-7.5]
1063   tail -f again follows changes to a file after it's renamed.
1064   [bug introduced in coreutils-7.5]
1066   tail --follow no longer misses changes to files if those files were
1067   replaced before inotify watches were created.
1068   [bug introduced in coreutils-7.5]
1070   tail --follow consistently outputs all data for a truncated file.
1071   [bug introduced in the beginning]
1073   tail --follow=name correctly outputs headers for multiple files
1074   when those files are being created or renamed.
1075   [bug introduced in coreutils-7.5]
1077 ** New features
1079   chroot accepts the new --skip-chdir option to not change the working directory
1080   to "/" after changing into the chroot(2) jail, thus retaining the current wor-
1081   king directory.  The new option is only permitted if the new root directory is
1082   the old "/", and therefore is useful with the --group and --userspec options.
1084   dd accepts a new status=progress level to print data transfer statistics
1085   on stderr approximately every second.
1087   numfmt can now process multiple fields with field range specifications similar
1088   to cut, and supports setting the output precision with the --format option.
1090   split accepts a new --separator option to select a record separator character
1091   other than the default newline character.
1093   stty allows setting the "extproc" option where supported, which is
1094   a useful setting with high latency links.
1096   sync no longer ignores arguments, and syncs each specified file, or with the
1097   --file-system option, the file systems associated with each specified file.
1099   tee accepts a new --output-error option to control operation with pipes
1100   and output errors in general.
1102 ** Changes in behavior
1104   df no longer suppresses separate exports of the same remote device, as
1105   these are generally explicitly mounted.  The --total option does still
1106   suppress duplicate remote file systems.
1107   [suppression was introduced in coreutils-8.21]
1109   mv no longer supports moving a file to a hardlink, instead issuing an error.
1110   The implementation was susceptible to races in the presence of multiple mv
1111   instances, which could result in both hardlinks being deleted.  Also on case
1112   insensitive file systems like HFS, mv would just remove a hardlinked 'file'
1113   if called like `mv file File`.  The feature was added in coreutils-5.0.1.
1115   numfmt --from-unit and --to-unit options now interpret suffixes as SI units,
1116   and IEC (power of 2) units are now specified by appending 'i'.
1118   tee will exit early if there are no more writable outputs.
1120   tee does not treat the file operand '-' as meaning standard output any longer,
1121   for better conformance to POSIX.  This feature was added in coreutils-5.3.0.
1123   timeout --foreground no longer sends SIGCONT to the monitored process,
1124   which was seen to cause intermittent issues with GDB for example.
1126 ** Improvements
1128   cp,install,mv will convert smaller runs of NULs in the input to holes,
1129   and cp --sparse=always avoids speculative preallocation on XFS for example.
1131   cp will read sparse files more efficiently when the destination is a
1132   non regular file.  For example when copying a disk image to a device node.
1134   mv will try a reflink before falling back to a standard copy, which is
1135   more efficient when moving files across BTRFS subvolume boundaries.
1137   stat and tail now know about IBRIX.  stat -f --format=%T now reports the file
1138   system type, and tail -f uses polling for files on IBRIX file systems.
1140   wc -l processes short lines much more efficiently.
1142   References from --help and the man pages of utilities have been corrected
1143   in various cases, and more direct links to the corresponding online
1144   documentation are provided.
1147 * Noteworthy changes in release 8.23 (2014-07-18) [stable]
1149 ** Bug fixes
1151   chmod -Rc no longer issues erroneous warnings for files with special bits set.
1152   [bug introduced in coreutils-6.0]
1154   cp -a, mv, and install --preserve-context, once again set the correct SELinux
1155   context for existing directories in the destination.  Previously they set
1156   the context of an existing directory to that of its last copied descendant.
1157   [bug introduced in coreutils-8.22]
1159   cp -a, mv, and install --preserve-context, no longer seg fault when running
1160   with SELinux enabled, when copying from file systems that return an error
1161   when reading the SELinux context for a file.
1162   [bug introduced in coreutils-8.22]
1164   cp -a and mv now preserve xattrs of symlinks copied across file systems.
1165   [bug introduced with extended attribute preservation feature in coreutils-7.1]
1167   date could crash or go into an infinite loop when parsing a malformed TZ="".
1168   [bug introduced with the --date='TZ="" ..' parsing feature in coreutils-5.3.0]
1170   dd's ASCII and EBCDIC conversions were incompatible with common practice and
1171   with POSIX, and have been corrected as follows.  First, conv=ascii now
1172   implies conv=unblock, and conv=ebcdic and conv=ibm now imply conv=block.
1173   Second, the translation tables for dd conv=ascii and conv=ebcdic have been
1174   corrected as shown in the following table, where A is the ASCII value, W is
1175   the old, wrong EBCDIC value, and E is the new, corrected EBCDIC value; all
1176   values are in octal.
1178       A   W   E
1179      041 117 132
1180      133 112 255
1181      135 132 275
1182      136 137 232
1183      174 152 117
1184      176 241 137
1185      313 232 152
1186      325 255 112
1187      345 275 241
1189   [These dd bugs were present in "the beginning".]
1191   df has more fixes related to the newer dynamic representation of file systems:
1192   Duplicates are elided for virtual file systems like tmpfs.
1193   Details for the correct device are output for points mounted multiple times.
1194   Placeholder values are output for inaccessible file systems, rather than
1195   than error messages or values for the wrong file system.
1196   [These bugs were present in "the beginning".]
1198   df now outputs all appropriate entries in the presence of bind mounts.
1199   On some systems, entries would have been incorrectly elided due to
1200   them being considered "dummy" mounts.
1201   [bug introduced in coreutils-8.22]
1203   du now silently ignores directory cycles introduced with bind mounts.
1204   Previously it would issue a warning and exit with a failure status.
1205   [bug introduced in coreutils-8.1]
1207   head --bytes=-N and --lines=-N now handles devices more
1208   consistently, not ignoring data from virtual devices like /dev/zero,
1209   or on BSD systems data from tty devices.
1210   [bug introduced in coreutils-5.0.1]
1212   head --bytes=-N - no longer fails with a bogus diagnostic when stdin's
1213   seek pointer is not at the beginning.
1214   [bug introduced with the --bytes=-N feature in coreutils-5.0.1]
1216   head --lines=-0, when the input does not contain a trailing '\n',
1217   now copies all input to stdout.  Previously nothing was output in this case.
1218   [bug introduced with the --lines=-N feature in coreutils-5.0.1]
1220   id, when invoked with no user name argument, now prints the correct group ID.
1221   Previously, in the default output format, it would print the default group ID
1222   in the password database, which may be neither real nor effective.  For e.g.,
1223   when run set-GID, or when the database changes outside the current session.
1224   [bug introduced in coreutils-8.1]
1226   ln -sf now replaces symbolic links whose targets can't exist.  Previously
1227   it would display an error, requiring --no-dereference to avoid the issue.
1228   [bug introduced in coreutils-5.3.0]
1230   ln -sr '' F no longer segfaults.  Now works as expected.
1231   [bug introduced with the --relative feature in coreutils-8.16]
1233   numfmt now handles blanks correctly in all unibyte locales.  Previously
1234   in locales where character 0xA0 is a blank, numfmt would mishandle it.
1235   [bug introduced when numfmt was added in coreutils-8.21]
1237   ptx --format long option parsing no longer falls through into the --help case.
1238   [bug introduced in TEXTUTILS-1_22i]
1240   ptx now consistently trims whitespace when processing multiple files.
1241   [This bug was present in "the beginning".]
1243   seq again generates correct output with start or end values = -0.
1244   [bug introduced in coreutils-8.20.]
1246   shuf --repeat no longer dumps core if the input is empty.
1247   [bug introduced with the --repeat feature in coreutils-8.22]
1249   sort when using multiple threads now avoids undefined behavior with mutex
1250   destruction, which could cause deadlocks on some implementations.
1251   [bug introduced in coreutils-8.6]
1253   tail -f now uses polling mode for VXFS to cater for its clustered mode.
1254   [bug introduced with inotify support added in coreutils-7.5]
1256 ** New features
1258   od accepts a new option: --endian=TYPE to handle inputs with different byte
1259   orders, or to provide consistent output on systems with disparate endianness.
1261   configure accepts the new option --enable-single-binary to build all the
1262   selected programs in a single binary called "coreutils".  The selected
1263   programs can still be called directly using symlinks to "coreutils" or
1264   shebangs with the option --coreutils-prog= passed to this program.  The
1265   install behavior is determined by the option --enable-single-binary=symlinks
1266   or --enable-single-binary=shebangs (the default).  With the symlinks option,
1267   you can't make a second symlink to any program because that will change the
1268   name of the called program, which is used by coreutils to determine the
1269   desired program.  The shebangs option doesn't suffer from this problem, but
1270   the /proc/$pid/cmdline file might not be updated on all the platforms.  The
1271   functionality of each program is not affected but this single binary will
1272   depend on all the required dynamic libraries even to run simple programs.
1273   If you desire to build some tools outside the single binary file, you can
1274   pass the option --enable-single-binary-exceptions=PROG_LIST with the comma
1275   separated list of programs you want to build separately.  This flag
1276   considerably reduces the overall size of the installed binaries which makes
1277   it suitable for embedded system.
1279 ** Changes in behavior
1281   chroot with an argument of "/" no longer implicitly changes the current
1282   directory to "/", allowing changing only user credentials for a command.
1284   chroot --userspec will now unset supplemental groups associated with root,
1285   and instead use the supplemental groups of the specified user.
1287   cut -d$'\n' again outputs lines identified in the --fields list, having
1288   not done so in v8.21 and v8.22.  Note using this non portable functionality
1289   will result in the delayed output of lines.
1291   ls with none of LS_COLORS or COLORTERM environment variables set,
1292   will now honor an empty or unknown TERM environment variable,
1293   and not output colors even with --colors=always.
1295 ** Improvements
1297   chroot has better --userspec and --group look-ups, with numeric IDs never
1298   causing name look-up errors.  Also look-ups are first done outside the chroot,
1299   in case the look-up within the chroot fails due to library conflicts etc.
1301   install now allows the combination of the -D and -t options.
1303   numfmt supports zero padding of numbers using the standard printf
1304   syntax of a leading zero, for example --format="%010f".
1305   Also throughput was improved by up to 800% by avoiding redundant processing.
1307   shred now supports multiple passes on GNU/Linux tape devices by rewinding
1308   the tape before each pass, avoids redundant writes to empty files,
1309   uses direct I/O for all passes where possible, and attempts to clear
1310   inode storage used for small files on some file systems.
1312   split avoids unnecessary input buffering, immediately writing input to output
1313   which is significant with --filter or when writing to fifos or stdout etc.
1315   stat and tail work better with HFS+, HFSX, LogFS and ConfigFS.  stat -f
1316   --format=%T now reports the file system type, and tail -f now uses inotify,
1317   rather than the default of issuing a warning and reverting to polling.
1320 * Noteworthy changes in release 8.22 (2013-12-13) [stable]
1322 ** Bug fixes
1324   df now processes the mount list correctly in the presence of unstatable
1325   mount points.  Previously it may have failed to output some mount points.
1326   [bug introduced in coreutils-8.21]
1328   df now processes symbolic links and relative paths to special files containing
1329   a mounted file system correctly.  Previously df displayed the statistics about
1330   the file system the file is stored on rather than the one inside.
1331   [This bug was present in "the beginning".]
1333   df now processes disk device nodes correctly in the presence of bind mounts.
1334   Now df shows the base mounted file system rather than the last one mounted.
1335   [This bug was present in "the beginning".]
1337   install now removes the target file if the strip program failed for any
1338   reason.  Before, that file was left behind, sometimes even with wrong
1339   permissions.
1340   [This bug was present in "the beginning".]
1342   ln --relative now updates existing symlinks correctly.  Previously it based
1343   the relative link on the dereferenced path of an existing link.
1344   [This bug was introduced when --relative was added in coreutils-8.16.]
1346   ls --recursive will no longer exit with "serious" exit code (2), if there
1347   is an error reading a directory not specified on the command line.
1348   [Bug introduced in coreutils-5.3.0]
1350   mkdir, mkfifo, and mknod now work better when creating a file in a directory
1351   with a default ACL whose umask disagrees with the process's umask, on a
1352   system such as GNU/Linux where directory ACL umasks override process umasks.
1353   [bug introduced in coreutils-6.0]
1355   mv will now replace empty directories in the destination with directories
1356   from the source, when copying across file systems.
1357   [This bug was present in "the beginning".]
1359   od -wN with N larger than 64K on a system with 32-bit size_t would
1360   print approximately 2*N bytes of extraneous padding.
1361   [Bug introduced in coreutils-7.0]
1363   rm -I now prompts for confirmation before removing a write protected file.
1364   [Bug introduced in coreutils-6.8]
1366   shred once again uses direct I/O on systems requiring aligned buffers.
1367   Also direct I/O failures for odd sized writes at end of file are now handled.
1368   [The "last write" bug was introduced in coreutils-5.3.0 but masked
1369    by the alignment bug introduced in coreutils-6.0]
1371   tail --retry -f now waits for the files specified to appear.  Before, tail
1372   would immediately exit when such a file is initially inaccessible.
1373   [This bug was introduced when inotify support was added in coreutils-7.5]
1375   tail -F has improved handling of symlinks.  Previously tail didn't respond
1376   to the symlink target (re)appearing after being (re)created.
1377   [This bug was introduced when inotify support was added in coreutils-7.5]
1379 ** New features
1381   cp, install, mkdir, mknod, mkfifo and mv now support "restorecon"
1382   functionality through the -Z option, to set the SELinux context
1383   appropriate for the new item location in the file system.
1385   csplit accepts a new option: --suppressed-matched, to elide the lines
1386   used to identify the split points.
1388   df --output now accepts a 'file' field, to propagate a specified
1389   command line argument through to the output.
1391   du accepts a new option: --inodes to show the number of inodes instead
1392   of the blocks used.
1394   id accepts a new option: --zero (-z) to delimit the output entries by
1395   a NUL instead of a white space character.
1397   id and ls with -Z report the SMACK security context where available.
1398   mkdir, mkfifo and mknod with --context set the SMACK context where available.
1400   id can now lookup by user ID, in addition to the existing name lookup.
1402   join accepts a new option: --zero-terminated (-z). As with the sort,uniq
1403   option of the same name, this makes join consume and produce NUL-terminated
1404   lines rather than newline-terminated lines.
1406   uniq accepts a new option: --group to print all items, while separating
1407   unique groups with empty lines.
1409   shred accepts new parameters to the --remove option to give greater
1410   control over that operation, which can greatly reduce sync overhead.
1412   shuf accepts a new option: --repeat (-r), which can repeat items in
1413   the output.
1415 ** Changes in behavior
1417   cp --link now dereferences a symbolic link as source before creating the
1418   hard link in the destination unless the -P,--no-deref option is specified.
1419   Previously, it would create a hard link of the symbolic link, even when
1420   the dereferencing options -L or -H were specified.
1422   cp, install, mkdir, mknod and mkfifo no longer accept an argument to the
1423   short -Z option.  The --context equivalent still takes an optional argument.
1425   dd status=none now suppresses all non fatal diagnostic messages,
1426   not just the transfer counts.
1428   df no longer accepts the long-obsolescent --megabytes option.
1430   stdbuf now requires at least one buffering mode option to be specified,
1431   as per the documented interface.
1433 ** Improvements
1435   base64 encoding throughput for bulk data is increased by about 60%.
1437   md5sum can use libcrypto hash routines where allowed to potentially
1438   get better performance through using more system specific logic.
1439   sha1sum for example has improved throughput by 40% on an i3-2310M.
1440   This also affects sha1sum, sha224sum, sha256sum, sha384sum and sha512sum.
1442   stat and tail work better with EFIVARFS, EXOFS, F2FS, HOSTFS, SMACKFS, SNFS
1443   and UBIFS.  stat -f --format=%T now reports the file system type, and tail -f
1444   now uses inotify for files on all those except SNFS, rather than the default
1445   (for unknown file system types) of issuing a warning and reverting to polling.
1447   shuf outputs subsets of large inputs much more efficiently.
1448   Reservoir sampling is used to limit memory usage based on the number of
1449   outputs, rather than the number of inputs.
1451   shred increases the default write block size from 12KiB to 64KiB
1452   to align with other utilities and reduce the system call overhead.
1454   split --line-bytes=SIZE, now only allocates memory as needed rather
1455   than allocating SIZE bytes at program start.
1457   stty now supports configuring "stick" (mark/space) parity where available.
1459 ** Build-related
1461   factor now builds on aarch64 based systems [bug introduced in coreutils-8.20]
1464 * Noteworthy changes in release 8.21 (2013-02-14) [stable]
1466 ** New programs
1468   numfmt: reformat numbers
1470 ** New features
1472   df now accepts the --output[=FIELD_LIST] option to define the list of columns
1473   to include in the output, or all available columns if the FIELD_LIST is
1474   omitted.  Note this enables df to output both block and inode fields together.
1476   du now accepts the --threshold=SIZE option to restrict the output to entries
1477   with such a minimum SIZE (or a maximum SIZE if it is negative).
1478   du recognizes -t SIZE as equivalent, for compatibility with FreeBSD.
1480   timeout now accepts the --preserve-status option to always propagate the exit
1481   status, useful for commands that can run for an indeterminate amount of time.
1483 ** Bug fixes
1485   cp --no-preserve=mode now no longer exits non-zero.
1486   [bug introduced in coreutils-8.20]
1488   cut with a range like "N-" no longer allocates N/8 bytes.  That buffer
1489   would never be used, and allocation failure could cause cut to fail.
1490   [bug introduced in coreutils-8.10]
1492   cut no longer accepts the invalid range 0-, which made it print empty lines.
1493   Instead, cut now fails and emits an appropriate diagnostic.
1494   [This bug was present in "the beginning".]
1496   cut now handles overlapping to-EOL ranges properly.  Before, it would
1497   interpret "-b2-,3-" like "-b3-".  Now it's treated like "-b2-".
1498   [This bug was present in "the beginning".]
1500   cut no longer prints extraneous delimiters when a to-EOL range subsumes
1501   another range.  Before, "echo 123|cut --output-delim=: -b2-,3" would print
1502   "2:3".  Now it prints "23".  [bug introduced in 5.3.0]
1504   cut -f no longer inspects input line N+1 before fully outputting line N,
1505   which avoids delayed output for intermittent input.
1506   [bug introduced in TEXTUTILS-1_8b]
1508   factor no longer loops infinitely on 32 bit powerpc or sparc systems.
1509   [bug introduced in coreutils-8.20]
1511   install -m M SOURCE DEST no longer has a race condition where DEST's
1512   permissions are temporarily derived from SOURCE instead of from M.
1514   pr -n no longer crashes when passed values >= 32.  Also, line numbers are
1515   consistently padded with spaces, rather than with zeros for certain widths.
1516   [bug introduced in TEXTUTILS-1_22i]
1518   seq -w ensures that for numbers input in scientific notation,
1519   the output numbers are properly aligned and of the correct width.
1520   [This bug was present in "the beginning".]
1522   seq -w ensures correct alignment when the step value includes a precision
1523   while the start value does not, and the number sequence narrows.
1524   [This bug was present in "the beginning".]
1526   seq -s no longer prints an erroneous newline after the first number, and
1527   outputs a newline after the last number rather than a trailing separator.
1528   Also seq no longer ignores a specified step value when the end value is 1.
1529   [bugs introduced in coreutils-8.20]
1531   timeout now ensures that blocking of ALRM signals is not inherited from
1532   its parent, which would cause timeouts to be ignored.
1533   [the bug dates back to the initial implementation]
1535 ** Changes in behavior
1537   df --total now prints '-' into the target column (mount point) of the
1538   summary line, accommodating the --output option where the target field
1539   can be in any column.  If there is no source column, then df prints
1540   'total' in the target column.
1542   df now properly outputs file system information with bind mounts present on
1543   the system by skipping duplicate entries (identified by the device number).
1544   Consequently, df also elides the early-boot pseudo file system type "rootfs".
1546   cut -d$'\n' no longer outputs lines identified in the --fields list,
1547   to align with other implementations and to avoid delayed output of lines.
1549   nl no longer supports the --page-increment option, which has been
1550   deprecated since coreutils-7.5.  Use --line-increment instead.
1552 ** Improvements
1554   readlink now supports multiple arguments, and a complementary
1555   -z, --zero option to delimit output items with the NUL character.
1557   stat and tail now know about CEPH.  stat -f --format=%T now reports the file
1558   system type, and tail -f uses polling for files on CEPH file systems.
1560   stty now supports configuring DTR/DSR hardware flow control where available.
1562 ** Build-related
1564   Perl is now more of a prerequisite.  It has long been required in order
1565   to run (not skip) a significant percentage of the tests.  Now, it is
1566   also required in order to generate proper man pages, via help2man.  The
1567   generated man/*.1 man pages are no longer distributed.  Building without
1568   perl, you would create stub man pages.  Thus, while perl is not an
1569   official prerequisite (build and "make check" will still succeed), any
1570   resulting man pages would be inferior.  In addition, this fixes a bug
1571   in distributed (not from clone) Makefile.in that could cause parallel
1572   build failure when building from modified sources, as is common practice
1573   for a patched distribution package.
1575   factor now builds on x86_64 with x32 ABI, 32 bit MIPS, and all HPPA systems,
1576   by avoiding incompatible asm.  [bug introduced in coreutils-8.20]
1578   A root-only test predicate would always fail.  Its job was to determine
1579   whether our dummy user, $NON_ROOT_USERNAME, was able to run binaries from
1580   the build directory.  As a result, all dependent tests were always skipped.
1581   Now, those tests may be run once again.  [bug introduced in coreutils-8.20]
1584 * Noteworthy changes in release 8.20 (2012-10-23) [stable]
1586 ** New features
1588   dd now accepts 'status=none' to suppress all informational output.
1590   md5sum now accepts the --tag option to print BSD-style output with GNU
1591   file name escaping.  This also affects sha1sum, sha224sum, sha256sum,
1592   sha384sum and sha512sum.
1594 ** Bug fixes
1596   cp could read from freed memory and could even make corrupt copies.
1597   This could happen with a very fragmented and sparse input file,
1598   on GNU/Linux file systems supporting fiemap extent scanning.
1599   This bug also affects mv when it resorts to copying, and install.
1600   [bug introduced in coreutils-8.11]
1602   cp --no-preserve=mode now no longer preserves the original file's
1603   permissions but correctly sets mode specified by 0666 & ~umask
1605   du no longer emits a "disk-corrupted"-style diagnostic when it detects
1606   a directory cycle that is due to a bind-mounted directory.  Instead,
1607   it detects this precise type of cycle, diagnoses it as such and
1608   eventually exits nonzero.
1610   factor (when using gmp) would mistakenly declare some composite numbers
1611   to be prime, e.g., 465658903, 2242724851, 6635692801 and many more.
1612   The fix makes factor somewhat slower (~25%) for ranges of consecutive
1613   numbers, and up to 8 times slower for some worst-case individual numbers.
1614   [bug introduced in coreutils-7.0, with GNU MP support]
1616   ls now correctly colors dangling symlinks when listing their containing
1617   directories, with orphaned symlink coloring disabled in LS_COLORS.
1618   [bug introduced in coreutils-8.14]
1620   rm -i -d now prompts the user then removes an empty directory, rather
1621   than ignoring the -d option and failing with an 'Is a directory' error.
1622   [bug introduced in coreutils-8.19, with the addition of --dir (-d)]
1624   rm -r S/ (where S is a symlink-to-directory) no longer gives the invalid
1625   "Too many levels of symbolic links" diagnostic.
1626   [bug introduced in coreutils-8.6]
1628   seq now handles arbitrarily long non-negative whole numbers when the
1629   increment is 1 and when no format-changing option is specified.
1630   Before, this would infloop:
1631     b=100000000000000000000; seq $b $b
1632   [the bug dates back to the initial implementation]
1634 ** Changes in behavior
1636   nproc now diagnoses with an error, non option command line parameters.
1638 ** Improvements
1640   factor's core has been rewritten for speed and increased range.
1641   It can now factor numbers up to 2^128, even without GMP support.
1642   Its speed is from a few times better (for small numbers) to over
1643   10,000 times better (just below 2^64).  The new code also runs a
1644   deterministic primality test for each prime factor, not just a
1645   probabilistic test.
1647   seq is now up to 70 times faster than it was in coreutils-8.19 and prior,
1648   but only with non-negative whole numbers, an increment of 1, and no
1649   format-changing options.
1651   stat and tail know about ZFS, VZFS and VMHGFS.  stat -f --format=%T now
1652   reports the file system type, and tail -f now uses inotify for files on
1653   ZFS and VZFS file systems, rather than the default (for unknown file
1654   system types) of issuing a warning and reverting to polling.  tail -f
1655   still uses polling for files on VMHGFS file systems.
1657 ** Build-related
1659   root-only tests now check for permissions of our dummy user,
1660   $NON_ROOT_USERNAME, before trying to run binaries from the build directory.
1661   Before, we would get hard-to-diagnose reports of failing root-only tests.
1662   Now, those tests are skipped with a useful diagnostic when the root tests
1663   are run without following the instructions in README.
1665   We now build most directories using non-recursive make rules.  I.e.,
1666   rather than running make in man/, lib/, src/, tests/, instead, the top
1667   level Makefile.am includes a $dir/local.mk that describes how to build
1668   the targets in the corresponding directory.  Two directories remain
1669   unconverted: po/, gnulib-tests/.  One nice side-effect is that the more
1670   accurate dependencies have eliminated a nagging occasional failure that
1671   was seen when running parallel "make syntax-check".
1674 * Noteworthy changes in release 8.19 (2012-08-20) [stable]
1676 ** Bug fixes
1678   df now fails when the list of mounted file systems (/etc/mtab) cannot
1679   be read, yet the file system type information is needed to process
1680   certain options like -a, -l, -t and -x.
1681   [This bug was present in "the beginning".]
1683   sort -u could fail to output one or more result lines.
1684   For example, this command would fail to print "1":
1685   (yes 7 | head -11; echo 1) | sort --p=1 -S32b -u
1686   [bug introduced in coreutils-8.6]
1688   sort -u could read freed memory.
1689   For example, this evokes a read from freed memory:
1690   perl -le 'print "a\n"."0"x900'|valgrind sort --p=1 -S32b -u>/dev/null
1691   [bug introduced in coreutils-8.6]
1693 ** New features
1695   rm now accepts the --dir (-d) option which makes it remove empty directories.
1696   Since removing empty directories is relatively safe, this option can be
1697   used as a part of the alias rm='rm --dir'.  This improves compatibility
1698   with Mac OS X and BSD systems which also honor the -d option.
1701 * Noteworthy changes in release 8.18 (2012-08-12) [stable]
1703 ** Bug fixes
1705   cksum now prints checksums atomically so that concurrent
1706   processes will not intersperse their output.
1707   [the bug dates back to the initial implementation]
1709   date -d "$(printf '\xb0')" would print 00:00:00 with today's date
1710   rather than diagnosing the invalid input.  Now it reports this:
1711   date: invalid date '\260'
1712   [This bug was present in "the beginning".]
1714   df no longer outputs control characters present in the mount point name.
1715   Such characters are replaced with '?', so for example, scripts consuming
1716   lines output by df, can work reliably.
1717   [This bug was present in "the beginning".]
1719   df --total now exits with an appropriate diagnostic and error code, when
1720   file system --type options do not lead to a processed file system.
1721   [This bug dates back to when --total was added in coreutils-7.0]
1723   head --lines=-N (-n-N) now resets the read pointer of a seekable input file.
1724   This means that "head -n-3" no longer consumes all of its input, and lines
1725   not output by head may be processed by other programs.  For example, this
1726   command now prints the final line, 2, while before it would print nothing:
1727     seq 2 > k; (head -n-1 > /dev/null; cat) < k
1728   [This bug was present in "the beginning".]
1730   ls --color would mis-color relative-named symlinks in /
1731   [bug introduced in coreutils-8.17]
1733   split now ensures it doesn't overwrite the input file with generated output.
1734   [the bug dates back to the initial implementation]
1736   stat and df now report the correct file system usage,
1737   in all situations on GNU/Linux, by correctly determining the block size.
1738   [df bug since coreutils-5.0.91, stat bug since the initial implementation]
1740   tail -f no longer tries to use inotify on AUFS or PanFS file systems
1741   [you might say this was introduced in coreutils-7.5, along with inotify
1742    support, but even now, its magic number isn't in the usual place.]
1744 ** New features
1746   stat -f recognizes the new remote file system types: aufs, panfs.
1748 ** Changes in behavior
1750   su: this program has been removed.  We stopped installing "su" by
1751   default with the release of coreutils-6.9.90 on 2007-12-01.  Now,
1752   that the util-linux package has the union of the Suse and Fedora
1753   patches as well as enough support to build on the Hurd, we no longer
1754   have any reason to include it here.
1756 ** Improvements
1758   sort avoids redundant processing in the presence of inaccessible inputs,
1759   or unwritable output.  Sort now diagnoses certain errors at start-up,
1760   rather than after potentially expensive processing.
1762   sort now allocates no more than 75% of physical memory by default,
1763   to better share system resources, and thus operate more efficiently.
1764   [The default max memory usage changed from 50% to 100% in coreutils-8.16]
1767 * Noteworthy changes in release 8.17 (2012-05-10) [stable]
1769 ** Bug fixes
1771   id and groups, when invoked with no user name argument, would print
1772   the default group ID listed in the password database, and sometimes
1773   that ID would be neither real nor effective.  For example, when run
1774   set-GID, or in a session for which the default group has just been
1775   changed, the new group ID would be listed, even though it is not
1776   yet effective. [bug introduced in coreutils-8.1]
1778   cp S D is no longer subject to a race: if an existing D were removed
1779   between the initial stat and subsequent open-without-O_CREATE, cp would
1780   fail with a confusing diagnostic saying that the destination, D, was not
1781   found.  Now, in this unusual case, it retries the open (but with O_CREATE),
1782   and hence usually succeeds.  With NFS attribute caching, the condition
1783   was particularly easy to trigger, since there, the removal of D could
1784   precede the initial stat.  [This bug was present in "the beginning".]
1786   split --number=C /dev/null no longer appears to infloop on GNU/Hurd
1787   [bug introduced in coreutils-8.8]
1789   stat no longer reports a negative file size as a huge positive number.
1790   [bug present since 'stat' was introduced in fileutils-4.1.9]
1792 ** New features
1794   split and truncate now allow any seekable files in situations where
1795   the file size is needed, instead of insisting on regular files.
1797   fmt now accepts the --goal=WIDTH (-g) option.
1799   stat -f recognizes new file system types: bdevfs, inodefs, qnx6
1801 ** Changes in behavior
1803   cp,mv,install,cat,split: now read and write a minimum of 64KiB at a time.
1804   This was previously 32KiB and increasing to 64KiB was seen to increase
1805   throughput by about 10% when reading cached files on 64 bit GNU/Linux.
1807   cp --attributes-only no longer truncates any existing destination file,
1808   allowing for more general copying of attributes from one file to another.
1811 * Noteworthy changes in release 8.16 (2012-03-26) [stable]
1813 ** New features
1815   As a GNU extension, 'chmod', 'mkdir', and 'install' now accept operators
1816   '-', '+', '=' followed by octal modes; for example, 'chmod +40 FOO' enables
1817   and 'chmod -40 FOO' disables FOO's group-read permissions.  Operator
1818   numeric modes can be combined with symbolic modes by separating them with
1819   commas; for example, =0,u+r clears all permissions except for enabling
1820   user-read permissions.  Unlike ordinary numeric modes, operator numeric
1821   modes do not preserve directory setuid and setgid bits; for example,
1822   'chmod =0 FOO' clears all of FOO's permissions, including setuid and setgid.
1824   Also, ordinary numeric modes with five or more digits no longer preserve
1825   setuid and setgid bits, so that 'chmod 00755 FOO' now clears FOO's setuid
1826   and setgid bits.  This allows scripts to be portable to other systems which
1827   lack the GNU extension mentioned previously, and where ordinary numeric
1828   modes do not preserve directory setuid and setgid bits.
1830   dd now accepts the count_bytes, skip_bytes iflags and the seek_bytes
1831   oflag, to more easily allow processing portions of a file.
1833   dd now accepts the conv=sparse flag to attempt to create sparse
1834   output, by seeking rather than writing to the output file.
1836   ln now accepts the --relative option, to generate a relative
1837   symbolic link to a target, irrespective of how the target is specified.
1839   split now accepts an optional "from" argument to --numeric-suffixes,
1840   which changes the start number from the default of 0.
1842   split now accepts the --additional-suffix option, to append an
1843   additional static suffix to output file names.
1845   basename now supports the -a and -s options, which allow processing
1846   of more than one argument at a time.  Also the complementary
1847   -z option was added to delimit output items with the NUL character.
1849   dirname now supports more than one argument.  Also the complementary
1850   -z option was added to delimit output items with the NUL character.
1852 ** Bug fixes
1854   du --one-file-system (-x) would ignore any non-directory specified on
1855   the command line.  For example, "touch f; du -x f" would print nothing.
1856   [bug introduced in coreutils-8.15]
1858   mv now lets you move a symlink onto a same-inode destination file that
1859   has two or more hard links.  Before, it would reject that, saying that
1860   they are the same, implicitly warning you that the move would result in
1861   data loss.  In this unusual case, when not moving the symlink onto its
1862   referent, there is no risk of data loss, since the symlink will
1863   typically still point to one of the hard links.
1865   "mv A B" could succeed, yet A would remain.  This would happen only when
1866   both A and B were hard links to the same symlink, and with a kernel for
1867   which rename("A","B") does nothing and returns 0 (POSIX mandates this
1868   surprising rename no-op behavior).  Now, mv handles this case by skipping
1869   the usually-useless rename and simply unlinking A.
1871   realpath no longer mishandles a root directory.  This was most
1872   noticeable on platforms where // is a different directory than /,
1873   but could also be observed with --relative-base=/ or
1874   --relative-to=/.  [bug since the beginning, in 8.15]
1876 ** Improvements
1878   ls can be much more efficient, especially with large directories on file
1879   systems for which getfilecon-, ACL-check- and XATTR-check-induced syscalls
1880   fail with ENOTSUP or similar.
1882   'realpath --relative-base=dir' in isolation now implies '--relative-to=dir'
1883   instead of causing a usage failure.
1885   split now supports an unlimited number of split files as default behavior.
1888 * Noteworthy changes in release 8.15 (2012-01-06) [stable]
1890 ** New programs
1892   realpath: print resolved file names.
1894 ** Bug fixes
1896   du -x no longer counts root directories of other file systems.
1897   [bug introduced in coreutils-5.1.0]
1899   ls --color many-entry-directory was uninterruptible for too long
1900   [bug introduced in coreutils-5.2.1]
1902   ls's -k option no longer affects how ls -l outputs file sizes.
1903   It now affects only the per-directory block counts written by -l,
1904   and the sizes written by -s.  This is for compatibility with BSD
1905   and with POSIX 2008.  Because -k is no longer equivalent to
1906   --block-size=1KiB, a new long option --kibibyte stands for -k.
1907   [bug introduced in coreutils-4.5.4]
1909   ls -l would leak a little memory (security context string) for each
1910   nonempty directory listed on the command line, when using SELinux.
1911   [bug probably introduced in coreutils-6.10 with SELinux support]
1913   rm -rf DIR would fail with "Device or resource busy" on Cygwin with NWFS
1914   and NcFsd file systems.  This did not affect Unix/Linux-based kernels.
1915   [bug introduced in coreutils-8.0, when rm began using fts]
1917   split -n 1/2 FILE no longer fails when operating on a growing file, or
1918   (on some systems) when operating on a non-regular file like /dev/zero.
1919   It would report "/dev/zero: No such file or directory" even though
1920   the file obviously exists.  Same for -n l/2.
1921   [bug introduced in coreutils-8.8, with the addition of the -n option]
1923   stat -f now recognizes the FhGFS and PipeFS file system types.
1925   tac no longer fails to handle two or more non-seekable inputs
1926   [bug introduced in coreutils-5.3.0]
1928   tail -f no longer tries to use inotify on GPFS or FhGFS file systems
1929   [you might say this was introduced in coreutils-7.5, along with inotify
1930    support, but the new magic numbers weren't in the usual places then.]
1932 ** Changes in behavior
1934   df avoids long UUID-including file system names in the default listing.
1935   With recent enough kernel/tools, these long names would be used, pushing
1936   second and subsequent columns far to the right.  Now, when a long name
1937   refers to a symlink, and no file systems are specified, df prints the
1938   usually-short referent instead.
1940   tail -f now uses polling (not inotify) when any of its file arguments
1941   resides on a file system of unknown type.  In addition, for each such
1942   argument, tail -f prints a warning with the FS type magic number and a
1943   request to report it to the bug-reporting address.
1946 * Noteworthy changes in release 8.14 (2011-10-12) [stable]
1948 ** Bug fixes
1950   ls --dereference no longer outputs erroneous "argetm" strings for
1951   dangling symlinks when an 'ln=target' entry is in $LS_COLORS.
1952   [bug introduced in fileutils-4.0]
1954   ls -lL symlink once again properly prints "+" when the referent has an ACL.
1955   [bug introduced in coreutils-8.13]
1957   sort -g no longer infloops for certain inputs containing NaNs
1958   [bug introduced in coreutils-8.5]
1960 ** Improvements
1962   md5sum --check now supports the -r format from the corresponding BSD tool.
1963   This also affects sha1sum, sha224sum, sha384sum and sha512sum.
1965   pwd now works also on systems without openat.  On such systems, pwd
1966   would fail when run from a directory whose absolute name contained
1967   more than PATH_MAX / 3 components.  The df, stat and readlink programs
1968   are also affected due to their use of the canonicalize_* functions.
1970 ** Changes in behavior
1972   timeout now only processes the first signal received from the set
1973   it is handling (SIGTERM, SIGINT, ...).  This is to support systems that
1974   implicitly create threads for some timer functions (like GNU/kFreeBSD).
1976 ** Build-related
1978   "make dist" no longer builds .tar.gz files.
1979   xz is portable enough and in wide-enough use that distributing
1980   only .tar.xz files is enough.
1983 * Noteworthy changes in release 8.13 (2011-09-08) [stable]
1985 ** Bug fixes
1987   chown and chgrp with the -v --from= options, now output the correct owner.
1988   I.e., for skipped files, the original ownership is output, not the new one.
1989   [bug introduced in sh-utils-2.0g]
1991   cp -r could mistakenly change the permissions of an existing destination
1992   directory.  [bug introduced in coreutils-6.8]
1994   cp -u -p would fail to preserve one hard link for each up-to-date copy
1995   of a src-hard-linked name in the destination tree.  I.e., if s/a and s/b
1996   are hard-linked and dst/s/a is up to date, "cp -up s dst" would copy s/b
1997   to dst/s/b rather than simply linking dst/s/b to dst/s/a.
1998   [This bug appears to have been present in "the beginning".]
2000   fts-using tools (rm, du, chmod, chgrp, chown, chcon) no longer use memory
2001   proportional to the number of entries in each directory they process.
2002   Before, rm -rf 4-million-entry-directory would consume about 1GiB of memory.
2003   Now, it uses less than 30MB, no matter how many entries there are.
2004   [this bug was inherent in the use of fts: thus, for rm the bug was
2005   introduced in coreutils-8.0.  The prior implementation of rm did not use
2006   as much memory.  du, chmod, chgrp and chown started using fts in 6.0.
2007   chcon was added in coreutils-6.9.91 with fts support.  ]
2009   pr -T no longer ignores a specified LAST_PAGE to stop at.
2010   [bug introduced in textutils-1.19q]
2012   printf '%d' '"' no longer accesses out-of-bounds memory in the diagnostic.
2013   [bug introduced in sh-utils-1.16]
2015   split --number l/... no longer creates extraneous files in certain cases.
2016   [bug introduced in coreutils-8.8]
2018   timeout now sends signals to commands that create their own process group.
2019   timeout is no longer confused when starting off with a child process.
2020   [bugs introduced in coreutils-7.0]
2022   unexpand -a now aligns correctly when there are spaces spanning a tabstop,
2023   followed by a tab.  In that case a space was dropped, causing misalignment.
2024   We also now ensure that a space never precedes a tab.
2025   [bug introduced in coreutils-5.3.0]
2027 ** Changes in behavior
2029   chmod, chown and chgrp now output the original attributes in messages,
2030   when -v or -c specified.
2032   cp -au (where --preserve=links is implicit) may now replace newer
2033   files in the destination, to mirror hard links from the source.
2035 ** New features
2037   date now accepts ISO 8601 date-time strings with "T" as the
2038   separator.  It has long parsed dates like "2004-02-29 16:21:42"
2039   with a space between the date and time strings.  Now it also parses
2040   "2004-02-29T16:21:42" and fractional-second and time-zone-annotated
2041   variants like "2004-02-29T16:21:42.333-07:00"
2043   md5sum accepts the new --strict option.  With --check, it makes the
2044   tool exit non-zero for any invalid input line, rather than just warning.
2045   This also affects sha1sum, sha224sum, sha384sum and sha512sum.
2047   split accepts a new --filter=CMD option.  With it, split filters output
2048   through CMD.  CMD may use the $FILE environment variable, which is set to
2049   the nominal output file name for each invocation of CMD.  For example, to
2050   split a file into 3 approximately equal parts, which are then compressed:
2051     split -n3 --filter='xz > $FILE.xz' big
2052   Note the use of single quotes, not double quotes.
2053   That creates files named xaa.xz, xab.xz and xac.xz.
2055   timeout accepts a new --foreground option, to support commands not started
2056   directly from a shell prompt, where the command is interactive or needs to
2057   receive signals initiated from the terminal.
2059 ** Improvements
2061   cp -p now copies trivial NSFv4 ACLs on Solaris 10.  Before, it would
2062   mistakenly apply a non-trivial ACL to the destination file.
2064   cp and ls now support HP-UX 11.11's ACLs, thanks to improved support
2065   in gnulib.
2067   df now supports disk partitions larger than 4 TiB on MacOS X 10.5
2068   or newer and on AIX 5.2 or newer.
2070   join --check-order now prints "join: FILE:LINE_NUMBER: bad_line" for an
2071   unsorted input, rather than e.g., "join: file 1 is not in sorted order".
2073   shuf outputs small subsets of large permutations much more efficiently.
2074   For example 'shuf -i1-$((2**32-1)) -n2' no longer exhausts memory.
2076   stat -f now recognizes the GPFS, MQUEUE and PSTOREFS file system types.
2078   timeout now supports sub-second timeouts.
2080 ** Build-related
2082   Changes inherited from gnulib address a build failure on HP-UX 11.11
2083   when using /opt/ansic/bin/cc.
2085   Numerous portability and build improvements inherited via gnulib.
2088 * Noteworthy changes in release 8.12 (2011-04-26) [stable]
2090 ** Bug fixes
2092   tail's --follow=name option no longer implies --retry on systems
2093   with inotify support.  [bug introduced in coreutils-7.5]
2095 ** Changes in behavior
2097   cp's extent-based (FIEMAP) copying code is more reliable in the face
2098   of varying and undocumented file system semantics:
2099   - it no longer treats unwritten extents specially
2100   - a FIEMAP-based extent copy always uses the FIEMAP_FLAG_SYNC flag.
2101       Before, it would incur the performance penalty of that sync only
2102       for 2.6.38 and older kernels.  We thought all problems would be
2103       resolved for 2.6.39.
2104   - it now attempts a FIEMAP copy only on a file that appears sparse.
2105       Sparse files are relatively unusual, and the copying code incurs
2106       the performance penalty of the now-mandatory sync only for them.
2108 ** Portability
2110   dd once again compiles on AIX 5.1 and 5.2
2113 * Noteworthy changes in release 8.11 (2011-04-13) [stable]
2115 ** Bug fixes
2117   cp -a --link would not create a hardlink to a symlink, instead
2118   copying the symlink and then not preserving its timestamp.
2119   [bug introduced in coreutils-8.0]
2121   cp now avoids FIEMAP issues with BTRFS before Linux 2.6.38,
2122   which could result in corrupt copies of sparse files.
2123   [bug introduced in coreutils-8.10]
2125   cut could segfault when invoked with a user-specified output
2126   delimiter and an unbounded range like "-f1234567890-".
2127   [bug introduced in coreutils-5.3.0]
2129   du would infloop when given --files0-from=DIR
2130   [bug introduced in coreutils-7.1]
2132   sort no longer spawns 7 worker threads to sort 16 lines
2133   [bug introduced in coreutils-8.6]
2135   touch built on Solaris 9 would segfault when run on Solaris 10
2136   [bug introduced in coreutils-8.8]
2138   wc would dereference a NULL pointer upon an early out-of-memory error
2139   [bug introduced in coreutils-7.1]
2141 ** New features
2143   dd now accepts the 'nocache' flag to the iflag and oflag options,
2144   which will discard any cache associated with the files, or
2145   processed portion thereof.
2147   dd now warns that 'iflag=fullblock' should be used,
2148   in various cases where partial reads can cause issues.
2150 ** Changes in behavior
2152   cp now avoids syncing files when possible, when doing a FIEMAP copy.
2153   The sync is only needed on Linux kernels before 2.6.39.
2154   [The sync was introduced in coreutils-8.10]
2156   cp now copies empty extents efficiently, when doing a FIEMAP copy.
2157   It no longer reads the zero bytes from the input, and also can efficiently
2158   create a hole in the output file when --sparse=always is specified.
2160   df now aligns columns consistently, and no longer wraps entries
2161   with longer device identifiers, over two lines.
2163   install now rejects its long-deprecated --preserve_context option.
2164   Use --preserve-context instead.
2166   test now accepts "==" as a synonym for "="
2169 * Noteworthy changes in release 8.10 (2011-02-04) [stable]
2171 ** Bug fixes
2173   du would abort with a failed assertion when two conditions are met:
2174   part of the hierarchy being traversed is moved to a higher level in the
2175   directory tree, and there is at least one more command line directory
2176   argument following the one containing the moved sub-tree.
2177   [bug introduced in coreutils-5.1.0]
2179   join --header now skips the ordering check for the first line
2180   even if the other file is empty.  [bug introduced in coreutils-8.5]
2182   join -v2 now ensures the default output format prints the match field
2183   at the start of the line when it is different to the match field for
2184   the first file. [bug present in "the beginning".]
2186   rm -f no longer fails for EINVAL or EILSEQ on file systems that
2187   reject file names invalid for that file system.
2189   uniq -f NUM no longer tries to process fields after end of line.
2190   [bug introduced in coreutils-7.0]
2192 ** New features
2194   cp now copies sparse files efficiently on file systems with FIEMAP
2195   support (ext4, btrfs, xfs, ocfs2).  Before, it had to read 2^20 bytes
2196   when copying a 1MiB sparse file.  Now, it copies bytes only for the
2197   non-sparse sections of a file.  Similarly, to induce a hole in the
2198   output file, it had to detect a long sequence of zero bytes.  Now,
2199   it knows precisely where each hole in an input file is, and can
2200   reproduce them efficiently in the output file.  mv also benefits
2201   when it resorts to copying, e.g., between file systems.
2203   join now supports -o 'auto' which will automatically infer the
2204   output format from the first line in each file, to ensure
2205   the same number of fields are output for each line.
2207 ** Changes in behavior
2209   join no longer reports disorder when one of the files is empty.
2210   This allows one to use join as a field extractor like:
2211   join -a1 -o 1.3,1.1 - /dev/null
2214 * Noteworthy changes in release 8.9 (2011-01-04) [stable]
2216 ** Bug fixes
2218   split no longer creates files with a suffix length that
2219   is dependent on the number of bytes or lines per file.
2220   [bug introduced in coreutils-8.8]
2223 * Noteworthy changes in release 8.8 (2010-12-22) [stable]
2225 ** Bug fixes
2227   cp -u no longer does unnecessary copying merely because the source
2228   has finer-grained timestamps than the destination.
2230   od now prints floating-point numbers without losing information, and
2231   it no longer omits spaces between floating-point columns in some cases.
2233   sort -u with at least two threads could attempt to read through a
2234   corrupted pointer. [bug introduced in coreutils-8.6]
2236   sort with at least two threads and with blocked output would busy-loop
2237   (spinlock) all threads, often using 100% of available CPU cycles to
2238   do no work.  I.e., "sort < big-file | less" could waste a lot of power.
2239   [bug introduced in coreutils-8.6]
2241   sort with at least two threads no longer segfaults due to use of pointers
2242   into the stack of an expired thread. [bug introduced in coreutils-8.6]
2244   sort --compress no longer mishandles subprocesses' exit statuses,
2245   no longer hangs indefinitely due to a bug in waiting for subprocesses,
2246   and no longer generates many more than NMERGE subprocesses.
2248   sort -m -o f f ... f no longer dumps core when file descriptors are limited.
2250 ** Changes in behavior
2252   sort will not create more than 8 threads by default due to diminishing
2253   performance gains.  Also the --parallel option is no longer restricted
2254   to the number of available processors.
2256 ** New features
2258   split accepts the --number/-n option to generate a specific number of
2259   files, as well as the --elide-empty-files/-e and --unbuffered/-u
2260   options to fine-tune the resulting output.
2263 * Noteworthy changes in release 8.7 (2010-11-13) [stable]
2265 ** Bug fixes
2267   cp, install, mv, and touch no longer crash when setting file times
2268   on Solaris 10 Update 9 [Solaris PatchID 144488 and newer expose a
2269   latent bug introduced in coreutils 8.1, and possibly a second latent
2270   bug going at least as far back as coreutils 5.97]
2272   csplit no longer corrupts heap when writing more than 999 files,
2273   nor does it leak memory for every chunk of input processed
2274   [the bugs were present in the initial implementation]
2276   tail -F once again notices changes in a currently unavailable
2277   remote directory [bug introduced in coreutils-7.5]
2279 ** Changes in behavior
2281   cp --attributes-only now completely overrides --reflink.
2282   Previously a reflink was needlessly attempted.
2284   stat's %X, %Y, and %Z directives once again print only the integer
2285   part of seconds since the epoch.  This reverts a change from
2286   coreutils-8.6, that was deemed unnecessarily disruptive.
2287   To obtain a nanosecond-precision timestamp for %X use %.X;
2288   if you want (say) just 3 fractional digits, use %.3X.
2289   Likewise for %Y and %Z.
2291   stat's new %W format directive would print floating point seconds.
2292   However, with the above change to %X, %Y and %Z, we've made %W work
2293   the same way as the others.
2295   stat gained support for several printf-style flags, such as %'s for
2296   listing sizes with the current locale's thousands separator.
2299 * Noteworthy changes in release 8.6 (2010-10-15) [stable]
2301 ** Bug fixes
2303   du no longer multiply counts a file that is a directory or whose
2304   link count is 1, even if the file is reached multiple times by
2305   following symlinks or via multiple arguments.
2307   du -H and -L now consistently count pointed-to files instead of
2308   symbolic links, and correctly diagnose dangling symlinks.
2310   du --ignore=D now ignores directory D even when that directory is
2311   found to be part of a directory cycle.  Before, du would issue a
2312   "NOTIFY YOUR SYSTEM MANAGER" diagnostic and fail.
2314   split now diagnoses read errors rather than silently exiting.
2315   [bug introduced in coreutils-4.5.8]
2317   tac would perform a double-free when given an input line longer than 16KiB.
2318   [bug introduced in coreutils-8.3]
2320   tail -F once again notices changes in a currently unavailable directory,
2321   and works around a Linux kernel bug where inotify runs out of resources.
2322   [bugs introduced in coreutils-7.5]
2324   tr now consistently handles case conversion character classes.
2325   In some locales, valid conversion specifications caused tr to abort,
2326   while in all locales, some invalid specifications were undiagnosed.
2327   [bugs introduced in coreutils 6.9.90 and 6.9.92]
2329 ** New features
2331   cp now accepts the --attributes-only option to not copy file data,
2332   which is useful for efficiently modifying files.
2334   du recognizes -d N as equivalent to --max-depth=N, for compatibility
2335   with FreeBSD.
2337   sort now accepts the --debug option, to highlight the part of the
2338   line significant in the sort, and warn about questionable options.
2340   sort now supports -d, -f, -i, -R, and -V in any combination.
2342   stat now accepts the %m format directive to output the mount point
2343   for a file.  It also accepts the %w and %W format directives for
2344   outputting the birth time of a file, if one is available.
2346 ** Changes in behavior
2348   df now consistently prints the device name for a bind mounted file,
2349   rather than its aliased target.
2351   du now uses less than half as much memory when operating on trees
2352   with many hard-linked files.  With --count-links (-l), or when
2353   operating on trees with no hard-linked files, there is no change.
2355   ls -l now uses the traditional three field time style rather than
2356   the wider two field numeric ISO style, in locales where a style has
2357   not been specified.  The new approach has nicer behavior in some
2358   locales, including English, which was judged to outweigh the disadvantage
2359   of generating less-predictable and often worse output in poorly-configured
2360   locales where there is an onus to specify appropriate non-default styles.
2361   [The old behavior was introduced in coreutils-6.0 and had been removed
2362    for English only using a different method since coreutils-8.1]
2364   rm's -d now evokes an error;  before, it was silently ignored.
2366   sort -g now uses long doubles for greater range and precision.
2368   sort -h no longer rejects numbers with leading or trailing ".", and
2369   no longer accepts numbers with multiple ".".  It now considers all
2370   zeros to be equal.
2372   sort now uses the number of available processors to parallelize
2373   the sorting operation.  The number of sorts run concurrently can be
2374   limited with the --parallel option or with external process
2375   control like taskset for example.
2377   stat now provides translated output when no format is specified.
2379   stat no longer accepts the --context (-Z) option.  Initially it was
2380   merely accepted and ignored, for compatibility.  Starting two years
2381   ago, with coreutils-7.0, its use evoked a warning.  Printing the
2382   SELinux context of a file can be done with the %C format directive,
2383   and the default output when no format is specified now automatically
2384   includes %C when context information is available.
2386   stat no longer accepts the %C directive when the --file-system
2387   option is in effect, since security context is a file attribute
2388   rather than a file system attribute.
2390   stat now outputs the full sub-second resolution for the atime,
2391   mtime, and ctime values since the Epoch, when using the %X, %Y, and
2392   %Z directives of the --format option.  This matches the fact that
2393   %x, %y, and %z were already doing so for the human-readable variant.
2395   touch's --file option is no longer recognized.  Use --reference=F (-r)
2396   instead.  --file has not been documented for 15 years, and its use has
2397   elicited a warning since coreutils-7.1.
2399   truncate now supports setting file sizes relative to a reference file.
2400   Also errors are no longer suppressed for unsupported file types, and
2401   relative sizes are restricted to supported file types.
2404 * Noteworthy changes in release 8.5 (2010-04-23) [stable]
2406 ** Bug fixes
2408   cp and mv once again support preserving extended attributes.
2409   [bug introduced in coreutils-8.4]
2411   cp now preserves "capabilities" when also preserving file ownership.
2413   ls --color once again honors the 'NORMAL' dircolors directive.
2414   [bug introduced in coreutils-6.11]
2416   sort -M now handles abbreviated months that are aligned using blanks
2417   in the locale database.  Also locales with 8 bit characters are
2418   handled correctly, including multi byte locales with the caveat
2419   that multi byte characters are matched case sensitively.
2421   sort again handles obsolescent key formats (+POS -POS) correctly.
2422   Previously if -POS was specified, 1 field too many was used in the sort.
2423   [bug introduced in coreutils-7.2]
2425 ** New features
2427   join now accepts the --header option, to treat the first line of each
2428   file as a header line to be joined and printed unconditionally.
2430   timeout now accepts the --kill-after option which sends a kill
2431   signal to the monitored command if it's still running the specified
2432   duration after the initial signal was sent.
2434   who: the "+/-" --mesg (-T) indicator of whether a user/tty is accepting
2435   messages could be incorrectly listed as "+", when in fact, the user was
2436   not accepting messages (mesg no).  Before, who would examine only the
2437   permission bits, and not consider the group of the TTY device file.
2438   Thus, if a login tty's group would change somehow e.g., to "root",
2439   that would make it unwritable (via write(1)) by normal users, in spite
2440   of whatever the permission bits might imply.  Now, when configured
2441   using the --with-tty-group[=NAME] option, who also compares the group
2442   of the TTY device with NAME (or "tty" if no group name is specified).
2444 ** Changes in behavior
2446   ls --color no longer emits the final 3-byte color-resetting escape
2447   sequence when it would be a no-op.
2449   join -t '' no longer emits an error and instead operates on
2450   each line as a whole (even if they contain NUL characters).
2453 * Noteworthy changes in release 8.4 (2010-01-13) [stable]
2455 ** Bug fixes
2457   nproc --all is now guaranteed to be as large as the count
2458   of available processors, which may not have been the case
2459   on GNU/Linux systems with neither /proc nor /sys available.
2460   [bug introduced in coreutils-8.1]
2462 ** Build-related
2464   Work around a build failure when using buggy <sys/capability.h>.
2465   Alternatively, configure with --disable-libcap.
2467   Compilation would fail on systems using glibc-2.7..2.9 due to changes in
2468   gnulib's wchar.h that tickled a bug in at least those versions of glibc's
2469   own <wchar.h> header.  Now, gnulib works around the bug in those older
2470   glibc <wchar.h> headers.
2472   Building would fail with a link error (cp/copy.o) when XATTR headers
2473   were installed without the corresponding library.  Now, configure
2474   detects that and disables xattr support, as one would expect.
2477 * Noteworthy changes in release 8.3 (2010-01-07) [stable]
2479 ** Bug fixes
2481   cp -p, install -p, mv, and touch -c could trigger a spurious error
2482   message when using new glibc coupled with an old kernel.
2483   [bug introduced in coreutils-6.12].
2485   ls -l --color no longer prints "argetm" in front of dangling
2486   symlinks when the 'LINK target' directive was given to dircolors.
2487   [bug introduced in fileutils-4.0]
2489   pr's page header was improperly formatted for long file names.
2490   [bug introduced in coreutils-7.2]
2492   rm -r --one-file-system works once again.
2493   The rewrite to make rm use fts introduced a regression whereby
2494   a commmand of the above form would fail for all subdirectories.
2495   [bug introduced in coreutils-8.0]
2497   stat -f recognizes more file system types: k-afs, fuseblk, gfs/gfs2, ocfs2,
2498   and rpc_pipefs. Also Minix V3 is displayed correctly as minix3, not minux3.
2499   [bug introduced in coreutils-8.1]
2501   tail -f (inotify-enabled) once again works with remote files.
2502   The use of inotify with remote files meant that any changes to those
2503   files that was not done from the local system would go unnoticed.
2504   [bug introduced in coreutils-7.5]
2506   tail -F (inotify-enabled) would abort when a tailed file is repeatedly
2507   renamed-aside and then recreated.
2508   [bug introduced in coreutils-7.5]
2510   tail -F (inotify-enabled) could fail to follow renamed files.
2511   E.g., given a "tail -F a b" process, running "mv a b" would
2512   make tail stop tracking additions to "b".
2513   [bug introduced in coreutils-7.5]
2515   touch -a and touch -m could trigger bugs in some file systems, such
2516   as xfs or ntfs-3g, and fail to update timestamps.
2517   [bug introduced in coreutils-8.1]
2519   wc now prints counts atomically so that concurrent
2520   processes will not intersperse their output.
2521   [the issue dates back to the initial implementation]
2524 * Noteworthy changes in release 8.2 (2009-12-11) [stable]
2526 ** Bug fixes
2528   id's use of mgetgroups no longer writes beyond the end of a malloc'd buffer
2529   [bug introduced in coreutils-8.1]
2531   id no longer crashes on systems without supplementary group support.
2532   [bug introduced in coreutils-8.1]
2534   rm once again handles zero-length arguments properly.
2535   The rewrite to make rm use fts introduced a regression whereby
2536   a command like "rm a '' b" would fail to remove "a" and "b", due to
2537   the presence of the empty string argument.
2538   [bug introduced in coreutils-8.0]
2540   sort is now immune to the signal handling of its parent.
2541   Specifically sort now doesn't exit with an error message
2542   if it uses helper processes for compression and its parent
2543   ignores CHLD signals. [bug introduced in coreutils-6.9]
2545   tail without -f no longer accesses uninitialized memory
2546   [bug introduced in coreutils-7.6]
2548   timeout is now immune to the signal handling of its parent.
2549   Specifically timeout now doesn't exit with an error message
2550   if its parent ignores CHLD signals. [bug introduced in coreutils-7.6]
2552   a user running "make distcheck" in the coreutils source directory,
2553   with TMPDIR unset or set to the name of a world-writable directory,
2554   and with a malicious user on the same system
2555   was vulnerable to arbitrary code execution
2556   [bug introduced in coreutils-5.0]
2559 * Noteworthy changes in release 8.1 (2009-11-18) [stable]
2561 ** Bug fixes
2563   chcon no longer exits immediately just because SELinux is disabled.
2564   Even then, chcon may still be useful.
2565   [bug introduced in coreutils-8.0]
2567   chcon, chgrp, chmod, chown and du now diagnose an ostensible directory cycle
2568   and arrange to exit nonzero.  Before, they would silently ignore the
2569   offending directory and all "contents."
2571   env -u A=B now fails, rather than silently adding A to the
2572   environment.  Likewise, printenv A=B silently ignores the invalid
2573   name.  [the bugs date back to the initial implementation]
2575   ls --color now handles files with capabilities correctly.  Previously
2576   files with capabilities were often not colored, and also sometimes, files
2577   without capabilites were colored in error. [bug introduced in coreutils-7.0]
2579   md5sum now prints checksums atomically so that concurrent
2580   processes will not intersperse their output.
2581   This also affected sum, sha1sum, sha224sum, sha384sum and sha512sum.
2582   [the bug dates back to the initial implementation]
2584   mktemp no longer leaves a temporary file behind if it was unable to
2585   output the name of the file to stdout.
2586   [the bug dates back to the initial implementation]
2588   nice -n -1 PROGRAM now runs PROGRAM even when its internal setpriority
2589   call fails with errno == EACCES.
2590   [the bug dates back to the initial implementation]
2592   nice, nohup, and su now refuse to execute the subsidiary program if
2593   they detect write failure in printing an otherwise non-fatal warning
2594   message to stderr.
2596   stat -f recognizes more file system types: afs, cifs, anon-inode FS,
2597   btrfs, cgroupfs, cramfs-wend, debugfs, futexfs, hfs, inotifyfs, minux3,
2598   nilfs, securityfs, selinux, xenfs
2600   tail -f (inotify-enabled) now avoids a race condition.
2601   Before, any data appended in the tiny interval between the initial
2602   read-to-EOF and the inotify watch initialization would be ignored
2603   initially (until more data was appended), or forever, if the file
2604   were first renamed or unlinked or never modified.
2605   [The race was introduced in coreutils-7.5]
2607   tail -F (inotify-enabled) now consistently tails a file that has been
2608   replaced via renaming.  That operation provokes either of two sequences
2609   of inotify events.  The less common sequence is now handled as well.
2610   [The bug came with the implementation change in coreutils-7.5]
2612   timeout now doesn't exit unless the command it is monitoring does,
2613   for any specified signal. [bug introduced in coreutils-7.0].
2615 ** Changes in behavior
2617   chroot, env, nice, and su fail with status 125, rather than 1, on
2618   internal error such as failure to parse command line arguments; this
2619   is for consistency with stdbuf and timeout, and avoids ambiguity
2620   with the invoked command failing with status 1.  Likewise, nohup
2621   fails with status 125 instead of 127.
2623   du (due to a change in gnulib's fts) can now traverse NFSv4 automounted
2624   directories in which the stat'd device number of the mount point differs
2625   during a traversal.  Before, it would fail, because such a mismatch would
2626   usually represent a serious error or a subversion attempt.
2628   echo and printf now interpret \e as the Escape character (0x1B).
2630   rm -f /read-only-fs/nonexistent now succeeds and prints no diagnostic
2631   on systems with an unlinkat syscall that sets errno to EROFS in that case.
2632   Before, it would fail with a "Read-only file system" diagnostic.
2633   Also, "rm /read-only-fs/nonexistent" now reports "file not found" rather
2634   than the less precise "Read-only file system" error.
2636 ** New programs
2638   nproc: Print the number of processing units available to a process.
2640 ** New features
2642   env and printenv now accept the option --null (-0), as a means to
2643   avoid ambiguity with newlines embedded in the environment.
2645   md5sum --check now also accepts openssl-style checksums.
2646   So do sha1sum, sha224sum, sha384sum and sha512sum.
2648   mktemp now accepts the option --suffix to provide a known suffix
2649   after the substitution in the template.  Additionally, uses such as
2650   "mktemp fileXXXXXX.txt" are able to infer an appropriate --suffix.
2652   touch now accepts the option --no-dereference (-h), as a means to
2653   change symlink timestamps on platforms with enough support.
2656 * Noteworthy changes in release 8.0 (2009-10-06) [beta]
2658 ** Bug fixes
2660   cp --preserve=xattr and --archive now preserve extended attributes even
2661   when the source file doesn't have write access.
2662   [bug introduced in coreutils-7.1]
2664   touch -t [[CC]YY]MMDDhhmm[.ss] now accepts a timestamp string ending in .60,
2665   to accommodate leap seconds.
2666   [the bug dates back to the initial implementation]
2668   ls --color now reverts to the color of a base file type consistently
2669   when the color of a more specific type is disabled.
2670   [bug introduced in coreutils-5.90]
2672   ls -LR exits with status 2, not 0, when it encounters a cycle
2674   "ls -is" is now consistent with ls -lis in ignoring values returned
2675   from a failed stat/lstat.  For example ls -Lis now prints "?", not "0",
2676   for the inode number and allocated size of a dereferenced dangling symlink.
2678   tail --follow --pid now avoids a race condition where data written
2679   just before the process dies might not have been output by tail.
2680   Also, tail no longer delays at all when the specified pid is not live.
2681   [The race was introduced in coreutils-7.5,
2682    and the unnecessary delay was present since textutils-1.22o]
2684 ** Portability
2686   On Solaris 9, many commands would mistakenly treat file/ the same as
2687   file.  Now, even on such a system, path resolution obeys the POSIX
2688   rules that a trailing slash ensures that the preceding name is a
2689   directory or a symlink to a directory.
2691 ** Changes in behavior
2693   id no longer prints SELinux " context=..." when the POSIXLY_CORRECT
2694   environment variable is set.
2696   readlink -f now ignores a trailing slash when deciding if the
2697   last component (possibly via a dangling symlink) can be created,
2698   since mkdir will succeed in that case.
2700 ** New features
2702   ln now accepts the options --logical (-L) and --physical (-P),
2703   added by POSIX 2008.  The default behavior is -P on systems like
2704   GNU/Linux where link(2) creates hard links to symlinks, and -L on
2705   BSD systems where link(2) follows symlinks.
2707   stat: without -f, a command-line argument of "-" now means standard input.
2708   With --file-system (-f), an argument of "-" is now rejected.
2709   If you really must operate on a file named "-", specify it as
2710   "./-" or use "--" to separate options from arguments.
2712 ** Improvements
2714   rm: rewrite to use gnulib's fts
2715   This makes rm -rf significantly faster (400-500%) in some pathological
2716   cases, and slightly slower (20%) in at least one pathological case.
2718   rm -r deletes deep hierarchies more efficiently.  Before, execution time
2719   was quadratic in the depth of the hierarchy, now it is merely linear.
2720   However, this improvement is not as pronounced as might be expected for
2721   very deep trees, because prior to this change, for any relative name
2722   length longer than 8KiB, rm -r would sacrifice official conformance to
2723   avoid the disproportionate quadratic performance penalty.  Leading to
2724   another improvement:
2726   rm -r is now slightly more standards-conformant when operating on
2727   write-protected files with relative names longer than 8KiB.
2730 * Noteworthy changes in release 7.6 (2009-09-11) [stable]
2732 ** Bug fixes
2734   cp, mv now ignore failure to preserve a symlink timestamp, when it is
2735   due to their running on a kernel older than what was implied by headers
2736   and libraries tested at configure time.
2737   [bug introduced in coreutils-7.5]
2739   cp --reflink --preserve now preserves attributes when cloning a file.
2740   [bug introduced in coreutils-7.5]
2742   cp --preserve=xattr no longer leaks resources on each preservation failure.
2743   [bug introduced in coreutils-7.1]
2745   dd now exits with non-zero status when it encounters a write error while
2746   printing a summary to stderr.
2747   [bug introduced in coreutils-6.11]
2749   dd cbs=N conv=unblock would fail to print a final newline when the size
2750   of the input was not a multiple of N bytes.
2751   [the non-conforming behavior dates back to the initial implementation]
2753   df no longer requires that each command-line argument be readable
2754   [bug introduced in coreutils-7.3]
2756   ls -i now prints consistent inode numbers also for mount points.
2757   This makes ls -i DIR less efficient on systems with dysfunctional readdir,
2758   because ls must stat every file in order to obtain a guaranteed-valid
2759   inode number.  [bug introduced in coreutils-6.0]
2761   tail -f (inotify-enabled) now flushes any initial output before blocking.
2762   Before, this would print nothing and wait: stdbuf -o 4K tail -f /etc/passwd
2763   Note that this bug affects tail -f only when its standard output is buffered,
2764   which is relatively unusual.
2765   [bug introduced in coreutils-7.5]
2767   tail -f once again works with standard input.  inotify-enabled tail -f
2768   would fail when operating on a nameless stdin.  I.e., tail -f < /etc/passwd
2769   would say "tail: cannot watch `-': No such file or directory", yet the
2770   relatively baroque tail -f /dev/stdin < /etc/passwd would work.  Now, the
2771   offending usage causes tail to revert to its conventional sleep-based
2772   (i.e., not inotify-based) implementation.
2773   [bug introduced in coreutils-7.5]
2775 ** Portability
2777   ln, link: link f z/ would mistakenly succeed on Solaris 10, given an
2778   existing file, f, and nothing named "z".  ln -T f z/ has the same problem.
2779   Each would mistakenly create "z" as a link to "f".  Now, even on such a
2780   system, each command reports the error, e.g.,
2781   link: cannot create link `z/' to `f': Not a directory
2783 ** New features
2785   cp --reflink accepts a new "auto" parameter which falls back to
2786   a standard copy if creating a copy-on-write clone is not possible.
2788 ** Changes in behavior
2790   tail -f now ignores "-" when stdin is a pipe or FIFO.
2791   tail-with-no-args now ignores -f unconditionally when stdin is a pipe or FIFO.
2792   Before, it would ignore -f only when no file argument was specified,
2793   and then only when POSIXLY_CORRECT was set.  Now, :|tail -f - terminates
2794   immediately.  Before, it would block indefinitely.
2797 * Noteworthy changes in release 7.5 (2009-08-20) [stable]
2799 ** Bug fixes
2801   dd's oflag=direct option now works even when the size of the input
2802   is not a multiple of e.g., 512 bytes.
2804   dd now handles signals consistently even when they're received
2805   before data copying has started.
2807   install runs faster again with SELinux enabled
2808   [introduced in coreutils-7.0]
2810   ls -1U (with two or more arguments, at least one a nonempty directory)
2811   would print entry names *before* the name of the containing directory.
2812   Also fixed incorrect output of ls -1RU and ls -1sU.
2813   [introduced in coreutils-7.0]
2815   sort now correctly ignores fields whose ending position is specified
2816   before the start position. Previously in numeric mode the remaining
2817   part of the line after the start position was used as the sort key.
2818   [This bug appears to have been present in "the beginning".]
2820   truncate -s failed to skip all whitespace in the option argument in
2821   some locales.
2823 ** New programs
2825   stdbuf: A new program to run a command with modified stdio buffering
2826   for its standard streams.
2828 ** Changes in behavior
2830   ls --color: files with multiple hard links are no longer colored differently
2831   by default. That can be enabled by changing the LS_COLORS environment
2832   variable. You can control that using the MULTIHARDLINK dircolors input
2833   variable which corresponds to the 'mh' LS_COLORS item. Note these variables
2834   were renamed from 'HARDLINK' and 'hl' which were available since
2835   coreutils-7.1 when this feature was introduced.
2837 ** Deprecated options
2839   nl --page-increment: deprecated in favor of --line-increment, the new option
2840   maintains the previous semantics and the same short option, -i.
2842 ** New features
2844   chroot now accepts the options --userspec and --groups.
2846   cp accepts a new option, --reflink: create a lightweight copy
2847   using copy-on-write (COW).  This is currently only supported within
2848   a btrfs file system.
2850   cp now preserves timestamps on symbolic links, when possible
2852   sort accepts a new option, --human-numeric-sort (-h): sort numbers
2853   while honoring human readable suffixes like KiB and MB etc.
2855   tail --follow now uses inotify when possible, to be more responsive
2856   to file changes and more efficient when monitoring many files.
2859 * Noteworthy changes in release 7.4 (2009-05-07) [stable]
2861 ** Bug fixes
2863   date -d 'next mon', when run on a Monday, now prints the date
2864   7 days in the future rather than the current day.  Same for any other
2865   day-of-the-week name, when run on that same day of the week.
2866   [This bug appears to have been present in "the beginning". ]
2868   date -d tuesday, when run on a Tuesday -- using date built from the 7.3
2869   release tarball, not from git -- would print the date 7 days in the future.
2870   Now, it works properly and prints the current date.  That was due to
2871   human error (including not-committed changes in a release tarball)
2872   and the fact that there is no check to detect when the gnulib/ git
2873   submodule is dirty.
2875 ** Build-related
2877   make check: two tests have been corrected
2879 ** Portability
2881   There have been some ACL-related portability fixes for *BSD,
2882   inherited from gnulib.
2885 * Noteworthy changes in release 7.3 (2009-05-01) [stable]
2887 ** Bug fixes
2889   cp now diagnoses failure to preserve selinux/xattr attributes when
2890   --preserve=context,xattr is specified in combination with -a.
2891   Also, cp no longer suppresses attribute-preservation diagnostics
2892   when preserving SELinux context was explicitly requested.
2894   ls now aligns output correctly in the presence of abbreviated month
2895   names from the locale database that have differing widths.
2897   ls -v and sort -V now order names like "#.b#" properly
2899   mv: do not print diagnostics when failing to preserve xattr's on file
2900   systems without xattr support.
2902   sort -m no longer segfaults when its output file is also an input file.
2903   E.g., with this, touch 1; sort -m -o 1 1, sort would segfault.
2904   [introduced in coreutils-7.2]
2906 ** Changes in behavior
2908   shred, sort, shuf: now use an internal pseudorandom generator by default.
2909   This is mainly noticeable in shred where the 3 random passes it does by
2910   default should proceed at the speed of the disk.  Previously /dev/urandom
2911   was used if available, which is relatively slow on GNU/Linux systems.
2913 ** Improved robustness
2915   cp would exit successfully after copying less than the full contents
2916   of a file larger than ~4000 bytes from a linux-/proc file system to a
2917   destination file system with a fundamental block size of 4KiB or greater.
2918   Reading into a 4KiB-or-larger buffer, cp's "read" syscall would return
2919   a value smaller than 4096, and cp would interpret that as EOF (POSIX
2920   allows this).  This optimization, now removed, saved 50% of cp's read
2921   syscalls when copying small files.  Affected linux kernels: at least
2922   2.6.9 through 2.6.29.
2923   [the optimization was introduced in coreutils-6.0]
2925 ** Portability
2927   df now pre-mounts automountable directories even with automounters for
2928   which stat-like syscalls no longer provoke mounting.  Now, df uses open.
2930   'id -G $USER' now works correctly even on Darwin and NetBSD. Previously it
2931   would either truncate the group list to 10, or go into an infinite loop,
2932   due to their non-standard getgrouplist implementations.
2933   [truncation introduced in coreutils-6.11]
2934   [infinite loop introduced in coreutils-7.1]
2937 * Noteworthy changes in release 7.2 (2009-03-31) [stable]
2939 ** New features
2941   pwd now accepts the options --logical (-L) and --physical (-P).  For
2942   compatibility with existing scripts, -P is the default behavior
2943   unless POSIXLY_CORRECT is requested.
2945 ** Bug fixes
2947   cat once again immediately outputs data it has processed.
2948   Previously it would have been buffered and only output if enough
2949   data was read, or on process exit.
2950   [bug introduced in coreutils-6.0]
2952   comm's new --check-order option would fail to detect disorder on any pair
2953   of lines where one was a prefix of the other.  For example, this would
2954   fail to report the disorder: printf 'Xb\nX\n'>k; comm --check-order k k
2955   [bug introduced in coreutils-7.0]
2957   cp once again diagnoses the invalid "cp -rl dir dir" right away,
2958   rather than after creating a very deep dir/dir/dir/... hierarchy.
2959   The bug strikes only with both --recursive (-r, -R) and --link (-l).
2960   [bug introduced in coreutils-7.1]
2962   ls --sort=version (-v) sorted names beginning with "." inconsistently.
2963   Now, names that start with "." are always listed before those that don't.
2965   pr: fix the bug whereby --indent=N (-o) did not indent header lines
2966   [bug introduced in coreutils-6.9.90]
2968   sort now handles specified key ends correctly.
2969   Previously -k1,1b would have caused leading space from field 2 to be
2970   included in the sort while -k2,3.0 would have not included field 3.
2972 ** Changes in behavior
2974   cat,cp,install,mv,split: these programs now read and write a minimum
2975   of 32KiB at a time.  This was seen to double throughput when reading
2976   cached files on GNU/Linux-based systems.
2978   cp -a now tries to preserve extended attributes (xattr), but does not
2979   diagnose xattr-preservation failure.  However, cp --preserve=all still does.
2981   ls --color: hard link highlighting can be now disabled by changing the
2982   LS_COLORS environment variable. To disable it you can add something like
2983   this to your profile: eval `dircolors | sed s/hl=[^:]*:/hl=:/`
2986 * Noteworthy changes in release 7.1 (2009-02-21) [stable]
2988 ** New features
2990   Add extended attribute support available on certain filesystems like ext2
2991   and XFS.
2992     cp: Tries to copy xattrs when --preserve=xattr or --preserve=all specified
2993     mv: Always tries to copy xattrs
2994     install: Never copies xattrs
2996   cp and mv accept a new option, --no-clobber (-n): silently refrain
2997   from overwriting any existing destination file
2999   dd accepts iflag=cio and oflag=cio to open the file in CIO (concurrent I/O)
3000   mode where this feature is available.
3002   install accepts a new option, --compare (-C): compare each pair of source
3003   and destination files, and if the destination has identical content and
3004   any specified owner, group, permissions, and possibly SELinux context, then
3005   do not modify the destination at all.
3007   ls --color now highlights hard linked files, too
3009   stat -f recognizes the Lustre file system type
3011 ** Bug fixes
3013   chgrp, chmod, chown --silent (--quiet, -f) no longer print some diagnostics
3014   [bug introduced in coreutils-5.1]
3016   cp uses much less memory in some situations
3018   cp -a now correctly tries to preserve SELinux context (announced in 6.9.90),
3019   doesn't inform about failure, unlike with --preserve=all
3021   du --files0-from=FILE no longer reads all of FILE into RAM before
3022   processing the first file name
3024   seq 9223372036854775807 9223372036854775808 now prints only two numbers
3025   on systems with extended long double support and good library support.
3026   Even with this patch, on some systems, it still produces invalid output,
3027   from 3 to at least 1026 lines long. [bug introduced in coreutils-6.11]
3029   seq -w now accounts for a decimal point added to the last number
3030   to correctly print all numbers to the same width.
3032   wc --files0-from=FILE no longer reads all of FILE into RAM, before
3033   processing the first file name, unless the list of names is known
3034   to be small enough.
3036 ** Changes in behavior
3038   cp and mv: the --reply={yes,no,query} option has been removed.
3039   Using it has elicited a warning for the last three years.
3041   dd: user specified offsets that are too big are handled better.
3042   Previously, erroneous parameters to skip and seek could result
3043   in redundant reading of the file with no warnings or errors.
3045   du: -H (initially equivalent to --si) is now equivalent to
3046   --dereference-args, and thus works as POSIX requires
3048   shred: now does 3 overwrite passes by default rather than 25.
3050   ls -l now marks SELinux-only files with the less obtrusive '.',
3051   rather than '+'.  A file with any other combination of MAC and ACL
3052   is still marked with a '+'.
3055 * Noteworthy changes in release 7.0 (2008-10-05) [beta]
3057 ** New programs
3059   timeout: Run a command with bounded time.
3060   truncate: Set the size of a file to a specified size.
3062 ** New features
3064   chgrp, chmod, chown, chcon, du, rm: now all display linear performance,
3065   even when operating on million-entry directories on ext3 and ext4 file
3066   systems.  Before, they would exhibit O(N^2) performance, due to linear
3067   per-entry seek time cost when operating on entries in readdir order.
3068   Rm was improved directly, while the others inherit the improvement
3069   from the newer version of fts in gnulib.
3071   comm now verifies that the inputs are in sorted order.  This check can
3072   be turned off with the --nocheck-order option.
3074   comm accepts new option, --output-delimiter=STR, that allows specification
3075   of an output delimiter other than the default single TAB.
3077   cp and mv: the deprecated --reply=X option is now also undocumented.
3079   dd accepts iflag=fullblock to make it accumulate full input blocks.
3080   With this new option, after a short read, dd repeatedly calls read,
3081   until it fills the incomplete block, reaches EOF, or encounters an error.
3083   df accepts a new option --total, which produces a grand total of all
3084   arguments after all arguments have been processed.
3086   If the GNU MP library is available at configure time, factor and
3087   expr support arbitrarily large numbers.  Pollard's rho algorithm is
3088   used to factor large numbers.
3090   install accepts a new option --strip-program to specify the program used to
3091   strip binaries.
3093   ls now colors names of files with capabilities if libcap is available.
3095   ls -v now uses filevercmp function as sort predicate (instead of strverscmp)
3097   md5sum now accepts the new option, --quiet, to suppress the printing of
3098   'OK' messages.  sha1sum, sha224sum, sha384sum, and sha512sum accept it, too.
3100   sort accepts a new option, --files0-from=F, that specifies a file
3101   containing a null-separated list of files to sort.  This list is used
3102   instead of filenames passed on the command-line to avoid problems with
3103   maximum command-line (argv) length.
3105   sort accepts a new option --batch-size=NMERGE, where NMERGE
3106   represents the maximum number of inputs that will be merged at once.
3107   When processing more than NMERGE inputs, sort uses temporary files.
3109   sort accepts a new option --version-sort (-V, --sort=version),
3110   specifying that ordering is to be based on filevercmp.
3112 ** Bug fixes
3114   chcon --verbose now prints a newline after each message
3116   od no longer suffers from platform bugs in printf(3).  This is
3117   probably most noticeable when using 'od -tfL' to print long doubles.
3119   seq -0.1 0.1 2 now prints 2,0 when locale's decimal point is ",".
3120   Before, it would mistakenly omit the final number in that example.
3122   shuf honors the --zero-terminated (-z) option, even with --input-range=LO-HI
3124   shuf --head-count is now correctly documented.  The documentation
3125   previously claimed it was called --head-lines.
3127 ** Improvements
3129   Improved support for access control lists (ACLs): On MacOS X, Solaris 7..10,
3130   HP-UX 11, Tru64, AIX, IRIX 6.5, and Cygwin, "ls -l" now displays the presence
3131   of an ACL on a file via a '+' sign after the mode, and "cp -p" copies ACLs.
3133   join has significantly better performance due to better memory management
3135   ls now uses constant memory when not sorting and using one_per_line format,
3136   no matter how many files are in a given directory.  I.e., to list a directory
3137   with very many files, ls -1U is much more efficient.
3139   od now aligns fields across lines when printing multiple -t
3140   specifiers, and no longer prints fields that resulted entirely from
3141   padding the input out to the least common multiple width.
3143 ** Changes in behavior
3145   stat's --context (-Z) option has always been a no-op.
3146   Now it evokes a warning that it is obsolete and will be removed.
3149 * Noteworthy changes in release 6.12 (2008-05-31) [stable]
3151 ** New features
3153   cp, install, mv, and touch now preserve nanosecond resolution on
3154   file timestamps, on platforms that have the 'utimensat' and
3155   'futimens' system calls.
3157 ** Bug fixes
3159   chcon, runcon: --help output now includes the bug-reporting address
3161   cp -p copies permissions more portably.  For example, on MacOS X 10.5,
3162   "cp -p some-fifo some-file" no longer fails while trying to copy the
3163   permissions from the some-fifo argument.
3165   id with no options now prints the SELinux context only when invoked
3166   with no USERNAME argument.
3168   id and groups once again print the AFS-specific nameless group-ID (PAG).
3169   Printing of such large-numbered, kernel-only (not in /etc/group) group-IDs
3170   was suppressed in 6.11 due to ignorance that they are useful.
3172   uniq: avoid subtle field-skipping malfunction due to isblank misuse.
3173   In some locales on some systems, isblank(240) (aka &nbsp) is nonzero.
3174   On such systems, uniq --skip-fields=N would fail to skip the proper
3175   number of fields for some inputs.
3177   tac: avoid segfault with --regex (-r) and multiple files, e.g.,
3178   "echo > x; tac -r x x".  [bug present at least in textutils-1.8b, from 1992]
3180 ** Changes in behavior
3182   install once again sets SELinux context, when possible
3183   [it was deliberately disabled in 6.9.90]
3186 * Noteworthy changes in release 6.11 (2008-04-19) [stable]
3188 ** Bug fixes
3190   configure --enable-no-install-program=groups now works.
3192   "cp -fR fifo E" now succeeds with an existing E.  Before this fix, using
3193   -fR to copy a fifo or "special" file onto an existing file would fail
3194   with EEXIST.  Now, it once again unlinks the destination before trying
3195   to create the destination file.  [bug introduced in coreutils-5.90]
3197   dd once again works with unnecessary options like if=/dev/stdin and
3198   of=/dev/stdout.  [bug introduced in fileutils-4.0h]
3200   id now uses getgrouplist, when possible.  This results in
3201   much better performance when there are many users and/or groups.
3203   ls no longer segfaults on files in /proc when linked with an older version
3204   of libselinux.  E.g., ls -l /proc/sys would dereference a NULL pointer.
3206   md5sum would segfault for invalid BSD-style input, e.g.,
3207   echo 'MD5 (' | md5sum -c -  Now, md5sum ignores that line.
3208   sha1sum, sha224sum, sha384sum, and sha512sum are affected, too.
3209   [bug introduced in coreutils-5.1.0]
3211   md5sum -c would accept a NUL-containing checksum string like "abcd\0..."
3212   and would unnecessarily read and compute the checksum of the named file,
3213   and then compare that checksum to the invalid one: guaranteed to fail.
3214   Now, it recognizes that the line is not valid and skips it.
3215   sha1sum, sha224sum, sha384sum, and sha512sum are affected, too.
3216   [bug present in the original version, in coreutils-4.5.1, 1995]
3218   "mkdir -Z x dir" no longer segfaults when diagnosing invalid context "x"
3219   mkfifo and mknod would fail similarly.  Now they're fixed.
3221   mv would mistakenly unlink a destination file before calling rename,
3222   when the destination had two or more hard links.  It no longer does that.
3223   [bug introduced in coreutils-5.3.0]
3225   "paste -d'\' file" no longer overruns memory (heap since coreutils-5.1.2,
3226   stack before then) [bug present in the original version, in 1992]
3228   "pr -e" with a mix of backspaces and TABs no longer corrupts the heap
3229   [bug present in the original version, in 1992]
3231   "ptx -F'\' long-file-name" would overrun a malloc'd buffer and corrupt
3232   the heap.  That was triggered by a lone backslash (or odd number of them)
3233   at the end of the option argument to --flag-truncation=STRING (-F),
3234   --word-regexp=REGEXP (-W), or --sentence-regexp=REGEXP (-S).
3236   "rm -r DIR" would mistakenly declare to be "write protected" -- and
3237   prompt about -- full DIR-relative names longer than MIN (PATH_MAX, 8192).
3239   "rmdir --ignore-fail-on-non-empty" detects and ignores the failure
3240   in more cases when a directory is empty.
3242   "seq -f % 1" would issue the erroneous diagnostic "seq: memory exhausted"
3243   rather than reporting the invalid string format.
3244   [bug introduced in coreutils-6.0]
3246 ** New features
3248   join now verifies that the inputs are in sorted order.  This check can
3249   be turned off with the --nocheck-order option.
3251   sort accepts the new option --sort=WORD, where WORD can be one of
3252   general-numeric, month, numeric or random.  These are equivalent to the
3253   options --general-numeric-sort/-g, --month-sort/-M, --numeric-sort/-n
3254   and --random-sort/-R, resp.
3256 ** Improvements
3258   id and groups work around an AFS-related bug whereby those programs
3259   would print an invalid group number, when given no user-name argument.
3261   ls --color no longer outputs unnecessary escape sequences
3263   seq gives better diagnostics for invalid formats.
3265 ** Portability
3267   rm now works properly even on systems like BeOS and Haiku,
3268   which have negative errno values.
3270 ** Consistency
3272   install, mkdir, rmdir and split now write --verbose output to stdout,
3273   not to stderr.
3276 * Noteworthy changes in release 6.10 (2008-01-22) [stable]
3278 ** Bug fixes
3280   Fix a non-portable use of sed in configure.ac.
3281   [bug introduced in coreutils-6.9.92]
3284 * Noteworthy changes in release 6.9.92 (2008-01-12) [beta]
3286 ** Bug fixes
3288   cp --parents no longer uses uninitialized memory when restoring the
3289   permissions of a just-created destination directory.
3290   [bug introduced in coreutils-6.9.90]
3292   tr's case conversion would fail in a locale with differing numbers
3293   of lower case and upper case characters.  E.g., this would fail:
3294   env LC_CTYPE=en_US.ISO-8859-1 tr '[:upper:]' '[:lower:]'
3295   [bug introduced in coreutils-6.9.90]
3297 ** Improvements
3299   "touch -d now writable-but-owned-by-someone-else" now succeeds
3300   whenever that same command would succeed without "-d now".
3301   Before, it would work fine with no -d option, yet it would
3302   fail with the ostensibly-equivalent "-d now".
3305 * Noteworthy changes in release 6.9.91 (2007-12-15) [beta]
3307 ** Bug fixes
3309   "ls -l" would not output "+" on SELinux hosts unless -Z was also given.
3311   "rm" would fail to unlink a non-directory when run in an environment
3312   in which the user running rm is capable of unlinking a directory.
3313   [bug introduced in coreutils-6.9]
3316 * Noteworthy changes in release 6.9.90 (2007-12-01) [beta]
3318 ** New programs
3320   arch: equivalent to uname -m, not installed by default
3321   But don't install this program on Solaris systems.
3323   chcon: change the SELinux security context of a file
3325   mktemp: create a temporary file or directory (or names)
3327   runcon: run a program in a different SELinux security context
3329 ** Programs no longer installed by default
3331   hostname, su
3333 ** Changes in behavior
3335   cp, by default, refuses to copy through a dangling destination symlink
3336   Set POSIXLY_CORRECT if you require the old, risk-prone behavior.
3338   pr -F no longer suppresses the footer or the first two blank lines in
3339   the header.  This is for compatibility with BSD and POSIX.
3341   tr now warns about an unescaped backslash at end of string.
3342   The tr from coreutils-5.2.1 and earlier would fail for such usage,
3343   and Solaris' tr ignores that final byte.
3345 ** New features
3347   Add SELinux support, based on the patch from Fedora:
3348   * cp accepts new --preserve=context option.
3349   * "cp -a" works with SELinux:
3350   Now, cp -a attempts to preserve context, but failure to do so does
3351   not change cp's exit status.  However "cp --preserve=context" is
3352   similar, but failure *does* cause cp to exit with nonzero status.
3353   * install accepts new "-Z, --context=C" option.
3354   * id accepts new "-Z" option.
3355   * stat honors the new %C format directive: SELinux security context string
3356   * ls accepts a slightly modified -Z option.
3357   * ls: contrary to Fedora version, does not accept --lcontext and --scontext
3359   The following commands and options now support the standard size
3360   suffixes kB, M, MB, G, GB, and so on for T, P, Y, Z, and Y:
3361   head -c, head -n, od -j, od -N, od -S, split -b, split -C,
3362   tail -c, tail -n.
3364   cp -p tries to preserve the GID of a file even if preserving the UID
3365   is not possible.
3367   uniq accepts a new option: --zero-terminated (-z).  As with the sort
3368   option of the same name, this makes uniq consume and produce
3369   NUL-terminated lines rather than newline-terminated lines.
3371   wc no longer warns about character decoding errors in multibyte locales.
3372   This means for example that "wc /bin/sh" now produces normal output
3373   (though the word count will have no real meaning) rather than many
3374   error messages.
3376 ** New build options
3378   By default, "make install" no longer attempts to install (or even build) su.
3379   To change that, use ./configure --enable-install-program=su.
3380   If you also want to install the new "arch" program, do this:
3381   ./configure --enable-install-program=arch,su.
3383   You can inhibit the compilation and installation of selected programs
3384   at configure time.  For example, to avoid installing "hostname" and
3385   "uptime", use ./configure --enable-no-install-program=hostname,uptime
3386   Note: currently, "make check" passes, even when arch and su are not
3387   built (that's the new default).  However, if you inhibit the building
3388   and installation of other programs, don't be surprised if some parts
3389   of "make check" fail.
3391 ** Remove deprecated options
3393   df no longer accepts the --kilobytes option.
3394   du no longer accepts the --kilobytes or --megabytes options.
3395   ls no longer accepts the --kilobytes option.
3396   ptx longer accepts the --copyright option.
3397   who no longer accepts -i or --idle.
3399 ** Improved robustness
3401   ln -f can no longer silently clobber a just-created hard link.
3402   In some cases, ln could be seen as being responsible for data loss.
3403   For example, given directories a, b, c, and files a/f and b/f, we
3404   should be able to do this safely: ln -f a/f b/f c && rm -f a/f b/f
3405   However, before this change, ln would succeed, and thus cause the
3406   loss of the contents of a/f.
3408   stty no longer silently accepts certain invalid hex values
3409   in its 35-colon command-line argument
3411 ** Bug fixes
3413   chmod no longer ignores a dangling symlink.  Now, chmod fails
3414   with a diagnostic saying that it cannot operate on such a file.
3415   [bug introduced in coreutils-5.1.0]
3417   cp attempts to read a regular file, even if stat says it is empty.
3418   Before, "cp /proc/cpuinfo c" would create an empty file when the kernel
3419   reports stat.st_size == 0, while "cat /proc/cpuinfo > c" would "work",
3420   and create a nonempty one. [bug introduced in coreutils-6.0]
3422   cp --parents no longer mishandles symlinks to directories in file
3423   name components in the source, e.g., "cp --parents symlink/a/b d"
3424   no longer fails.  Also, 'cp' no longer considers a destination
3425   symlink to be the same as the referenced file when copying links
3426   or making backups.  For example, if SYM is a symlink to FILE,
3427   "cp -l FILE SYM" now reports an error instead of silently doing
3428   nothing.  The behavior of 'cp' is now better documented when the
3429   destination is a symlink.
3431   "cp -i --update older newer" no longer prompts; same for mv
3433   "cp -i" now detects read errors on standard input, and no longer consumes
3434   too much seekable input; same for ln, install, mv, and rm.
3436   cut now diagnoses a range starting with zero (e.g., -f 0-2) as invalid;
3437   before, it would treat it as if it started with 1 (-f 1-2).
3439   "cut -f 2-0" now fails; before, it was equivalent to "cut -f 2-"
3441   cut now diagnoses the '-' in "cut -f -" as an invalid range, rather
3442   than interpreting it as the unlimited range, "1-".
3444   date -d now accepts strings of the form e.g., 'YYYYMMDD +N days',
3445   in addition to the usual 'YYYYMMDD N days'.
3447   du -s now includes the size of any stat'able-but-inaccessible directory
3448   in the total size.
3450   du (without -s) prints whatever it knows of the size of an inaccessible
3451   directory.  Before, du would print nothing for such a directory.
3453   ls -x DIR would sometimes output the wrong string in place of the
3454   first entry.  [introduced in coreutils-6.8]
3456   ls --color would mistakenly color a dangling symlink as if it were
3457   a regular symlink.  This would happen only when the dangling symlink
3458   was not a command-line argument and in a directory with d_type support.
3459   [introduced in coreutils-6.0]
3461   ls --color, (with a custom LS_COLORS envvar value including the
3462   ln=target attribute) would mistakenly output the string "target"
3463   before the name of each symlink.  [introduced in coreutils-6.0]
3465   od's --skip (-j) option now works even when the kernel says that a
3466   nonempty regular file has stat.st_size = 0.  This happens at least
3467   with files in /proc and linux-2.6.22.
3469   "od -j L FILE" had a bug: when the number of bytes to skip, L, is exactly
3470   the same as the length of FILE, od would skip *no* bytes.  When the number
3471   of bytes to skip is exactly the sum of the lengths of the first N files,
3472   od would skip only the first N-1 files. [introduced in textutils-2.0.9]
3474   ./printf %.10000000f 1 could get an internal ENOMEM error and generate
3475   no output, yet erroneously exit with status 0.  Now it diagnoses the error
3476   and exits with nonzero status.  [present in initial implementation]
3478   seq no longer mishandles obvious cases like "seq 0 0.000001 0.000003",
3479   so workarounds like "seq 0 0.000001 0.0000031" are no longer needed.
3481   seq would mistakenly reject some valid format strings containing %%,
3482   and would mistakenly accept some invalid ones. e.g., %g%% and %%g, resp.
3484   "seq .1 .1" would mistakenly generate no output on some systems
3486   Obsolete sort usage with an invalid ordering-option character, e.g.,
3487   "env _POSIX2_VERSION=199209 sort +1x" no longer makes sort free an
3488   invalid pointer [introduced in coreutils-6.5]
3490   sorting very long lines (relative to the amount of available memory)
3491   no longer provokes unaligned memory access
3493   split --line-bytes=N (-C N) no longer creates an empty file
3494   [this bug is present at least as far back as textutils-1.22 (Jan, 1997)]
3496   tr -c no longer aborts when translating with Set2 larger than the
3497   complement of Set1.  [present in the original version, in 1992]
3499   tr no longer rejects an unmatched [:lower:] or [:upper:] in SET1.
3500   [present in the original version]
3503 * Noteworthy changes in release 6.9 (2007-03-22) [stable]
3505 ** Bug fixes
3507   cp -x (--one-file-system) would fail to set mount point permissions
3509   The default block size and output format for df -P are now unaffected by
3510   the DF_BLOCK_SIZE, BLOCK_SIZE, and BLOCKSIZE environment variables.  It
3511   is still affected by POSIXLY_CORRECT, though.
3513   Using pr -m -s (i.e., merging files, with TAB as the output separator)
3514   no longer inserts extraneous spaces between output columns.
3516 * Noteworthy changes in release 6.8 (2007-02-24) [not-unstable]
3518 ** Bug fixes
3520   chgrp, chmod, and chown now honor the --preserve-root option.
3521   Before, they would warn, yet continuing traversing and operating on /.
3523   chmod no longer fails in an environment (e.g., a chroot) with openat
3524   support but with insufficient /proc support.
3526   "cp --parents F/G D" no longer creates a directory D/F when F is not
3527   a directory (and F/G is therefore invalid).
3529   "cp --preserve=mode" would create directories that briefly had
3530   too-generous permissions in some cases.  For example, when copying a
3531   directory with permissions 777 the destination directory might
3532   temporarily be setgid on some file systems, which would allow other
3533   users to create subfiles with the same group as the directory.  Fix
3534   similar problems with 'install' and 'mv'.
3536   cut no longer dumps core for usage like "cut -f2- f1 f2" with two or
3537   more file arguments.  This was due to a double-free bug, introduced
3538   in coreutils-5.3.0.
3540   dd bs= operands now silently override any later ibs= and obs=
3541   operands, as POSIX and tradition require.
3543   "ls -FRL" always follows symbolic links on Linux.  Introduced in
3544   coreutils-6.0.
3546   A cross-partition "mv /etc/passwd ~" (by non-root) now prints
3547   a reasonable diagnostic.  Before, it would print this:
3548   "mv: cannot remove `/etc/passwd': Not a directory".
3550   pwd and "readlink -e ." no longer fail unnecessarily when a parent
3551   directory is unreadable.
3553   rm (without -f) could prompt when it shouldn't, or fail to prompt
3554   when it should, when operating on a full name longer than 511 bytes
3555   and getting an ENOMEM error while trying to form the long name.
3557   rm could mistakenly traverse into the wrong directory under unusual
3558   conditions: when a full name longer than 511 bytes specifies a search-only
3559   directory, and when forming that name fails with ENOMEM, rm would attempt
3560   to open a truncated-to-511-byte name with the first five bytes replaced
3561   with "[...]".  If such a directory were to actually exist, rm would attempt
3562   to remove it.
3564   "rm -rf /etc/passwd" (run by non-root) now prints a diagnostic.
3565   Before it would print nothing.
3567   "rm --interactive=never F" no longer prompts for an unwritable F
3569   "rm -rf D" would emit a misleading diagnostic when failing to
3570   remove a symbolic link within the unwritable directory, D.
3571   Introduced in coreutils-6.0.  Similarly, when a cross-partition
3572   "mv" fails because the source directory is unwritable, it now gives
3573   a reasonable diagnostic.  Before, this would print
3574     $ mkdir /tmp/x; touch /tmp/x/y; chmod -w /tmp/x;
3575     $ test $(stat -c %d /tmp/x) -ne $(stat -c %d .) && mv /tmp/x/y .
3576     mv: cannot remove `/tmp/x/y': Not a directory
3577   Now it prints this:
3578     mv: cannot remove `/tmp/x/y': Permission denied.
3580 ** New features
3582   sort's new --compress-program=PROG option specifies a compression
3583   program to use when writing and reading temporary files.
3584   This can help save both time and disk space when sorting large inputs.
3586   sort accepts the new option -C, which acts like -c except no diagnostic
3587   is printed.  Its --check option now accepts an optional argument, and
3588   --check=quiet and --check=silent are now aliases for -C, while
3589   --check=diagnose-first is an alias for -c or plain --check.
3592 * Noteworthy changes in release 6.7 (2006-12-08) [stable]
3594 ** Bug fixes
3596   When cp -p copied a file with special mode bits set, the same bits
3597   were set on the copy even when ownership could not be preserved.
3598   This could result in files that were setuid to the wrong user.
3599   To fix this, special mode bits are now set in the copy only if its
3600   ownership is successfully preserved.  Similar problems were fixed
3601   with mv when copying across file system boundaries.  This problem
3602   affects all versions of coreutils through 6.6.
3604   cp --preserve=ownership would create output files that temporarily
3605   had too-generous permissions in some cases.  For example, when
3606   copying a file with group A and mode 644 into a group-B sticky
3607   directory, the output file was briefly readable by group B.
3608   Fix similar problems with cp options like -p that imply
3609   --preserve=ownership, with install -d when combined with either -o
3610   or -g, and with mv when copying across file system boundaries.
3611   This bug affects all versions of coreutils through 6.6.
3613   du --one-file-system (-x) would skip subdirectories of any directory
3614   listed as second or subsequent command line argument.  This bug affects
3615   coreutils-6.4, 6.5 and 6.6.
3618 * Noteworthy changes in release 6.6 (2006-11-22) [stable]
3620 ** Bug fixes
3622   ls would segfault (dereference a NULL pointer) for a file with a
3623   nameless group or owner.  This bug was introduced in coreutils-6.5.
3625   A bug in the latest official m4/gettext.m4 (from gettext-0.15)
3626   made configure fail to detect gettext support, due to the unusual
3627   way in which coreutils uses AM_GNU_GETTEXT.
3629 ** Improved robustness
3631   Now, du (and the other fts clients: chmod, chgrp, chown) honor a
3632   trailing slash in the name of a symlink-to-directory even on
3633   Solaris 9, by working around its buggy fstatat implementation.
3636 * Major changes in release 6.5 (2006-11-19) [stable]
3638 ** Bug fixes
3640   du (and the other fts clients: chmod, chgrp, chown) would exit early
3641   when encountering an inaccessible directory on a system with native
3642   openat support (i.e., linux-2.6.16 or newer along with glibc-2.4
3643   or newer).  This bug was introduced with the switch to gnulib's
3644   openat-based variant of fts, for coreutils-6.0.
3646   "ln --backup f f" now produces a sensible diagnostic
3648 ** New features
3650   rm accepts a new option: --one-file-system
3653 * Major changes in release 6.4 (2006-10-22) [stable]
3655 ** Bug fixes
3657   chgrp and chown would malfunction when invoked with both -R and -H and
3658   with one or more of the following: --preserve-root, --verbose, --changes,
3659   --from=o:g (chown only).  This bug was introduced with the switch to
3660   gnulib's openat-based variant of fts, for coreutils-6.0.
3662   cp --backup dir1 dir2, would rename an existing dir2/dir1 to dir2/dir1~.
3663   This bug was introduced in coreutils-6.0.
3665   With --force (-f), rm no longer fails for ENOTDIR.
3666   For example, "rm -f existing-non-directory/anything" now exits
3667   successfully, ignoring the error about a nonexistent file.
3670 * Major changes in release 6.3 (2006-09-30) [stable]
3672 ** Improved robustness
3674   pinky no longer segfaults on Darwin 7.9.0 (MacOS X 10.3.9) due to a
3675   buggy native getaddrinfo function.
3677   rm works around a bug in Darwin 7.9.0 (MacOS X 10.3.9) that would
3678   sometimes keep it from removing all entries in a directory on an HFS+
3679   or NFS-mounted partition.
3681   sort would fail to handle very large input (around 40GB) on systems with a
3682   mkstemp function that returns a file descriptor limited to 32-bit offsets.
3684 ** Bug fixes
3686   chmod would fail unnecessarily in an unusual case: when an initially-
3687   inaccessible argument is rendered accessible by chmod's action on a
3688   preceding command line argument.  This bug also affects chgrp, but
3689   it is harder to demonstrate.  It does not affect chown.  The bug was
3690   introduced with the switch from explicit recursion to the use of fts
3691   in coreutils-5.1.0 (2003-10-15).
3693   cp -i and mv -i occasionally neglected to prompt when the copy or move
3694   action was bound to fail.  This bug dates back to before fileutils-4.0.
3696   With --verbose (-v), cp and mv would sometimes generate no output,
3697   or neglect to report file removal.
3699   For the "groups" command:
3701     "groups" no longer prefixes the output with "user :" unless more
3702     than one user is specified; this is for compatibility with BSD.
3704     "groups user" now exits nonzero when it gets a write error.
3706     "groups" now processes options like --help more compatibly.
3708   shuf would infloop, given 8KB or more of piped input
3710 ** Portability
3712   Versions of chmod, chown, chgrp, du, and rm (tools that use openat etc.)
3713   compiled for Solaris 8 now also work when run on Solaris 10.
3716 * Major changes in release 6.2 (2006-09-18) [stable candidate]
3718 ** Changes in behavior
3720   mkdir -p and install -d (or -D) now use a method that forks a child
3721   process if the working directory is unreadable and a later argument
3722   uses a relative file name.  This avoids some race conditions, but it
3723   means you may need to kill two processes to stop these programs.
3725   rm now rejects attempts to remove the root directory, e.g., 'rm -fr /'
3726   now fails without removing anything.  Likewise for any file name with
3727   a final './' or '../' component.
3729   tail now ignores the -f option if POSIXLY_CORRECT is set, no file
3730   operand is given, and standard input is any FIFO; formerly it did
3731   this only for pipes.
3733 ** Infrastructure changes
3735   Coreutils now uses gnulib via the gnulib-tool script.
3736   If you check the source out from CVS, then follow the instructions
3737   in README-cvs.  Although this represents a large change to the
3738   infrastructure, it should cause no change in how the tools work.
3740 ** Bug fixes
3742   cp --backup no longer fails when the last component of a source file
3743   name is "." or "..".
3745   "ls --color" would highlight other-writable and sticky directories
3746   no differently than regular directories on a file system with
3747   dirent.d_type support.
3749   "mv -T --verbose --backup=t A B" now prints the " (backup: B.~1~)"
3750   suffix when A and B are directories as well as when they are not.
3752   mv and "cp -r" no longer fail when invoked with two arguments
3753   where the first one names a directory and the second name ends in
3754   a slash and doesn't exist.  E.g., "mv dir B/", for nonexistent B,
3755   now succeeds, once more.  This bug was introduced in coreutils-5.3.0.
3758 * Major changes in release 6.1 (2006-08-19) [unstable]
3760 ** Changes in behavior
3762   df now considers BSD "kernfs" file systems to be dummies
3764 ** New features
3766   printf now supports the 'I' flag on hosts whose underlying printf
3767   implementations support 'I', e.g., "printf %Id 2".
3769 ** Bug fixes
3771   cp --sparse preserves sparseness at the end of a file, even when
3772   the file's apparent size is not a multiple of its block size.
3773   [introduced with the original design, in fileutils-4.0r, 2000-04-29]
3775   df (with a command line argument) once again prints its header
3776   [introduced in coreutils-6.0]
3778   ls -CF would misalign columns in some cases involving non-stat'able files
3779   [introduced in coreutils-6.0]
3781 * Major changes in release 6.0 (2006-08-15) [unstable]
3783 ** Improved robustness
3785   df: if the file system claims to have more available than total blocks,
3786   report the number of used blocks as being "total - available"
3787   (a negative number) rather than as garbage.
3789   dircolors: a new autoconf run-test for AIX's buggy strndup function
3790   prevents malfunction on that system;  may also affect cut, expand,
3791   and unexpand.
3793   fts no longer changes the current working directory, so its clients
3794   (chmod, chown, chgrp, du) no longer malfunction under extreme conditions.
3796   pwd and other programs using lib/getcwd.c work even on file systems
3797   where dirent.d_ino values are inconsistent with those from stat.st_ino.
3799   rm's core is now reentrant: rm --recursive (-r) now processes
3800   hierarchies without changing the working directory at all.
3802 ** Changes in behavior
3804   basename and dirname now treat // as different from / on platforms
3805   where the two are distinct.
3807   chmod, install, and mkdir now preserve a directory's set-user-ID and
3808   set-group-ID bits unless you explicitly request otherwise.  E.g.,
3809   'chmod 755 DIR' and 'chmod u=rwx,go=rx DIR' now preserve DIR's
3810   set-user-ID and set-group-ID bits instead of clearing them, and
3811   similarly for 'mkdir -m 755 DIR' and 'mkdir -m u=rwx,go=rx DIR'.  To
3812   clear the bits, mention them explicitly in a symbolic mode, e.g.,
3813   'mkdir -m u=rwx,go=rx,-s DIR'.  To set them, mention them explicitly
3814   in either a symbolic or a numeric mode, e.g., 'mkdir -m 2755 DIR',
3815   'mkdir -m u=rwx,go=rx,g+s' DIR.  This change is for convenience on
3816   systems where these bits inherit from parents.  Unfortunately other
3817   operating systems are not consistent here, and portable scripts
3818   cannot assume the bits are set, cleared, or preserved, even when the
3819   bits are explicitly mentioned.  For example, OpenBSD 3.9 'mkdir -m
3820   777 D' preserves D's setgid bit but 'chmod 777 D' clears it.
3821   Conversely, Solaris 10 'mkdir -m 777 D', 'mkdir -m g-s D', and
3822   'chmod 0777 D' all preserve D's setgid bit, and you must use
3823   something like 'chmod g-s D' to clear it.
3825   'cp --link --no-dereference' now works also on systems where the
3826   link system call cannot create a hard link to a symbolic link.
3827   This change has no effect on systems with a Linux-based kernel.
3829   csplit and nl now use POSIX syntax for regular expressions, not
3830   Emacs syntax.  As a result, character classes like [[:print:]] and
3831   interval expressions like A\{1,9\} now have their usual meaning,
3832   . no longer matches the null character, and \ must precede the + and
3833   ? operators.
3835   date: a command like date -d '2006-04-23 21 days ago' would print
3836   the wrong date in some time zones.  (see the test for an example)
3838   df changes:
3840     df now considers "none" and "proc" file systems to be dummies and
3841     therefore does not normally display them.  Also, inaccessible file
3842     systems (which can be caused by shadowed mount points or by
3843     chrooted bind mounts) are now dummies, too.
3845     df now fails if it generates no output, so you can inspect the
3846     exit status of a command like "df -t ext3 -t reiserfs DIR" to test
3847     whether DIR is on a file system of type "ext3" or "reiserfs".
3849   expr no longer complains about leading ^ in a regular expression
3850   (the anchor is ignored), or about regular expressions like A** (the
3851   second "*" is ignored).  expr now exits with status 2 (not 3) for
3852   errors it detects in the expression's values; exit status 3 is now
3853   used only for internal errors (such as integer overflow, which expr
3854   now checks for).
3856   install and mkdir now implement the X permission symbol correctly,
3857   e.g., 'mkdir -m a+X dir'; previously the X was ignored.
3859   install now creates parent directories with mode u=rwx,go=rx (755)
3860   instead of using the mode specified by the -m option; and it does
3861   not change the owner or group of parent directories.  This is for
3862   compatibility with BSD and closes some race conditions.
3864   ln now uses different (and we hope clearer) diagnostics when it fails.
3865   ln -v now acts more like FreeBSD, so it generates output only when
3866   successful and the output is easier to parse.
3868   ls now defaults to --time-style='locale', not --time-style='posix-long-iso'.
3869   However, the 'locale' time style now behaves like 'posix-long-iso'
3870   if your locale settings appear to be messed up.  This change
3871   attempts to have the default be the best of both worlds.
3873   mkfifo and mknod no longer set special mode bits (setuid, setgid,
3874   and sticky) with the -m option.
3876   nohup's usual diagnostic now more precisely specifies the I/O
3877   redirections, e.g., "ignoring input and appending output to
3878   nohup.out".  Also, nohup now redirects stderr to nohup.out (or
3879   $HOME/nohup.out) if stdout is closed and stderr is a tty; this is in
3880   response to Open Group XCU ERN 71.
3882   rm --interactive now takes an optional argument, although the
3883   default of using no argument still acts like -i.
3885   rm no longer fails to remove an empty, unreadable directory
3887   seq changes:
3889     seq defaults to a minimal fixed point format that does not lose
3890     information if seq's operands are all fixed point decimal numbers.
3891     You no longer need the '-f%.f' in 'seq -f%.f 1048575 1024 1050623',
3892     for example, since the default format now has the same effect.
3894     seq now lets you use %a, %A, %E, %F, and %G formats.
3896     seq now uses long double internally rather than double.
3898   sort now reports incompatible options (e.g., -i and -n) rather than
3899   silently ignoring one of them.
3901   stat's --format=FMT option now works the way it did before 5.3.0:
3902   FMT is automatically newline terminated.  The first stable release
3903   containing this change was 5.92.
3905   stat accepts the new option --printf=FMT, where FMT is *not*
3906   automatically newline terminated.
3908   stat: backslash escapes are interpreted in a format string specified
3909   via --printf=FMT, but not one specified via --format=FMT.  That includes
3910   octal (\ooo, at most three octal digits), hexadecimal (\xhh, one or
3911   two hex digits), and the standard sequences (\a, \b, \f, \n, \r, \t,
3912   \v, \", \\).
3914   With no operand, 'tail -f' now silently ignores the '-f' only if
3915   standard input is a FIFO or pipe and POSIXLY_CORRECT is set.
3916   Formerly, it ignored the '-f' when standard input was a FIFO, pipe,
3917   or socket.
3919 ** Scheduled for removal
3921   ptx's --copyright (-C) option is scheduled for removal in 2007, and
3922   now evokes a warning.  Use --version instead.
3924   rm's --directory (-d) option is scheduled for removal in 2006.  This
3925   option has been silently ignored since coreutils 5.0.  On systems
3926   that support unlinking of directories, you can use the "unlink"
3927   command to unlink a directory.
3929   Similarly, we are considering the removal of ln's --directory (-d,
3930   -F) option in 2006.  Please write to <bug-coreutils@gnu.org> if this
3931   would cause a problem for you.  On systems that support hard links
3932   to directories, you can use the "link" command to create one.
3934 ** New programs
3936   base64: base64 encoding and decoding (RFC 3548) functionality.
3937   sha224sum: print or check a SHA224 (224-bit) checksum
3938   sha256sum: print or check a SHA256 (256-bit) checksum
3939   sha384sum: print or check a SHA384 (384-bit) checksum
3940   sha512sum: print or check a SHA512 (512-bit) checksum
3941   shuf: Shuffle lines of text.
3943 ** New features
3945   chgrp now supports --preserve-root, --no-preserve-root (default),
3946   as it was documented to do, and just as chmod, chown, and rm do.
3948   New dd iflag= and oflag= flags:
3950     'directory' causes dd to fail unless the file is a directory, on
3951     hosts that support this (e.g., Linux kernels, version 2.1.126 and
3952     later).  This has limited utility but is present for completeness.
3954     'noatime' causes dd to read a file without updating its access
3955     time, on hosts that support this (e.g., Linux kernels, version
3956     2.6.8 and later).
3958     'nolinks' causes dd to fail if the file has multiple hard links,
3959     on hosts that support this (e.g., Solaris 10 and later).
3961   ls accepts the new option --group-directories-first, to make it
3962   list directories before files.
3964   rm now accepts the -I (--interactive=once) option.  This new option
3965   prompts once if rm is invoked recursively or if more than three
3966   files are being deleted, which is less intrusive than -i prompting
3967   for every file, but provides almost the same level of protection
3968   against mistakes.
3970   shred and sort now accept the --random-source option.
3972   sort now accepts the --random-sort (-R) option and 'R' ordering option.
3974   sort now supports obsolete usages like "sort +1 -2" unless
3975   POSIXLY_CORRECT is set.  However, when conforming to POSIX
3976   1003.1-2001 "sort +1" still sorts the file named "+1".
3978   wc accepts a new option --files0-from=FILE, where FILE contains a
3979   list of NUL-terminated file names.
3981 ** Bug fixes
3983   cat with any of the options, -A -v -e -E -T, when applied to a
3984   file in /proc or /sys (linux-specific), would truncate its output,
3985   usually printing nothing.
3987   cp -p would fail in a /proc-less chroot, on some systems
3989   When 'cp -RL' encounters the same directory more than once in the
3990   hierarchy beneath a single command-line argument, it no longer confuses
3991   them with hard-linked directories.
3993   fts-using tools (chmod, chown, chgrp, du) no longer fail due to
3994   a double-free bug -- it could be triggered by making a directory
3995   inaccessible while e.g., du is traversing the hierarchy under it.
3997   fts-using tools (chmod, chown, chgrp, du) no longer misinterpret
3998   a very long symlink chain as a dangling symlink.  Before, such a
3999   misinterpretation would cause these tools not to diagnose an ELOOP error.
4001   ls --indicator-style=file-type would sometimes stat a symlink
4002   unnecessarily.
4004   ls --file-type worked like --indicator-style=slash (-p),
4005   rather than like --indicator-style=file-type.
4007   mv: moving a symlink into the place of an existing non-directory is
4008   now done atomically;  before, mv would first unlink the destination.
4010   mv -T DIR EMPTY_DIR no longer fails unconditionally.  Also, mv can
4011   now remove an empty destination directory: mkdir -p a b/a; mv a b
4013   rm (on systems with openat) can no longer exit before processing
4014   all command-line arguments.
4016   rm is no longer susceptible to a few low-probability memory leaks.
4018   rm -r no longer fails to remove an inaccessible and empty directory
4020   rm -r's cycle detection code can no longer be tricked into reporting
4021   a false positive (introduced in fileutils-4.1.9).
4023   shred --remove FILE no longer segfaults on Gentoo systems
4025   sort would fail for large inputs (~50MB) on systems with a buggy
4026   mkstemp function.  sort and tac now use the replacement mkstemp
4027   function, and hence are no longer subject to limitations (of 26 or 32,
4028   on the maximum number of files from a given template) on HP-UX 10.20,
4029   SunOS 4.1.4, Solaris 2.5.1 and OSF1/Tru64 V4.0F&V5.1.
4031   tail -f once again works on a file with the append-only
4032   attribute (affects at least Linux ext2, ext3, xfs file systems)
4034 * Major changes in release 5.97 (2006-06-24) [stable]
4035 * Major changes in release 5.96 (2006-05-22) [stable]
4036 * Major changes in release 5.95 (2006-05-12) [stable]
4037 * Major changes in release 5.94 (2006-02-13) [stable]
4039 [see the b5_9x branch for details]
4041 * Major changes in release 5.93 (2005-11-06) [stable]
4043 ** Bug fixes
4045   dircolors no longer segfaults upon an attempt to use the new
4046   STICKY_OTHER_WRITABLE (OWT) attribute.
4048   du no longer overflows a counter when processing a file larger than
4049   2^31-1 on some 32-bit systems (at least some AIX 5.1 configurations).
4051   md5sum once again defaults to using the ' ' non-binary marker
4052   (rather than the '*' binary marker) by default on Unix-like systems.
4054   mkdir -p and install -d no longer exit nonzero when asked to create
4055   a directory like 'nonexistent/.'
4057   rm emits a better diagnostic when (without -r) it fails to remove
4058   a directory on e.g., Solaris 9/10 systems.
4060   tac now works when stdin is a tty, even on non-Linux systems.
4062   "tail -c 2 FILE" and "touch 0101000000" now operate as POSIX
4063   1003.1-2001 requires, even when coreutils is conforming to older
4064   POSIX standards, as the newly-required behavior is upward-compatible
4065   with the old.
4067   The documentation no longer mentions rm's --directory (-d) option.
4069 ** Build-related bug fixes
4071   installing .mo files would fail
4074 * Major changes in release 5.92 (2005-10-22) [stable]
4076 ** Bug fixes
4078   chmod now diagnoses an invalid mode string starting with an octal digit
4080   dircolors now properly quotes single-quote characters
4083 * Major changes in release 5.91 (2005-10-17) [stable candidate]
4085 ** Bug fixes
4087   "mkdir -p /a/b/c" no longer fails merely because a leading prefix
4088   directory (e.g., /a or /a/b) exists on a read-only file system.
4090 ** Removed options
4092   tail's --allow-missing option has been removed.  Use --retry instead.
4094   stat's --link and -l options have been removed.
4095   Use --dereference (-L) instead.
4097 ** Deprecated options
4099   Using ls, du, or df with the --kilobytes option now evokes a warning
4100   that the long-named option is deprecated.  Use '-k' instead.
4102   du's long-named --megabytes option now evokes a warning.
4103   Use -m instead.
4106 * Major changes in release 5.90 (2005-09-29) [unstable]
4108 ** Bring back support for 'head -NUM', 'tail -NUM', etc. even when
4109   conforming to POSIX 1003.1-2001.  The following changes apply only
4110   when conforming to POSIX 1003.1-2001; there is no effect when
4111   conforming to older POSIX versions.
4113   The following usages now behave just as when conforming to older POSIX:
4115     date -I
4116     expand -TAB1[,TAB2,...]
4117     fold -WIDTH
4118     head -NUM
4119     join -j FIELD
4120     join -j1 FIELD
4121     join -j2 FIELD
4122     join -o FIELD_NAME1 FIELD_NAME2...
4123     nice -NUM
4124     od -w
4125     pr -S
4126     split -NUM
4127     tail -[NUM][bcl][f] [FILE]
4129   The following usages no longer work, due to the above changes:
4131     date -I TIMESPEC  (use 'date -ITIMESPEC' instead)
4132     od -w WIDTH       (use 'od -wWIDTH' instead)
4133     pr -S STRING      (use 'pr -SSTRING' instead)
4135   A few usages still have behavior that depends on which POSIX standard is
4136   being conformed to, and portable applications should beware these
4137   problematic usages.  These include:
4139     Problematic       Standard-conforming replacement, depending on
4140        usage            whether you prefer the behavior of:
4141                       POSIX 1003.2-1992    POSIX 1003.1-2001
4142     sort +4           sort -k 5            sort ./+4
4143     tail +4           tail -n +4           tail ./+4
4144     tail - f          tail f               [see (*) below]
4145     tail -c 4         tail -c 10 ./4       tail -c4
4146     touch 12312359 f  touch -t 12312359 f  touch ./12312359 f
4147     uniq +4           uniq -s 4            uniq ./+4
4149     (*) "tail - f" does not conform to POSIX 1003.1-2001; to read
4150     standard input and then "f", use the command "tail -- - f".
4152   These changes are in response to decisions taken in the January 2005
4153   Austin Group standardization meeting.  For more details, please see
4154   "Utility Syntax Guidelines" in the Minutes of the January 2005
4155   Meeting <https://www.opengroup.org/austin/docs/austin_239.html>.
4157 ** Binary input and output are now implemented more consistently.
4158   These changes affect only platforms like MS-DOS that distinguish
4159   between binary and text files.
4161   The following programs now always use text input/output:
4163     expand unexpand
4165   The following programs now always use binary input/output to copy data:
4167     cp install mv shred
4169   The following programs now always use binary input/output to copy
4170   data, except for stdin and stdout when it is a terminal.
4172     head tac tail tee tr
4173     (cat behaves similarly, unless one of the options -bensAE is used.)
4175   cat's --binary or -B option has been removed.  It existed only on
4176   MS-DOS-like platforms, and didn't work as documented there.
4178   md5sum and sha1sum now obey the -b or --binary option, even if
4179   standard input is a terminal, and they no longer report files to be
4180   binary if they actually read them in text mode.
4182 ** Changes for better conformance to POSIX
4184   cp, ln, mv, rm changes:
4186     Leading white space is now significant in responses to yes-or-no questions.
4187     For example, if "rm" asks "remove regular file `foo'?" and you respond
4188     with " y" (i.e., space before "y"), it counts as "no".
4190   dd changes:
4192     On a QUIT or PIPE signal, dd now exits without printing statistics.
4194     On hosts lacking the INFO signal, dd no longer treats the USR1
4195     signal as if it were INFO when POSIXLY_CORRECT is set.
4197     If the file F is non-seekable and contains fewer than N blocks,
4198     then before copying "dd seek=N of=F" now extends F with zeroed
4199     blocks until F contains N blocks.
4201   fold changes:
4203     When POSIXLY_CORRECT is set, "fold file -3" is now equivalent to
4204     "fold file ./-3", not the obviously-erroneous "fold file ./-w3".
4206   ls changes:
4208     -p now marks only directories; it is equivalent to the new option
4209     --indicator-style=slash.  Use --file-type or
4210     --indicator-style=file-type to get -p's old behavior.
4212   nice changes:
4214     Documentation and diagnostics now refer to "nicenesses" (commonly
4215     in the range -20...19) rather than "nice values" (commonly 0...39).
4217   nohup changes:
4219     nohup now ignores the umask when creating nohup.out.
4221     nohup now closes stderr if it is a terminal and stdout is closed.
4223     nohup now exits with status 127 (not 1) when given an invalid option.
4225   pathchk changes:
4227     It now rejects the empty name in the normal case.  That is,
4228     "pathchk -p ''" now fails, and "pathchk ''" fails unless the
4229     current host (contra POSIX) allows empty file names.
4231     The new -P option checks whether a file name component has leading "-",
4232     as suggested in interpretation "Austin-039:XCU:pathchk:pathchk -p"
4233     <https://collaboration.opengroup.org/austin/interps/documents.php?action=show&gdid=6232>.
4234     It also rejects the empty name even if the current host accepts it; see
4235     <https://collaboration.opengroup.org/austin/interps/documents.php?action=show&gdid=6233>.
4237     The --portability option is now equivalent to -p -P.
4239 ** Bug fixes
4241   chmod, mkdir, mkfifo, and mknod formerly mishandled rarely-used symbolic
4242   permissions like =xX and =u, and did not properly diagnose some invalid
4243   strings like g+gr, ug,+x, and +1.  These bugs have been fixed.
4245   csplit could produce corrupt output, given input lines longer than 8KB
4247   dd now computes statistics using a realtime clock (if available)
4248   rather than the time-of-day clock, to avoid glitches if the
4249   time-of-day is changed while dd is running.  Also, it avoids
4250   using unsafe code in signal handlers; this fixes some core dumps.
4252   expr and test now correctly compare integers of unlimited magnitude.
4254   expr now detects integer overflow when converting strings to integers,
4255   rather than silently wrapping around.
4257   ls now refuses to generate timestamps containing more than 1000 bytes, to
4258   foil potential denial-of-service attacks on hosts with very large stacks.
4260   "mkdir -m =+x dir" no longer ignores the umask when evaluating "+x",
4261   and similarly for mkfifo and mknod.
4263   "mkdir -p /tmp/a/b dir" no longer attempts to create the '.'-relative
4264   directory, dir (in /tmp/a), when, after creating /tmp/a/b, it is unable
4265   to return to its initial working directory.  Similarly for "install -D
4266   file /tmp/a/b/file".
4268   "pr -D FORMAT" now accepts the same formats that "date +FORMAT" does.
4270   stat now exits nonzero if a file operand does not exist
4272 ** Improved robustness
4274   Date no longer needs to allocate virtual memory to do its job,
4275   so it can no longer fail due to an out-of-memory condition,
4276   no matter how large the result.
4278 ** Improved portability
4280   hostid now prints exactly 8 hexadecimal digits, possibly with leading zeros,
4281   and without any spurious leading "fff..." on 64-bit hosts.
4283   nice now works on Darwin 7.7.0 in spite of its invalid definition of NZERO.
4285   'rm -r' can remove all entries in a directory even when it is on a
4286   file system for which readdir is buggy and that was not checked by
4287   coreutils' old configure-time run-test.
4289   sleep no longer fails when resumed after being suspended on linux-2.6.8.1,
4290   in spite of that kernel's buggy nanosleep implementation.
4292 ** New features
4294   chmod -w now complains if its behavior differs from what chmod a-w
4295   would do, and similarly for chmod -r, chmod -x, etc.
4297   cp and mv: the --reply=X option is deprecated
4299   date accepts the new option --rfc-3339=TIMESPEC.  The old --iso-8601 (-I)
4300   option is deprecated; it still works, but new applications should avoid it.
4301   date, du, ls, and pr's time formats now support new %:z, %::z, %:::z
4302   specifiers for numeric time zone offsets like -07:00, -07:00:00, and -07.
4304   dd has new iflag= and oflag= flags "binary" and "text", which have an
4305   effect only on nonstandard platforms that distinguish text from binary I/O.
4307   dircolors now supports SETUID, SETGID, STICKY_OTHER_WRITABLE,
4308   OTHER_WRITABLE, and STICKY, with ls providing default colors for these
4309   categories if not specified by dircolors.
4311   du accepts new options: --time[=TYPE] and --time-style=STYLE
4313   join now supports a NUL field separator, e.g., "join -t '\0'".
4314   join now detects and reports incompatible options, e.g., "join -t x -t y",
4316   ls no longer outputs an extra space between the mode and the link count
4317   when none of the listed files has an ACL.
4319   md5sum --check now accepts multiple input files, and similarly for sha1sum.
4321   If stdin is a terminal, nohup now redirects it from /dev/null to
4322   prevent the command from tying up an OpenSSH session after you logout.
4324   "rm -FOO" now suggests "rm ./-FOO" if the file "-FOO" exists and
4325   "-FOO" is not a valid option.
4327   stat -f -c %S outputs the fundamental block size (used for block counts).
4328   stat -f's default output format has been changed to output this size as well.
4329   stat -f recognizes file systems of type XFS and JFS
4331   "touch -" now touches standard output, not a file named "-".
4333   uname -a no longer generates the -p and -i outputs if they are unknown.
4335 * Major changes in release 5.3.0 (2005-01-08) [unstable]
4337 ** Bug fixes
4339   Several fixes to chgrp and chown for compatibility with POSIX and BSD:
4341     Do not affect symbolic links by default.
4342     Now, operate on whatever a symbolic link points to, instead.
4343     To get the old behavior, use --no-dereference (-h).
4345     --dereference now works, even when the specified owner
4346     and/or group match those of an affected symlink.
4348     Check for incompatible options.  When -R and --dereference are
4349     both used, then either -H or -L must also be used.  When -R and -h
4350     are both used, then -P must be in effect.
4352     -H, -L, and -P have no effect unless -R is also specified.
4353     If -P and -R are both specified, -h is assumed.
4355     Do not optimize away the chown() system call when the file's owner
4356     and group already have the desired value.  This optimization was
4357     incorrect, as it failed to update the last-changed time and reset
4358     special permission bits, as POSIX requires.
4360     "chown : file", "chown '' file", and "chgrp '' file" now succeed
4361     without changing the uid or gid, instead of reporting an error.
4363     Do not report an error if the owner or group of a
4364     recursively-encountered symbolic link cannot be updated because
4365     the file system does not support it.
4367   chmod now accepts multiple mode-like options, e.g., "chmod -r -w f".
4369   chown is no longer subject to a race condition vulnerability, when
4370   used with --from=O:G and without the (-h) --no-dereference option.
4372   cut's --output-delimiter=D option works with abutting byte ranges.
4374   dircolors's documentation now recommends that shell scripts eval
4375   "`dircolors`" rather than `dircolors`, to avoid shell expansion pitfalls.
4377   du no longer segfaults when a subdirectory of an operand
4378   directory is removed while du is traversing that subdirectory.
4379   Since the bug was in the underlying fts.c module, it also affected
4380   chown, chmod, and chgrp.
4382   du's --exclude-from=FILE and --exclude=P options now compare patterns
4383   against the entire name of each file, rather than against just the
4384   final component.
4386   echo now conforms to POSIX better.  It supports the \0ooo syntax for
4387   octal escapes, and \c now terminates printing immediately.  If
4388   POSIXLY_CORRECT is set and the first argument is not "-n", echo now
4389   outputs all option-like arguments instead of treating them as options.
4391   expand and unexpand now conform to POSIX better.  They check for
4392   blanks (which can include characters other than space and tab in
4393   non-POSIX locales) instead of spaces and tabs.  Unexpand now
4394   preserves some blanks instead of converting them to tabs or spaces.
4396   "ln x d/" now reports an error if d/x is a directory and x a file,
4397   instead of incorrectly creating a link to d/x/x.
4399   ls no longer segfaults on systems for which SIZE_MAX != (size_t) -1.
4401   md5sum and sha1sum now report an error when given so many input
4402   lines that their line counter overflows, instead of silently
4403   reporting incorrect results.
4405   Fixes for "nice":
4407     If it fails to lower the niceness due to lack of permissions,
4408     it goes ahead and runs the command anyway, as POSIX requires.
4410     It no longer incorrectly reports an error if the current niceness
4411     happens to be -1.
4413     It no longer assumes that nicenesses range from -20 through 19.
4415     It now consistently adjusts out-of-range nicenesses to the
4416     closest values in range; formerly it sometimes reported an error.
4418   pathchk no longer accepts trailing options, e.g., "pathchk -p foo -b"
4419   now treats -b as a file name to check, not as an invalid option.
4421   'pr --columns=N' was not equivalent to 'pr -N' when also using
4422   either -s or -w.
4424   pr now supports page numbers up to 2**64 on most hosts, and it
4425   detects page number overflow instead of silently wrapping around.
4426   pr now accepts file names that begin with "+" so long as the rest of
4427   the file name does not look like a page range.
4429   printf has several changes:
4431     It now uses 'intmax_t' (not 'long int') to format integers, so it
4432     can now format 64-bit integers on most modern hosts.
4434     On modern hosts it now supports the C99-inspired %a, %A, %F conversion
4435     specs, the "'" and "0" flags, and the ll, j, t, and z length modifiers
4436     (this is compatible with recent Bash versions).
4438     The printf command now rejects invalid conversion specifications
4439     like %#d, instead of relying on undefined behavior in the underlying
4440     printf function.
4442   ptx now diagnoses invalid values for its --width=N (-w)
4443   and --gap-size=N (-g) options.
4445   mv (when moving between partitions) no longer fails when
4446   operating on too many command-line-specified nonempty directories.
4448   "readlink -f" is more compatible with prior implementations
4450   rm (without -f) no longer hangs when attempting to remove a symlink
4451   to a file on an off-line NFS-mounted partition.
4453   rm no longer gets a failed assertion under some unusual conditions.
4455   rm no longer requires read access to the current directory.
4457   "rm -r" would mistakenly fail to remove files under a directory
4458   for some types of errors (e.g., read-only file system, I/O error)
4459   when first encountering the directory.
4461   "sort" fixes:
4463     "sort -o -" now writes to a file named "-" instead of to standard
4464     output; POSIX requires this.
4466     An unlikely race condition has been fixed where "sort" could have
4467     mistakenly removed a temporary file belonging to some other process.
4469     "sort" no longer has O(N**2) behavior when it creates many temporary files.
4471   tac can now handle regular, nonseekable files like Linux's
4472   /proc/modules.  Before, it would produce no output for such a file.
4474   tac would exit immediately upon I/O or temp-file creation failure.
4475   Now it continues on, processing any remaining command line arguments.
4477   "tail -f" no longer mishandles pipes and fifos.  With no operands,
4478   tail now ignores -f if standard input is a pipe, as POSIX requires.
4479   When conforming to POSIX 1003.2-1992, tail now supports the SUSv2 b
4480   modifier (e.g., "tail -10b file") and it handles some obscure cases
4481   more correctly, e.g., "tail +cl" now reads the file "+cl" rather
4482   than reporting an error, "tail -c file" no longer reports an error,
4483   and "tail - file" no longer reads standard input.
4485   tee now exits when it gets a SIGPIPE signal, as POSIX requires.
4486   To get tee's old behavior, use the shell command "(trap '' PIPE; tee)".
4487   Also, "tee -" now writes to standard output instead of to a file named "-".
4489   "touch -- MMDDhhmm[yy] file" is now equivalent to
4490   "touch MMDDhhmm[yy] file" even when conforming to pre-2001 POSIX.
4492   tr no longer mishandles a second operand with leading "-".
4494   who now prints user names in full instead of truncating them after 8 bytes.
4496   The following commands now reject unknown options instead of
4497   accepting them as operands, so that users are properly warned that
4498   options may be added later.  Formerly they accepted unknown options
4499   as operands; e.g., "basename -a a" acted like "basename -- -a a".
4501     basename dirname factor hostname link nohup sync unlink yes
4503 ** New features
4505   For efficiency, 'sort -m' no longer copies input to a temporary file
4506   merely because the input happens to come from a pipe.  As a result,
4507   some relatively-contrived examples like 'cat F | sort -m -o F - G'
4508   are no longer safe, as 'sort' might start writing F before 'cat' is
4509   done reading it.  This problem cannot occur unless '-m' is used.
4511   When outside the default POSIX locale, the 'who' and 'pinky'
4512   commands now output timestamps like "2004-06-21 13:09" instead of
4513   the traditional "Jun 21 13:09".
4515   pwd now works even when run from a working directory whose name
4516   is longer than PATH_MAX.
4518   cp, install, ln, and mv have a new --no-target-directory (-T) option,
4519   and -t is now a short name for their --target-directory option.
4521   cp -pu and mv -u (when copying) now don't bother to update the
4522   destination if the resulting timestamp would be no newer than the
4523   preexisting timestamp.  This saves work in the common case when
4524   copying or moving multiple times to the same destination in a file
4525   system with a coarse timestamp resolution.
4527   cut accepts a new option, --complement, to complement the set of
4528   selected bytes, characters, or fields.
4530   dd now also prints the number of bytes transferred, the time, and the
4531   transfer rate.  The new "status=noxfer" operand suppresses this change.
4533   dd has new conversions for the conv= option:
4535     nocreat   do not create the output file
4536     excl      fail if the output file already exists
4537     fdatasync physically write output file data before finishing
4538     fsync     likewise, but also write metadata
4540   dd has new iflag= and oflag= options with the following flags:
4542     append    append mode (makes sense for output file only)
4543     direct    use direct I/O for data
4544     dsync     use synchronized I/O for data
4545     sync      likewise, but also for metadata
4546     nonblock  use non-blocking I/O
4547     nofollow  do not follow symlinks
4548     noctty    do not assign controlling terminal from file
4550   stty now provides support (iutf8) for setting UTF-8 input mode.
4552   With stat, a specified format is no longer automatically newline terminated.
4553   If you want a newline at the end of your output, append '\n' to the format
4554   string.
4556   'df', 'du', and 'ls' now take the default block size from the
4557   BLOCKSIZE environment variable if the BLOCK_SIZE, DF_BLOCK_SIZE,
4558   DU_BLOCK_SIZE, and LS_BLOCK_SIZE environment variables are not set.
4559   Unlike the other variables, though, BLOCKSIZE does not affect
4560   values like 'ls -l' sizes that are normally displayed as bytes.
4561   This new behavior is for compatibility with BSD.
4563   du accepts a new option --files0-from=FILE, where FILE contains a
4564   list of NUL-terminated file names.
4566   Date syntax as used by date -d, date -f, and touch -d has been
4567   changed as follows:
4569     Dates like 'January 32' with out-of-range components are now rejected.
4571     Dates can have fractional timestamps like 2004-02-27 14:19:13.489392193.
4573     Dates can be entered via integer counts of seconds since 1970 when
4574     prefixed by '@'.  For example, '@321' represents 1970-01-01 00:05:21 UTC.
4576     Time zone corrections can now separate hours and minutes with a colon,
4577     and can follow standard abbreviations like "UTC".  For example,
4578     "UTC +0530" and "+05:30" are supported, and are both equivalent to "+0530".
4580     Date values can now have leading TZ="..." assignments that override
4581     the environment only while that date is being processed.  For example,
4582     the following shell command converts from Paris to New York time:
4584       TZ="America/New_York" date --date='TZ="Europe/Paris" 2004-10-31 06:30'
4586   'date' has a new option --iso-8601=ns that outputs
4587   nanosecond-resolution timestamps.
4589   echo -e '\xHH' now outputs a byte whose hexadecimal value is HH,
4590   for compatibility with bash.
4592   ls now exits with status 1 on minor problems, 2 if serious trouble.
4594   ls has a new --hide=PATTERN option that behaves like
4595   --ignore=PATTERN, except that it is overridden by -a or -A.
4596   This can be useful for aliases, e.g., if lh is an alias for
4597   "ls --hide='*~'", then "lh -A" lists the file "README~".
4599   In the following cases POSIX allows the default GNU behavior,
4600   so when POSIXLY_CORRECT is set:
4602     false, printf, true, unlink, and yes all support --help and --option.
4603     ls supports TABSIZE.
4604     pr no longer depends on LC_TIME for the date format in non-POSIX locales.
4605     printf supports \u, \U, \x.
4606     tail supports two or more files when using the obsolete option syntax.
4608   The usual '--' operand is now supported by chroot, hostid, hostname,
4609   pwd, sync, and yes.
4611   'od' now conforms to POSIX better, and is more compatible with BSD:
4613     The older syntax "od [-abcdfilosx]... [FILE] [[+]OFFSET[.][b]]" now works
4614     even without --traditional.  This is a change in behavior if there
4615     are one or two operands and the last one begins with +, or if
4616     there are two operands and the latter one begins with a digit.
4617     For example, "od foo 10" and "od +10" now treat the last operand as
4618     an offset, not as a file name.
4620     -h is no longer documented, and may be withdrawn in future versions.
4621     Use -x or -t x2 instead.
4623     -i is now equivalent to -t dI (not -t d2), and
4624     -l is now equivalent to -t dL (not -t d4).
4626     -s is now equivalent to -t d2.  The old "-s[NUM]" or "-s NUM"
4627     option has been renamed to "-S NUM".
4629     The default output format is now -t oS, not -t o2, i.e., short int
4630     rather than two-byte int.  This makes a difference only on hosts like
4631     Cray systems where the C short int type requires more than two bytes.
4633   readlink accepts new options: --canonicalize-existing (-e)
4634   and --canonicalize-missing (-m).
4636   The stat option --filesystem has been renamed to --file-system, for
4637   consistency with POSIX "file system" and with cp and du --one-file-system.
4639 ** Removed features
4641   md5sum and sha1sum's undocumented --string option has been removed.
4643   tail's undocumented --max-consecutive-size-changes option has been removed.
4645 * Major changes in release 5.2.1 (2004-03-12) [stable]
4647 ** Bug fixes
4649   mv could mistakenly fail to preserve hard links when moving two
4650   or more arguments between partitions.
4652   'cp --sparse=always F /dev/hdx' no longer tries to use lseek to create
4653   holes in the destination.
4655   nohup now sets the close-on-exec flag for its copy of the stderr file
4656   descriptor.  This avoids some nohup-induced hangs.  For example, before
4657   this change, if you ran 'ssh localhost', then 'nohup sleep 600 </dev/null &',
4658   and then exited that remote shell, the ssh session would hang until the
4659   10-minute sleep terminated.  With the fixed nohup, the ssh session
4660   terminates immediately.
4662   'expr' now conforms to POSIX better:
4664     Integers like -0 and 00 are now treated as zero.
4666     The '|' operator now returns 0, not its first argument, if both
4667     arguments are null or zero.  E.g., 'expr "" \| ""' now returns 0,
4668     not the empty string.
4670     The '|' and '&' operators now use short-circuit evaluation, e.g.,
4671     'expr 1 \| 1 / 0' no longer reports a division by zero.
4673 ** New features
4675   'chown user.group file' now has its traditional meaning even when
4676   conforming to POSIX 1003.1-2001, so long as no user has a name
4677   containing '.' that happens to equal 'user.group'.
4680 * Major changes in release 5.2.0 (2004-02-19) [stable]
4682 ** Bug fixes
4684   none
4687 * Major changes in release 5.1.3 (2004-02-08): candidate to become stable 5.2.0
4689 ** Bug fixes
4691   'cp -d' now works as required even on systems like OSF V5.1 that
4692   declare stat and lstat as 'static inline' functions.
4694   timestamps output by stat now include actual fractional seconds,
4695   when available -- or .0000000 for files without that information.
4697   seq no longer infloops when printing 2^31 or more numbers.
4698   For reference, seq `echo 2^31|bc` > /dev/null takes about one hour
4699   on a 1.6 GHz Athlon 2000 XP.  Now it can output 2^53-1 numbers before
4700   misbehaving.
4702 * Major changes in release 5.1.2 (2004-01-25):
4704 ** Bug fixes
4706   rmdir -p exits with status 1 on error; formerly it sometimes exited
4707   with status 0 when given more than one argument.
4709   nohup now always exits with status 127 when it finds an error,
4710   as POSIX requires; formerly it sometimes exited with status 1.
4712   Several programs (including cut, date, dd, env, hostname, nl, pr,
4713   stty, and tr) now always exit with status 1 when they find an error;
4714   formerly they sometimes exited with status 2.
4716   factor no longer reports a usage error if stdin has the wrong format.
4718   paste no longer infloops on ppc systems (bug introduced in 5.1.1)
4721 * Major changes in release 5.1.1 (2004-01-17):
4723 ** Configuration option
4725   You can select the default level of POSIX conformance at configure-time,
4726   e.g., by ./configure DEFAULT_POSIX2_VERSION=199209
4728 ** Bug fixes
4730   fold -s works once again on systems with differing sizes for int
4731   and size_t (bug introduced in 5.1.0)
4733 ** New features
4735   touch -r now specifies the origin for any relative times in the -d
4736   operand, if both options are given.  For example, "touch -r FOO -d
4737   '-5 seconds' BAR" sets BAR's modification time to be five seconds
4738   before FOO's.
4740   join: The obsolete options "-j1 FIELD", "-j2 FIELD", and
4741   "-o LIST1 LIST2..." are no longer supported on POSIX 1003.1-2001 systems.
4742   Portable scripts should use "-1 FIELD", "-2 FIELD", and
4743   "-o LIST1,LIST2..." respectively.  If join was compiled on a
4744   POSIX 1003.1-2001 system, you may enable the old behavior
4745   by setting _POSIX2_VERSION=199209 in your environment.
4746   [This change was reverted in coreutils 5.3.1.]
4749 * Major changes in release 5.1.0 (2003-12-21):
4751 ** New features
4753   chgrp, chmod, and chown can now process (with -R) hierarchies of virtually
4754   unlimited depth.  Before, they would fail to operate on any file they
4755   encountered with a relative name of length PATH_MAX (often 4096) or longer.
4757   chgrp, chmod, chown, and rm accept the new options:
4758   --preserve-root, --no-preserve-root (default)
4760   chgrp and chown now accept POSIX-mandated -L, -H, and -P options
4762   du can now process hierarchies of virtually unlimited depth.
4763   Before, du was limited by the user's stack size and it would get a
4764   stack overflow error (often a segmentation fault) when applied to
4765   a hierarchy of depth around 30,000 or larger.
4767   du works even when run from an inaccessible directory
4769   du -D now dereferences all symlinks specified on the command line,
4770   not just the ones that reference directories
4772   du now accepts -P (--no-dereference), for compatibility with du
4773   of NetBSD and for consistency with e.g., chown and chgrp
4775   du's -H option will soon have the meaning required by POSIX
4776   (--dereference-args, aka -D) rather then the current meaning of --si.
4777   Now, using -H elicits a warning to that effect.
4779   When given -l and similar options, ls now adjusts the output column
4780   widths to fit the data, so that output lines are shorter and have
4781   columns that line up better.  This may adversely affect shell
4782   scripts that expect fixed-width columns, but such shell scripts were
4783   not portable anyway, even with old GNU ls where the columns became
4784   ragged when a datum was too wide.
4786   du accepts a new option, -0/--null, to make it produce NUL-terminated
4787   output lines
4789 ** Bug fixes
4791   printf, seq, tail, and sleep now parse floating-point operands
4792   and options in the C locale.  POSIX requires this for printf.
4794   od -c -w9999999 no longer segfaults
4796   csplit no longer reads from freed memory (dumping core on some systems)
4798   csplit would mistakenly exhaust virtual memory in some cases
4800   ls --width=N (for very large N) is no longer subject to an address
4801   arithmetic bug that could result in bounds violations.
4803   ls --width=N (with -x or -C) no longer allocates more space
4804   (potentially much more) than necessary for a given directory.
4806   dd 'unblock' and 'sync' may now be combined (e.g., dd conv=unblock,sync)
4808 * Major changes in release 5.0.91 (2003-09-08):
4810 ** New features
4812   date accepts a new option --rfc-2822, an alias for --rfc-822.
4814   split accepts a new option -d or --numeric-suffixes.
4816   cp, install, mv, and touch now preserve microsecond resolution on
4817   file timestamps, on platforms that have the 'utimes' system call.
4818   Unfortunately there is no system call yet to preserve file
4819   timestamps to their full nanosecond resolution; microsecond
4820   resolution is the best we can do right now.
4822   sort now supports the zero byte (NUL) as a field separator; use -t '\0'.
4823   The -t '' option, which formerly had no effect, is now an error.
4825   sort option order no longer matters for the options -S, -d, -i, -o, and -t.
4826   Stronger options override weaker, and incompatible options are diagnosed.
4828   'sha1sum --check' now accepts the BSD format for SHA1 message digests
4829   in addition to the BSD format for MD5 ones.
4831   who -l now means 'who --login', not 'who --lookup', per POSIX.
4832   who's -l option has been eliciting an unconditional warning about
4833   this impending change since sh-utils-2.0.12 (April 2002).
4835 ** Bug fixes
4837   Mistakenly renaming a file onto itself, e.g., via 'mv B b' when 'B' is
4838   the same directory entry as 'b' no longer destroys the directory entry
4839   referenced by both 'b' and 'B'.  Note that this would happen only on
4840   file systems like VFAT where two different names may refer to the same
4841   directory entry, usually due to lower->upper case mapping of file names.
4842   Now, the above can happen only on file systems that perform name mapping and
4843   that support hard links (stat.st_nlink > 1).  This mitigates the problem
4844   in two ways: few file systems appear to be affected (hpfs and ntfs are),
4845   when the bug is triggered, mv no longer removes the last hard link to a file.
4846   *** ATTENTION ***: if you know how to distinguish the following two cases
4847   without writing to the file system in question, please let me know:
4848   1) B and b refer to the same directory entry on a file system like NTFS
4849        (B may well have a link count larger than 1)
4850   2) B and b are hard links to the same file
4852   stat no longer overruns a buffer for format strings ending in '%'
4854   fold -s -wN would infloop for N < 8 with TABs in the input.
4855   E.g., this would not terminate: printf 'a\t' | fold -w2 -s
4857   'split -a0', although of questionable utility, is accepted once again.
4859   'df DIR' used to hang under some conditions on OSF/1 5.1.  Now it doesn't.
4861   seq's --width (-w) option now works properly even when the endpoint
4862   requiring the larger width is negative and smaller than the other endpoint.
4864   seq's default step is 1, even if LAST < FIRST.
4866   paste no longer mistakenly outputs 0xFF bytes for a nonempty input file
4867   without a trailing newline.
4869   'tail -n0 -f FILE' and 'tail -c0 -f FILE' no longer perform what amounted
4870   to a busy wait, rather than sleeping between iterations.
4872   tail's long-undocumented --allow-missing option now elicits a warning
4875 * Major changes in release 5.0.90 (2003-07-29):
4877 ** New features
4879   sort is now up to 30% more CPU-efficient in some cases
4881   'test' is now more compatible with Bash and POSIX:
4883     'test -t', 'test --help', and 'test --version' now silently exit
4884     with status 0.  To test whether standard output is a terminal, use
4885     'test -t 1'.  To get help and version info for 'test', use
4886     '[ --help' and '[ --version'.
4888     'test' now exits with status 2 (not 1) if there is an error.
4890   wc count field widths now are heuristically adjusted depending on the input
4891   size, if known.  If only one count is printed, it is guaranteed to
4892   be printed without leading spaces.
4894   Previously, wc did not align the count fields if POSIXLY_CORRECT was set,
4895   but POSIX did not actually require this undesirable behavior, so it
4896   has been removed.
4898 ** Bug fixes
4900   kill no longer tries to operate on argv[0] (introduced in 5.0.1)
4901   Why wasn't this noticed?  Although many tests use kill, none of
4902   them made an effort to avoid using the shell's built-in kill.
4904   '[' invoked with no arguments no longer evokes a segfault
4906   rm without --recursive (aka -r or -R) no longer prompts regarding
4907   unwritable directories, as required by POSIX.
4909   uniq -c now uses a SPACE, not a TAB between the count and the
4910   corresponding line, as required by POSIX.
4912   expr now exits with status 2 if the expression is syntactically valid,
4913   and with status 3 if an error occurred.  POSIX requires this.
4915   expr now reports trouble if string comparison fails due to a collation error.
4917   split now generates suffixes properly on EBCDIC hosts.
4919   split -a0 now works, as POSIX requires.
4921   'sort --version' and 'sort --help' fail, as they should
4922   when their output is redirected to /dev/full.
4924   'su --version > /dev/full' now fails, as it should.
4926 ** Fewer arbitrary limitations
4928   cut requires 97% less memory when very large field numbers or
4929   byte offsets are specified.
4932 * Major changes in release 5.0.1 (2003-07-15):
4934 ** New programs
4935 - new program: '[' (much like 'test')
4937 ** New features
4938 - head now accepts --lines=-N (--bytes=-N) to print all but the
4939   N lines (bytes) at the end of the file
4940 - md5sum --check now accepts the output of the BSD md5sum program, e.g.,
4941   MD5 (f) = d41d8cd98f00b204e9800998ecf8427e
4942 - date -d DATE can now parse a DATE string like May-23-2003
4943 - chown: '.' is no longer recognized as a separator in the OWNER:GROUP
4944   specifier on POSIX 1003.1-2001 systems.  If chown *was not* compiled
4945   on such a system, then it still accepts '.', by default.  If chown
4946   was compiled on a POSIX 1003.1-2001 system, then you may enable the
4947   old behavior by setting _POSIX2_VERSION=199209 in your environment.
4948 - chown no longer tries to preserve set-user-ID and set-group-ID bits;
4949   on some systems, the chown syscall resets those bits, and previous
4950   versions of the chown command would call chmod to restore the original,
4951   pre-chown(2) settings, but that behavior is problematic.
4952   1) There was a window whereby a malicious user, M, could subvert a
4953   chown command run by some other user and operating on files in a
4954   directory where M has write access.
4955   2) Before (and even now, on systems with chown(2) that doesn't reset
4956   those bits), an unwary admin. could use chown unwittingly to create e.g.,
4957   a set-user-ID root copy of /bin/sh.
4959 ** Bug fixes
4960 - chown --dereference no longer leaks a file descriptor per symlink processed
4961 - 'du /' once again prints the '/' on the last line
4962 - split's --verbose option works once again [broken in 4.5.10 and 5.0]
4963 - tail -f is no longer subject to a race condition that could make it
4964   delay displaying the last part of a file that had stopped growing.  That
4965   bug could also make tail -f give an unwarranted 'file truncated' warning.
4966 - du no longer runs out of file descriptors unnecessarily
4967 - df and 'readlink --canonicalize' no longer corrupt the heap on
4968   non-glibc, non-solaris systems
4969 - 'env -u UNSET_VARIABLE' no longer dumps core on non-glibc systems
4970 - readlink's --canonicalize option now works on systems like Solaris that
4971   lack the canonicalize_file_name function but do have resolvepath.
4972 - mv now removes 'a' in this example on all systems: touch a; ln a b; mv a b
4973   This behavior is contrary to POSIX (which requires that the mv command do
4974   nothing and exit successfully), but I suspect POSIX will change.
4975 - date's %r format directive now honors locale settings
4976 - date's '-' (no-pad) format flag now affects the space-padded-by-default
4977   conversion specifiers, %e, %k, %l
4978 - fmt now diagnoses invalid obsolescent width specifications like '-72x'
4979 - fmt now exits nonzero when unable to open an input file
4980 - tsort now fails when given an odd number of input tokens,
4981   as required by POSIX.  Before, it would act as if the final token
4982   appeared one additional time.
4984 ** Fewer arbitrary limitations
4985 - tail's byte and line counts are no longer limited to OFF_T_MAX.
4986   Now the limit is UINTMAX_MAX (usually 2^64).
4987 - split can now handle --bytes=N and --lines=N with N=2^31 or more.
4989 ** Portability
4990 - 'kill -t' now prints signal descriptions (rather than '?') on systems
4991   like Tru64 with __sys_siglist but no strsignal function.
4992 - stat.c now compiles on Ultrix systems
4993 - sleep now works on AIX systems that lack support for clock_gettime
4994 - rm now works around Darwin6.5's broken readdir function
4995   Before 'rm -rf DIR' would fail to remove all files in DIR
4996   if there were more than 338.
4998 * Major changes in release 5.0 (2003-04-02):
4999 - false --help now exits nonzero
5001 [4.5.12]
5002 * printf no longer treats \x specially when POSIXLY_CORRECT is set
5003 * printf avoids buffer overrun with format ending in a backslash and
5004 * printf avoids buffer overrun with incomplete conversion specifier
5005 * printf accepts multiple flags in a single conversion specifier
5007 [4.5.11]
5008 * seq no longer requires that a field width be specified
5009 * seq no longer fails when given a field width of '0'
5010 * seq now accepts " " and "'" as valid format flag characters
5011 * df now shows a HOSTNAME: prefix for each remote-mounted file system on AIX 5.1
5012 * portability tweaks for HP-UX, AIX 5.1, DJGPP
5014 [4.5.10]
5015 * printf no longer segfaults for a negative field width or precision
5016 * shred now always enables --exact for non-regular files
5017 * du no longer lists hard-linked files more than once
5018 * du no longer dumps core on some systems due to "infinite" recursion
5019   via nftw's use of the buggy replacement function in getcwd.c
5020 * portability patches for a few vendor compilers and 64-bit systems
5021 * du -S *really* now works like it did before the change in 4.5.5
5023 [4.5.9]
5024 * du no longer truncates file sizes or sums to fit in 32-bit size_t
5025 * work around Linux kernel bug in getcwd (fixed in 2.4.21-pre4), so that pwd
5026   now fails if the name of the working directory is so long that getcwd
5027   truncates it.  Before it would print the truncated name and exit successfully.
5028 * 'df /some/mount-point' no longer hangs on a GNU libc system when another
5029   hard-mounted NFS file system (preceding /some/mount-point in /proc/mounts)
5030   is inaccessible.
5031 * rm -rf now gives an accurate diagnostic when failing to remove a file
5032   under certain unusual conditions
5033 * mv and 'cp --preserve=links' now preserve multiple hard links even under
5034   certain unusual conditions where they used to fail
5036 [4.5.8]
5037 * du -S once again works like it did before the change in 4.5.5
5038 * stat accepts a new file format, %B, for the size of each block reported by %b
5039 * du accepts new option: --apparent-size
5040 * du --bytes (-b) works the same way it did in fileutils-3.16 and before
5041 * du reports proper sizes for directories (not zero) (broken in 4.5.6 or 4.5.7)
5042 * df now always displays under 'Filesystem', the device file name
5043   corresponding to the listed mount point.  Before, for a block- or character-
5044   special file command line argument, df would display that argument.  E.g.,
5045   'df /dev/hda' would list '/dev/hda' as the 'Filesystem', rather than say
5046   /dev/hda3 (the device on which '/' is mounted), as it does now.
5047 * test now works properly when invoked from a set user ID or set group ID
5048   context and when testing access to files subject to alternate protection
5049   mechanisms.  For example, without this change, a set-UID program that invoked
5050   'test -w F' (to see if F is writable) could mistakenly report that it *was*
5051   writable, even though F was on a read-only file system, or F had an ACL
5052   prohibiting write access, or F was marked as immutable.
5054 [4.5.7]
5055 * du would fail with more than one DIR argument when any but the last did not
5056   contain a slash (due to a bug in ftw.c)
5058 [4.5.6]
5059 * du no longer segfaults on Solaris systems (fixed heap-corrupting bug in ftw.c)
5060 * du --exclude=FILE works once again (this was broken by the rewrite for 4.5.5)
5061 * du no longer gets a failed assertion for certain hierarchy lay-outs
5062   involving hard-linked directories
5063 * 'who -r' no longer segfaults when using non-C-locale messages
5064 * df now displays a mount point (usually '/') for non-mounted
5065   character-special and block files
5067 [4.5.5]
5068 * ls --dired produces correct byte offset for file names containing
5069   nonprintable characters in a multibyte locale
5070 * du has been rewritten to use a variant of GNU libc's ftw.c
5071 * du now counts the space associated with a directory's directory entry,
5072   even if it cannot list or chdir into that subdirectory.
5073 * du -S now includes the st_size of each entry corresponding to a subdirectory
5074 * rm on FreeBSD can once again remove directories from NFS-mounted file systems
5075 * ls has a new option --dereference-command-line-symlink-to-dir, which
5076   corresponds to the new default behavior when none of -d, -l -F, -H, -L
5077   has been specified.
5078 * ls dangling-symlink now prints 'dangling-symlink'.
5079   Before, it would fail with 'no such file or directory'.
5080 * ls -s symlink-to-non-dir and ls -i symlink-to-non-dir now print
5081   attributes of 'symlink', rather than attributes of their referents.
5082 * Fix a bug introduced in 4.5.4 that made it so that ls --color would no
5083   longer highlight the names of files with the execute bit set when not
5084   specified on the command line.
5085 * shred's --zero (-z) option no longer gobbles up any following argument.
5086   Before, 'shred --zero file' would produce 'shred: missing file argument',
5087   and worse, 'shred --zero f1 f2 ...' would appear to work, but would leave
5088   the first file untouched.
5089 * readlink: new program
5090 * cut: new feature: when used to select ranges of byte offsets (as opposed
5091   to ranges of fields) and when --output-delimiter=STRING is specified,
5092   output STRING between ranges of selected bytes.
5093 * rm -r can no longer be tricked into mistakenly reporting a cycle.
5094 * when rm detects a directory cycle, it no longer aborts the entire command,
5095   but rather merely stops processing the affected command line argument.
5097 [4.5.4]
5098 * cp no longer fails to parse options like this: --preserve=mode,ownership
5099 * 'ls --color -F symlink-to-dir' works properly
5100 * ls is much more efficient on directories with valid dirent.d_type.
5101 * stty supports all baud rates defined in linux-2.4.19.
5102 * 'du symlink-to-dir/' would improperly remove the trailing slash
5103 * 'du ""' would evoke a bounds violation.
5104 * In the unlikely event that running 'du /' resulted in 'stat ("/", ...)'
5105   failing, du would give a diagnostic about '' (empty string) rather than '/'.
5106 * printf: a hexadecimal escape sequence has at most two hex. digits, not three.
5107 * The following features have been added to the --block-size option
5108   and similar environment variables of df, du, and ls.
5109   - A leading "'" generates numbers with thousands separators.
5110     For example:
5111       $ ls -l --block-size="'1" file
5112       -rw-rw-r--    1 eggert   src      47,483,707 Sep 24 23:40 file
5113   - A size suffix without a leading integer generates a suffix in the output.
5114     For example:
5115       $ ls -l --block-size="K"
5116       -rw-rw-r--    1 eggert   src          46371K Sep 24 23:40 file
5117 * ls's --block-size option now affects file sizes in all cases, not
5118   just for --block-size=human-readable and --block-size=si.  Fractional
5119   sizes are now always rounded up, for consistency with df and du.
5120 * df now displays the block size using powers of 1000 if the requested
5121   block size seems to be a multiple of a power of 1000.
5122 * nl no longer gets a segfault when run like this 'yes|nl -s%n'
5124 [4.5.3]
5125 * du --dereference-args (-D) no longer fails in certain cases
5126 * 'ln --target-dir=DIR' no longer fails when given a single argument
5128 [4.5.2]
5129 * 'rm -i dir' (without --recursive (-r)) no longer recurses into dir
5130 * 'tail -c N FILE' now works with files of size >= 4GB
5131 * 'mkdir -p' can now create very deep (e.g. 40,000-component) directories
5132 * rmdir -p dir-with-trailing-slash/ no longer fails
5133 * printf now honors the '--' command line delimiter
5134 * od's 8-byte formats x8, o8, and u8 now work
5135 * tail now accepts fractional seconds for its --sleep-interval=S (-s) option
5137 [4.5.1]
5138 * du and ls now report sizes of symbolic links (before they'd always report 0)
5139 * uniq now obeys the LC_COLLATE locale, as per POSIX 1003.1-2001 TC1.
5141 ========================================================================
5142 Here are the NEWS entries made from fileutils-4.1 until the
5143 point at which the packages merged to form the coreutils:
5145 [4.1.11]
5146 * 'rm symlink-to-unwritable' doesn't prompt [introduced in 4.1.10]
5147 [4.1.10]
5148 * rm once again gives a reasonable diagnostic when failing to remove a file
5149     owned by someone else in a sticky directory [introduced in 4.1.9]
5150 * df now rounds all quantities up, as per POSIX.
5151 * New ls time style: long-iso, which generates YYYY-MM-DD HH:MM.
5152 * Any time style can be preceded by "posix-"; this causes "ls" to
5153   use traditional timestamp format when in the POSIX locale.
5154 * The default time style is now posix-long-iso instead of posix-iso.
5155   Set TIME_STYLE="posix-iso" to revert to the behavior of 4.1.1 through 4.1.9.
5156 * 'rm dangling-symlink' doesn't prompt [introduced in 4.1.9]
5157 * stat: remove support for --secure/-s option and related %S and %C format specs
5158 * stat: rename --link/-l to --dereference/-L.
5159     The old options will continue to work for a while.
5160 [4.1.9]
5161 * rm can now remove very deep hierarchies, in spite of any limit on stack size
5162 * new programs: link, unlink, and stat
5163 * New ls option: --author (for the Hurd).
5164 * 'touch -c no-such-file' no longer fails, per POSIX
5165 [4.1.8]
5166 * mv no longer mistakenly creates links to preexisting destination files
5167     that aren't moved
5168 [4.1.7]
5169 * rm: close a hole that would allow a running rm process to be subverted
5170 [4.1.6]
5171 * New cp option: --copy-contents.
5172 * cp -r is now equivalent to cp -R.  Use cp -R -L --copy-contents to get the
5173   traditional (and rarely desirable) cp -r behavior.
5174 * ls now accepts --time-style=+FORMAT, where +FORMAT works like date's format
5175 * The obsolete usage 'touch [-acm] MMDDhhmm[YY] FILE...' is no longer
5176   supported on systems conforming to POSIX 1003.1-2001.  Use touch -t instead.
5177 * cp and inter-partition mv no longer give a misleading diagnostic in some
5178     unusual cases
5179 [4.1.5]
5180 * cp -r no longer preserves symlinks
5181 * The block size notation is now compatible with SI and with IEC 60027-2.
5182   For example, --block-size=1MB now means --block-size=1000000,
5183   whereas --block-size=1MiB now means --block-size=1048576.
5184   A missing 'B' (e.g. '1M') has the same meaning as before.
5185   A trailing 'B' now means decimal, not binary; this is a silent change.
5186   The nonstandard 'D' suffix (e.g. '1MD') is now obsolescent.
5187 * -H or --si now outputs the trailing 'B', for consistency with the above.
5188 * Programs now output trailing 'K' (not 'k') to mean 1024, as per IEC 60027-2.
5189 * New df, du short option -B is short for --block-size.
5190 * You can omit an integer '1' before a block size suffix,
5191   e.g. 'df -BG' is equivalent to 'df -B 1G' and to 'df --block-size=1G'.
5192 * The following options are now obsolescent, as their names are
5193   incompatible with IEC 60027-2:
5194    df, du: -m or --megabytes (use -BM or --block-size=1M)
5195    df, du, ls: --kilobytes (use --block-size=1K)
5196 [4.1.4]
5197 * df --local no longer lists smbfs file systems whose name starts with //
5198 * dd now detects the Linux/tape/lseek bug at run time and warns about it.
5199 [4.1.3]
5200 * ls -R once again outputs a blank line between per-directory groups of files.
5201     This was broken by the cycle-detection change in 4.1.1.
5202 * dd once again uses 'lseek' on character devices like /dev/mem and /dev/kmem.
5203     On systems with the linux kernel (at least up to 2.4.16), dd must still
5204     resort to emulating 'skip=N' behavior using reads on tape devices, because
5205     lseek has no effect, yet appears to succeed.  This may be a kernel bug.
5206 [4.1.2]
5207 * cp no longer fails when two or more source files are the same;
5208     now it just gives a warning and doesn't copy the file the second time.
5209     E.g., cp a a d/ produces this:
5210     cp: warning: source file `a' specified more than once
5211 * chmod would set the wrong bit when given symbolic mode strings like
5212     these: g=o, o=g, o=u.  E.g., 'chmod a=,o=w,ug=o f' would give a mode
5213     of --w-r---w- rather than --w--w--w-.
5214 [4.1.1]
5215 * mv (likewise for cp), now fails rather than silently clobbering one of
5216     the source files in the following example:
5217     rm -rf a b c; mkdir a b c; touch a/f b/f; mv a/f b/f c
5218 * ls -R detects directory cycles, per POSIX.  It warns and doesn't infloop.
5219 * cp's -P option now means the same as --no-dereference, per POSIX.
5220     Use --parents to get the old meaning.
5221 * When copying with the -H and -L options, cp can preserve logical
5222     links between source files with --preserve=links
5223 * cp accepts new options:
5224     --preserve[={mode,ownership,timestamps,links,all}]
5225     --no-preserve={mode,ownership,timestamps,links,all}
5226 * cp's -p and --preserve options remain unchanged and are equivalent
5227     to '--preserve=mode,ownership,timestamps'
5228 * mv and cp accept a new option: --reply={yes,no,query};  provides a consistent
5229     mechanism to control whether one is prompted about certain existing
5230     destination files.  Note that cp's and mv's -f options don't have the
5231     same meaning: cp's -f option no longer merely turns off '-i'.
5232 * remove portability limitations (e.g., PATH_MAX on the Hurd, fixes for
5233     64-bit systems)
5234 * mv now prompts before overwriting an existing, unwritable destination file
5235     when stdin is a tty, unless --force (-f) is specified, as per POSIX.
5236 * mv: fix the bug whereby 'mv -uf source dest' would delete source,
5237     even though it's older than dest.
5238 * chown's --from=CURRENT_OWNER:CURRENT_GROUP option now works
5239 * cp now ensures that the set-user-ID and set-group-ID bits are cleared for
5240     the destination file when when copying and not preserving permissions.
5241 * 'ln -f --backup k k' gives a clearer diagnostic
5242 * ls no longer truncates user names or group names that are longer
5243     than 8 characters.
5244 * ls's new --dereference-command-line option causes it to dereference
5245   symbolic links on the command-line only.  It is the default unless
5246   one of the -d, -F, or -l options are given.
5247 * ls -H now means the same as ls --dereference-command-line, as per POSIX.
5248 * ls -g now acts like ls -l, except it does not display owner, as per POSIX.
5249 * ls -n now implies -l, as per POSIX.
5250 * ls can now display dates and times in one of four time styles:
5252   - The 'full-iso' time style gives full ISO-style timestamps like
5253     '2001-05-14 23:45:56.477817180 -0700'.
5254   - The 'iso' time style gives ISO-style timestamps like '2001-05-14 '
5255     and '05-14 23:45'.
5256   - The 'locale' time style gives locale-dependent timestamps like
5257     'touko  14  2001' and 'touko  14 23:45' (in a Finnish locale).
5258   - The 'posix-iso' time style gives traditional POSIX-locale
5259     timestamps like 'May 14  2001' and 'May 14 23:45' unless the user
5260     specifies a non-POSIX locale, in which case it uses ISO-style dates.
5261     This is the default.
5263   You can specify a time style with an option like --time-style='iso'
5264   or with an environment variable like TIME_STYLE='iso'.  GNU Emacs 21
5265   and later can parse ISO dates, but older Emacs versions cannot, so
5266   if you are using an older version of Emacs outside the default POSIX
5267   locale, you may need to set TIME_STYLE="locale".
5269 * --full-time is now an alias for "-l --time-style=full-iso".
5272 ========================================================================
5273 Here are the NEWS entries made from sh-utils-2.0 until the
5274 point at which the packages merged to form the coreutils:
5276  [2.0.15]
5277 * date no longer accepts e.g., September 31 in the MMDDhhmm syntax
5278 * fix a bug in this package's .m4 files and in configure.ac
5279  [2.0.14]
5280 * nohup's behavior is changed as follows, to conform to POSIX 1003.1-2001:
5281   - nohup no longer adjusts scheduling priority; use "nice" for that.
5282   - nohup now redirects stderr to stdout, if stderr is not a terminal.
5283   - nohup exit status is now 126 if command was found but not invoked,
5284     127 if nohup failed or if command was not found.
5285  [2.0.13]
5286 * uname and uptime work better on *BSD systems
5287 * pathchk now exits nonzero for a path with a directory component
5288     that specifies a non-directory
5289  [2.0.12]
5290 * kill: new program
5291 * who accepts new options: --all (-a), --boot (-b), --dead (-d), --login,
5292    --process (-p), --runlevel (-r), --short (-s), --time (-t), --users (-u).
5293    The -u option now produces POSIX-specified results and is the same as
5294    the long option '--users'.  --idle is no longer the same as -u.
5295 * The following changes apply on systems conforming to POSIX 1003.1-2001:
5296    - 'date -I' is no longer supported.  Instead, use 'date --iso-8601'.
5297    - 'nice -NUM' is no longer supported.  Instead, use 'nice -n NUM'.
5298   [This change was reverted in coreutils 5.3.1.]
5299 * New 'uname' options -i or --hardware-platform, and -o or --operating-system.
5300    'uname -a' now outputs -i and -o information at the end.
5301    New uname option --kernel-version is an alias for -v.
5302    Uname option --release has been renamed to --kernel-release,
5303    and --sysname has been renamed to --kernel-name;
5304    the old options will work for a while, but are no longer documented.
5305 * 'expr' now uses the LC_COLLATE locale for string comparison, as per POSIX.
5306 * 'expr' now requires '+' rather than 'quote' to quote tokens;
5307     this removes an incompatibility with POSIX.
5308 * date -d 'last friday' would print a date/time that was one hour off
5309     (e.g., 23:00 on *thursday* rather than 00:00 of the preceding friday)
5310     when run such that the current time and the target date/time fall on
5311     opposite sides of a daylight savings time transition.
5312     This problem arose only with relative date strings like 'last monday'.
5313     It was not a problem with strings that include absolute dates.
5314 * factor is twice as fast, for large numbers
5315  [2.0.11]
5316 * setting the date now works properly, even when using -u
5317 * 'date -f - < /dev/null' no longer dumps core
5318 * some DOS/Windows portability changes
5319  [2.0j]
5320 * 'date -d DATE' now parses certain relative DATEs correctly
5321  [2.0i]
5322 * fixed a bug introduced in 2.0h that made many programs fail with a
5323  'write error' when invoked with the --version option
5324  [2.0h]
5325 * all programs fail when printing --help or --version output to a full device
5326 * printf exits nonzero upon write failure
5327 * yes now detects and terminates upon write failure
5328 * date --rfc-822 now always emits day and month names from the 'C' locale
5329 * portability tweaks for Solaris8, Ultrix, and DOS
5330  [2.0g]
5331 * date now handles two-digit years with leading zeros correctly.
5332 * printf interprets unicode, \uNNNN \UNNNNNNNN, on systems with the
5333   required support;  from Bruno Haible.
5334 * stty's rprnt attribute now works on HPUX 10.20
5335 * seq's --equal-width option works more portably
5336  [2.0f]
5337 * fix build problems with ut_name vs. ut_user
5338  [2.0e]
5339 * stty: fix long-standing bug that caused test failures on at least HPUX
5340   systems when COLUMNS was set to zero
5341 * still more portability fixes
5342 * unified lib/: now that directory and most of the configuration framework
5343   is common between fileutils, textutils, and sh-utils
5344  [2.0d]
5345 * fix portability problem with sleep vs lib/strtod.c's requirement for -lm
5346  [2.0c]
5347 * fix portability problems with nanosleep.c and with the new code in sleep.c
5348  [2.0b]
5349 * Regenerate lib/Makefile.in so that nanosleep.c is distributed.
5350  [2.0a]
5351 * sleep accepts floating point arguments on command line
5352 * sleep's clock continues counting down when sleep is suspended
5353 * when a suspended sleep process is resumed, it continues sleeping if
5354   there is any time remaining
5355 * who once again prints whatever host information it has, even without --lookup
5357 ========================================================================
5358 For older NEWS entries for the fileutils, textutils, and sh-utils
5359 packages, see ./old/*/NEWS.
5361   This package began as the union of the following:
5362   textutils-2.1, fileutils-4.1.11, sh-utils-2.0.15.
5364 ========================================================================
5366 Copyright (C) 2001-2022 Free Software Foundation, Inc.
5368 Permission is granted to copy, distribute and/or modify this document
5369 under the terms of the GNU Free Documentation License, Version 1.3 or
5370 any later version published by the Free Software Foundation; with no
5371 Invariant Sections, with no Front-Cover Texts, and with no Back-Cover
5372 Texts.  A copy of the license is included in the "GNU Free
5373 Documentation License" file as part of this distribution.