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