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