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