]> git.ipfire.org Git - thirdparty/coreutils.git/log
thirdparty/coreutils.git
5 years agodoc: fix typo in env --split-string documentation
Pádraig Brady [Mon, 27 Jul 2020 12:10:55 +0000 (13:10 +0100)] 
doc: fix typo in env --split-string documentation

* doc/coreutils.texi: Fix grammar.

5 years agodate: clarify the Epoch
Paul Eggert [Fri, 24 Jul 2020 20:33:09 +0000 (13:33 -0700)] 
date: clarify the Epoch

* src/date.c (usage): Mention the Epoch under %s for clarity,
and capitalize.

5 years agodoc: modernize date examples
Paul Eggert [Fri, 24 Jul 2020 20:31:10 +0000 (13:31 -0700)] 
doc: modernize date examples

* doc/coreutils.texi: Use more-modern date examples.
Capitalize “Epoch” to be consistent with POSIX.

5 years agobuild: update gnulib submodule to latest
Paul Eggert [Fri, 24 Jul 2020 19:22:29 +0000 (12:22 -0700)] 
build: update gnulib submodule to latest

* bootstrap.conf (gnulib_modules): Add hash-triple.

5 years agodoc: clarify 'timeout -k' behavior
Bernhard Voelker [Sat, 4 Jul 2020 23:20:10 +0000 (01:20 +0200)] 
doc: clarify 'timeout -k' behavior

* doc/coreutils.texi (timeout invocation): Document that the the
duration of --kill-after=DURATION begins when sending the initial
signal.  Also mention that -k does not have any effect if timeout's
duration is 0.

Suggested by Jonny Grant <jg@jguk.org>.

5 years agofactor: port to --without-libgmp
Paul Eggert [Sun, 19 Jul 2020 01:45:06 +0000 (18:45 -0700)] 
factor: port to --without-libgmp

* src/factor.c (mp_factor_using_division): Use mpz_fdiv_q_2exp
instead of its no-longer-documented mpz_div_2exp alias.
(print_factors): Use mpz_out_str instead of gmp_printf.

5 years agobuild: be less aggressive about -fanalyzer
Paul Eggert [Fri, 10 Jul 2020 22:54:51 +0000 (15:54 -0700)] 
build: be less aggressive about -fanalyzer

* configure.ac: Don’t enable -fanalyzer unless configured with the
new --enable-gcc-warnings=expensive option.  See thread at:
https://lists.gnu.org/r/coreutils/2020-07/msg00011.html

5 years agofactor: explain why non-GMP code (Bug#42269)
Paul Eggert [Thu, 9 Jul 2020 01:58:18 +0000 (18:58 -0700)] 
factor: explain why non-GMP code (Bug#42269)

* doc/coreutils.texi (factor invocation):
* src/factor.c: Explain why the two-word algorithm is useful.

5 years agodoc: mention expr and factor bignums
Paul Eggert [Wed, 8 Jul 2020 15:09:31 +0000 (08:09 -0700)] 
doc: mention expr and factor bignums

* NEWS:
* doc/coreutils.texi (expr invocation, factor invocation):
Mention bignum support on all platforms.  Modernize timings.

5 years agofactor: treat ' +bignum' like non-bignum
Paul Eggert [Wed, 8 Jul 2020 15:05:06 +0000 (08:05 -0700)] 
factor: treat ' +bignum' like non-bignum

* src/factor.c (strto2uintmax): Instead of here ...
(print_factors): ... skip spaces and '+' here, so that
bignums are treated like non-bignums.
* tests/misc/factor.pl (bug-gmp-plus_2_sup_128_plus_1): New test.

5 years agotests: simplify since expr now works on bignums
Paul Eggert [Wed, 8 Jul 2020 14:45:05 +0000 (07:45 -0700)] 
tests: simplify since expr now works on bignums

* cfg.mk (sc_prohibit_expr_unsigned): Remove.
* tests/dd/skip-seek-past-dev.sh (DEV_OFLOW):
* tests/id/setgid.sh (gp1):
* tests/misc/cut-huge-range.sh (CUT_MAX):
* tests/misc/expr.pl:
* tests/misc/sort-discrim.sh:
Assume expr works on bignums.
* tests/misc/cut-huge-range.sh (subtract_one):
Remove; no longer needed.

5 years agofactor: simplify tests by assuming libgmp
Paul Eggert [Wed, 8 Jul 2020 06:48:53 +0000 (23:48 -0700)] 
factor: simplify tests by assuming libgmp

* tests/misc/factor.pl: Test bignums even if !HAVE_GMP.

5 years agomaint: use Gnulib libgmp module
Paul Eggert [Tue, 7 Jul 2020 17:39:10 +0000 (10:39 -0700)] 
maint: use Gnulib libgmp module

This lets use assume multiple-precision arithmetic on all
platforms, simplifying the code.
* bootstrap.conf (gnulib_modules): Add libgmp.
* configure.ac: Don’t call cu_GMP, as this is now done by Gnulib.
* m4/gmp.m4: Remove.
* src/expr.c, src/factor.c: Use gmp.h unconditionally.
* src/factor.c: Use the simpler ‘#ifndef mpz_inits’ to
determine whether there is an mpz_inits macro.

5 years agobuild: update gnulib submodule to latest
Paul Eggert [Tue, 7 Jul 2020 03:35:25 +0000 (20:35 -0700)] 
build: update gnulib submodule to latest

5 years agodoc: add timeout examples
Bernhard Voelker [Fri, 3 Jul 2020 22:19:31 +0000 (00:19 +0200)] 
doc: add timeout examples

* doc/coreutils.texi (timeout invocation): Add examples.

Suggested by Jonny Grant <jg@jguk.org> in
https://lists.gnu.org/r/bug-coreutils/2020-06/msg00018.html

5 years agotests: avoid spurious testsuite failure
Andreas Schwab [Tue, 30 Jun 2020 11:05:55 +0000 (13:05 +0200)] 
tests: avoid spurious testsuite failure

* tests/dd/stats.sh: Increase timeout.
Fixes https://bugs.gnu.org/42135

5 years agotests: fix false failure with valgrind and reflink
Pádraig Brady [Fri, 26 Jun 2020 18:57:09 +0000 (19:57 +0100)] 
tests: fix false failure with valgrind and reflink

* tests/cp/fiemap-FMR.sh: Avoid FICLONE ioctl,
which would avoid the point of the test (fiemap testing).
Also it avoids a valgrind bug with this ioctl:
https://bugs.kde.org/show_bug.cgi?id=397605

5 years agocp: use copy_file_range if available
Paul Eggert [Fri, 26 Jun 2020 00:34:23 +0000 (17:34 -0700)] 
cp: use copy_file_range if available

* NEWS: Mention this.
* bootstrap.conf (gnulib_modules): Add copy-file-range.
* src/copy.c (sparse_copy): Try copy_file_range if not
looking for holes.

5 years agocp: use SEEK_DATA/SEEK_HOLE if available
Paul Eggert [Thu, 25 Jun 2020 23:31:44 +0000 (16:31 -0700)] 
cp: use SEEK_DATA/SEEK_HOLE if available

If it works, prefer lseek with SEEK_DATA and SEEK_HOLE to FIEMAP,
as lseek is simpler and more portable (will be in next POSIX).
Problem reported in 2011 by Jeff Liu (Bug#8061).
* NEWS: Mention this.
* src/copy.c (lseek_copy) [SEEK_HOLE]: New function.
(enum scantype): New constants ERROR_SCANTYPE, LSEEK_SCANTYPE.
(union scan_inference): New type.
(infer_scantype): Last arg is now union scan_inference *,
not struct extent_scan *.  All callers changed.
Prefer SEEK_HOLE to FIEMAP if both work, since
SEEK_HOLE is simpler and more portable.
(copy_reg): Do the fdadvise after initial scan, in case the scan
fails.  Report an error if the initial scan fails.
(copy_reg) [SEEK_HOLE]: Use lseek_copy if scantype says so.

5 years agocp: avoid copy_reg goto
Paul Eggert [Thu, 25 Jun 2020 00:05:20 +0000 (17:05 -0700)] 
cp: avoid copy_reg goto

* src/copy.c (copy_reg): Redo to avoid label and goto.

5 years agocp: refactor extent_copy
Paul Eggert [Wed, 24 Jun 2020 02:18:04 +0000 (19:18 -0700)] 
cp: refactor extent_copy

* src/copy.c (extent_copy): New arg SCAN, replacing
REQUIRE_NORMAL_COPY.  All callers changed.
(enum scantype): New type.
(infer_scantype): Rename from is_probably_sparse and return
the new type.  Add args FD and SCAN.  All callers changed.

5 years agomaint: typo fix
Paul Eggert [Fri, 26 Jun 2020 01:10:49 +0000 (18:10 -0700)] 
maint: typo fix

* NEWS: Fix typo.

5 years agochmod: man page fixes
Paul Eggert [Tue, 23 Jun 2020 15:41:20 +0000 (08:41 -0700)] 
chmod: man page fixes

* man/chmod.x: Mention -6000 too.  Use .BR to fix trailing period.

5 years agodoc: fix punctuation in man pages
Pádraig Brady [Sat, 20 Jun 2020 17:20:04 +0000 (18:20 +0100)] 
doc: fix punctuation in man pages

* man/chmod.x: Add missing punctuation.
* src/expand-common.c: Likewise.
* src/numfmt.c: Likewise.
* src/rm.c: Likewise.

Fixes https://bugs.gnu.org/41962

5 years agostat,tail: add support for the VBOXSF file system
Bernhard Voelker [Fri, 19 Jun 2020 18:33:55 +0000 (20:33 +0200)] 
stat,tail: add support for the VBOXSF file system

* src/stat.c (human_fstype): Add case for the 'vboxsf' file system type
which is used for VirtualBox Shared Folders mounted in VirtualBox guest
VMs.
* NEWS: Mention the Improvement.
Fixes https://bugs.gnu.org/41935

5 years agocp: default to COW
Paul Eggert [Fri, 19 Jun 2020 05:16:24 +0000 (22:16 -0700)] 
cp: default to COW

Likewise for ‘install’.  Proposed in Bug#24400, and long past due.
* NEWS:
* doc/coreutils.texi (cp invocation):
* src/copy.h (enum Reflink_type): Document this.
* src/cp.c (cp_option_init):
* src/install.c (cp_option_init): Implement this.

5 years agomaint: avoid signed integer overflows
Tobias Stoeckmann [Sun, 14 Jun 2020 12:47:11 +0000 (14:47 +0200)] 
maint: avoid signed integer overflows

Since -LONG_MIN results in LONG_MIN again, the operation itself is
a signed integer overflow.

This can be observed with the following calls (best if compiled
with -ftrapv or -fsanitize=undefined):

  $ numfmt --padding=-9223372036854775808
  $ seq 1e-9223372036854775808

Technically, the change in seq "reduces" the precision, but a double
or long double that small would be represented as 0 anyway.

* src/numfmt.c: Explicitly disallow --padding=LONG_MIN.
* src/seq.c: Treat 1e$LONG_MIN as 1e-$LONG_MAX.
* tests/misc/numfmt.pl: Add a test case.
* tests/misc/seq-precision.sh: Likewise.

Fixes https://bugs.gnu.org/41850

5 years agodoc: timeout: improve documentation of the exit status
Bernhard Voelker [Sun, 7 Jun 2020 11:58:14 +0000 (12:58 +0100)] 
doc: timeout: improve documentation of the exit status

* doc/coreutils.texi (timeout invocation): Document that the exit
status is 137 when the KILL signal is used, regardless of whether that
signal is sent to COMMAND or timeout.
* src/timeout.c (usage): Likewise. Also split out and expand
on the possible exit status values to a separate table.

Discussed at https://bugs.gnu.org/41634

5 years agomaint: use getrandom, not getentropy
Paul Eggert [Mon, 1 Jun 2020 22:53:27 +0000 (15:53 -0700)] 
maint: use getrandom, not getentropy

This makes for one Gnulib module less, and at runtime there’s
typically just one getrandom syscall instead of several for large
nonces.
* gl/lib/randread.c: Include sys/random.h instead of sys/time.h
and unistd.h.
(get_nonce): Use getrandom, not getentropy.
* gl/modules/randread (Depends-on):
Depend on getrandom, not getentropy.
* src/shred.c (main):
* src/shuf.c (main):
* src/sort.c (random_md5_state_init):
Say "getrandom" rather than "getentropy" in (unlikely) diagnostic.

5 years agomaint: use getentropy and new tempname modules
Paul Eggert [Mon, 1 Jun 2020 05:21:34 +0000 (22:21 -0700)] 
maint: use getentropy and new tempname modules

Update gnulib submodule to latest and use its new features.
Gnulib’s new getentropy module means coreutils can now assume
getentropy instead of approximating it, badly in some cases.
Gnulib’s improvements to the tempname module mean coreutils no
longer needs to maintain private patches.
* bootstrap.conf (gnulib_modules): Remove gettimeofday.
* gl/lib/randread.c (NAME_OF_NONCE_DEVICE): Remove.
(get_nonce): Return success indicator.  Remove bytes_bound arg.
All callers changed.  Rewrite by using getentropy instead of
reading the nonce device and falling back on gettimeofday.
Fail if getentropy fails.
(randread_new): Return NULL (setting errno) if get_nonce fails.
All callers changed.
* gl/lib/tempname.c.diff, gl/lib/tempname.h.diff:
* gl/modules/tempname.diff: Remove.
* gl/modules/randread (Depends-on):
Depend on getentropy, not gettimeofday.
* src/ptx.c (swallow_file_in_memory):
* src/shuf.c (read_input):
Adjust to read_file changes in Gnulib.
* src/shred.c (main):
* src/shuf.c (main):
* src/sort.c (random_md5_state_init):
Diagnose the new form of randread_new failures: randread_new can
fail now when !random_source, meaning getentropy failed.

5 years agoecho: pacify Oracle Studio 12.6
Paul Eggert [Mon, 1 Jun 2020 05:20:34 +0000 (22:20 -0700)] 
echo: pacify Oracle Studio 12.6

* src/echo.c (main): Don’t assign pointer to bool.
This is well-defined in C99, but is arguably bad style
and Oracle Studio 12.6 complains.

5 years agomaint: copy FDL from gnulib instead of using it as module
Bernhard Voelker [Mon, 25 May 2020 14:31:08 +0000 (16:31 +0200)] 
maint: copy FDL from gnulib instead of using it as module

Since the previous gnulib update, bootstrap outputs this warning:

  Notice from module fdl:
    Don't use this module! Instead, copy the referenced license file \
    into your version control repository.

See gnulib commit:
  https://git.sv.gnu.org/cgit/gnulib.git/commit/?id=88fc5afbccc9

* bootstrap.conf (gnulib_modules): Remove 'fdl'.
* doc/fdl.texi: Add file as a copy of 'gnulib/doc/fdl.texi'.
* doc/.gitignore (/fdl.texi): Remove entry.
* cfg.mk (FILTER_LONG_LINES): Add pattern for the 'fdl.texi' file.

5 years agomaint: fix syntax-check failure from recent adjustment
Bernhard Voelker [Sat, 23 May 2020 01:53:59 +0000 (03:53 +0200)] 
maint: fix syntax-check failure from recent adjustment

* cfg.mk (old_NEWS_hash): Regenerate after commit v8.32-15-g6d0107a37

5 years agotests: fix removed-directory test
Bernhard Voelker [Sat, 23 May 2020 00:46:22 +0000 (02:46 +0200)] 
tests: fix removed-directory test

The previous attempt to skip that test on NFS (commit 4181fc518362)
made the test fail; it introduced two problems:
a) In the good case, i.e., when the subshell returns with exit status 0,
the test ran into framework_failure_.
b) As the subshell also runs with 'set -x', the later comparison of
/dev/null with 'err' would fail.

* tests/ls/removed-directory.sh: Revert to the style without subshell,
and add 'test -d .' to verify that 'ls' can read the removed dir.

5 years agodate: document +%-N change
Paul Eggert [Thu, 21 May 2020 00:31:18 +0000 (17:31 -0700)] 
date: document +%-N change

Suggested by Kamil Dudka in:
https://lists.gnu.org/r/bug-gnulib/2020-05/msg00205.html
* NEWS: Mention the change for coreutils 8.23.
* doc/coreutils.texi (Padding and other flags):
Document it.

5 years agols: port removed-directory test to NFS
Paul Eggert [Thu, 21 May 2020 00:09:03 +0000 (17:09 -0700)] 
ls: port removed-directory test to NFS

* tests/ls/removed-directory.sh:
Port test to NFS, where one gets a stale file handle
when looking at a removed directory.

5 years agodd: omit unnecessary vars when !lint
Paul Eggert [Wed, 20 May 2020 23:47:49 +0000 (16:47 -0700)] 
dd: omit unnecessary vars when !lint

* src/dd.c (real_ibuf, real_obuf) [!lint]:
Remove, as they're needed only when lint checking.
All uses removed when 'lint' is not defined.

5 years agomaint: omit unnecessary pragmas and fix tsort.c
Paul Eggert [Wed, 20 May 2020 23:40:26 +0000 (16:40 -0700)] 
maint: omit unnecessary pragmas and fix tsort.c

* src/chown-core.c, src/comm.c:
* src/tsort.c (record_relation):
Remove GCC 10 pragmas that are not needed in GCC 10.1.0 (the first
public GCC 10 release) and that in some cases cause diagnostics
with GCC 10.1.0.  The tsort.c change fixes a bug that was
inadvertantly introduced when these pragmas were added.

5 years agobuild: update gnulib submodule to latest
Paul Eggert [Wed, 20 May 2020 22:50:38 +0000 (15:50 -0700)] 
build: update gnulib submodule to latest

5 years agomaint: avoid warnings from GCC's -fanalyzer
Pádraig Brady [Sun, 10 May 2020 13:22:06 +0000 (14:22 +0100)] 
maint: avoid warnings from GCC's -fanalyzer

* src/env.c (build_argv): Add an assert() to avoid:
  warning: use of NULL 'n' where non-null expected
  [CWE-690] [-Wanalyzer-null-argument]
  note: argument 1 of 'getenv' must be non-null
* src/dd.c (alloc_ibuf): Don't discard the allocated pointer, to avoid:
  [CWE-401] [-Wanalyzer-malloc-leak]
(alloc_obuf): Likewise.
(cleanup): Deallocate the now tracked buffers which
also avoids "possibly lost" warnings from valgrind.
* src/tsort.c (search_item): Add asserts to avoid:
  [CWE-690] [-Wanalyzer-null-dereference]
(record_relation): An assert doesn't suffice here,
so disable the warning for this function.
* src/comm.c: Suppress the following false positive for the whole file:
  [CWE-457] [-Wanalyzer-use-of-uninitialized-value]
* src/chown-core.c: Suppress the following false positive for the file:
  [CWE-415] [-Wanalyzer-double-free]

5 years agols: allow --classify to be ignored for non tty output
Jason Kim [Sun, 19 Apr 2020 08:40:16 +0000 (01:40 -0700)] 
ls: allow --classify to be ignored for non tty output

Have the `ls` `--classify` option take an optional argument for when to
classify ("always", "auto", "never"), just like the optional argument
for `--color`.  When the optional argument is not specified, default to
"always" for backwards compatibility.

* src/ls.c (usage): Update help text.
(decode_switches): Support an optional argument for --classify.
* tests/ls/classify.sh: Add a new test.
* tests/local.mk: Reference the new test.
* NEWS: Mention the new feature.

5 years agobuild: update gnulib to latest - to avoid du(1) crash on XFS
Bernhard Voelker [Tue, 21 Apr 2020 21:00:43 +0000 (23:00 +0200)] 
build: update gnulib to latest - to avoid du(1) crash on XFS

Pull in a fix for FTS to avoid a crash when traversing a heavily
changed XFS file system:

> fts: remove NOSTAT_LEAF_OPTIMIZATION

* NEWS (Bug fixes): Mention the fix.
* gnulib: Update to latest.
* bootstrap: Sync from gnulib/build-aux/bootstrap.

Discussed at:
<https://lists.gnu.org/r/bug-gnulib/2020-04/msg00068.html>

5 years agomaint: clean up recently added test
Pádraig Brady [Thu, 2 Apr 2020 15:10:05 +0000 (16:10 +0100)] 
maint: clean up recently added test

* tests/misc/uniq-collate.sh: Remove logic that
was already refactored into gen_input().

5 years agocp: ensure --attributes-only doesn't remove files
Pádraig Brady [Wed, 1 Apr 2020 11:51:34 +0000 (12:51 +0100)] 
cp: ensure --attributes-only doesn't remove files

* src/copy.c (copy_internal): Ensure we don't unlink the destination
unless explicitly requested.
* tests/cp/attr-existing.sh: Add test cases.
* NEWS: Mention the bug fix.
Fixes https://bugs.gnu.org/40352

5 years agobuild: update gnulib submodule to latest
Paul Eggert [Sat, 28 Mar 2020 19:16:18 +0000 (12:16 -0700)] 
build: update gnulib submodule to latest

* src/selinux.c: Do not include dosname.h; not needed, since
system.h does that for us via dirname.h.

5 years agomaint: add texi2dvi build directory to doc/.gitignore
Bernhard Voelker [Sun, 15 Mar 2020 10:20:41 +0000 (11:20 +0100)] 
maint: add texi2dvi build directory to doc/.gitignore

* doc/.gitignore (/coreutils.t2p/): Add entry for the build directory
left behind after 'make pdf'.
While at it, sort the file.

5 years agols: improve removed-directory test
Paul Eggert [Sat, 7 Mar 2020 18:29:51 +0000 (10:29 -0800)] 
ls: improve removed-directory test

* tests/ls/removed-directory.sh: Remove host_triplet test.
Skip this test if one cannot remove the working directory.
From a suggestion by Bernhard Voelker (Bug#39929).

5 years agols: restore 8.31 behavior on removed directories
Paul Eggert [Fri, 6 Mar 2020 01:25:29 +0000 (17:25 -0800)] 
ls: restore 8.31 behavior on removed directories

* NEWS: Mention this.
* src/ls.c: Do not include <sys/sycall.h>
(print_dir): Don't worry about whether the directory is removed.
* tests/ls/removed-directory.sh: Adjust to match new (i.e., old)
behavior.

5 years agomaint: post-release administrivia
Pádraig Brady [Thu, 5 Mar 2020 14:04:42 +0000 (14:04 +0000)] 
maint: post-release administrivia

* NEWS: Add header line for next release.
* .prev-version: Record previous version.
* cfg.mk (old_NEWS_hash): Auto-update.

5 years agoversion 8.32 v8.32
Pádraig Brady [Thu, 5 Mar 2020 13:23:50 +0000 (13:23 +0000)] 
version 8.32

* NEWS: Record release date.

5 years agotests: don't rely on system env(1) being present
Pádraig Brady [Wed, 4 Mar 2020 15:56:52 +0000 (15:56 +0000)] 
tests: don't rely on system env(1) being present

* tests/misc/env-S.pl: `env -i env` will call the system env
due to the path being cleared, so pass the absolute path
of our env binary under test to avoid that.  This was seen
to be an issue on Guix where /usr/bin/env was not available.

5 years agobasenc: avoid undefined behaviour in z85 processing
Pádraig Brady [Wed, 4 Mar 2020 12:24:49 +0000 (12:24 +0000)] 
basenc: avoid undefined behaviour in z85 processing

* src/basenc.c (z85_decode_ctx_init): Ensure we're working
with unsigned, as otherwise ubsan triggers with:
  src/basenc.c:767:18: runtime error: signed integer overflow:
  43 * 52200625 cannot be represented in type 'int'
(z85_encode): Likewise to avoid the usban error:
  src/basenc.c:630:26: runtime error:
  left shift of 134 by 24 places cannot be represented in type 'int'

5 years agotests: avoid a false failure on OpenIndiana 11
Pádraig Brady [Sun, 1 Mar 2020 22:28:29 +0000 (22:28 +0000)] 
tests: avoid a false failure on OpenIndiana 11

* tests/misc/timeout-parameters.sh: Split the large timeout
handling to ...
* tests/misc/timeout-large-parameters.sh: ... here, so that
the 3 second delay is contained in its own test, and if
the test is skipped due invalid handling within timeout(1),
it will be more apparent.
Also adjust the check so we skip whenever the kernel timer
fires immediately, to handle the buggy OpenIndiana 11 kernel also.
Reported by Bruno Haible.

5 years agotests: avoid a hang on GNU/Hurd from 2019
Pádraig Brady [Sun, 1 Mar 2020 22:03:38 +0000 (22:03 +0000)] 
tests: avoid a hang on GNU/Hurd from 2019

* tests/du/8gb.sh: Add a timeout around:
`dd bs=1 seek=8G of=big < /dev/null`

5 years agotests: use bash in some scripts to avoid false failures
Pádraig Brady [Sun, 1 Mar 2020 21:49:16 +0000 (21:49 +0000)] 
tests: use bash in some scripts to avoid false failures

* init.cfg (require_bash_as_SHELL_): A new function to replace
SHELL for the current test, with bash if available.
This is useful on OpenIndiana 11 where /bin/sh was seen
to have races in handling of SIGPIPE.
* tests/misc/seq-epipe.sh: Use the new function to enforce bash.
* tests/misc/env-signal-handler.sh: Likewise.
Reported by Bruno Haible

5 years agotests: improve test coverage for ls stat checks
Pádraig Brady [Sun, 1 Mar 2020 12:36:35 +0000 (12:36 +0000)] 
tests: improve test coverage for ls stat checks

* tests/ls/stat-free-color.sh: Check for the availability
of various stat calls individually, and add statx() and fstatat64()
to the list to check.  Fix the stat counting logic to
ignore lines like "+++ exited with 0 +++".
* tests/ls/stat-free-symlinks.sh: Check syscalls other than stat().

5 years agotests: enable 4 more tests to be executed on FreeBSD
Bruno Haible [Sun, 1 Mar 2020 02:03:59 +0000 (03:03 +0100)] 
tests: enable 4 more tests to be executed on FreeBSD

* init.cfg (gcc_shared_libs_): New variable.
(gcc_shared_): Use it, instead of hardcoding -ldl.
(require_gcc_shared_): Determine the suitable value
for gcc_shared_libs_.

5 years agotests: fix incorrect `|| fail` pattern in tests
Pádraig Brady [Sat, 29 Feb 2020 20:48:58 +0000 (20:48 +0000)] 
tests: fix incorrect `|| fail` pattern in tests

* tests/ls/stat-free-symlinks.sh: s/|| fail/|| fail=1/.
* tests/misc/tee.sh: Likewise.
* tests/touch/relative.sh: Likewise.
* cfg.mk (sc_prohibit_or_fail): A new syntax-check to avoid this.

5 years agotests: avoid false failures on darwin 19.2.0
Pádraig Brady [Sat, 29 Feb 2020 20:23:44 +0000 (20:23 +0000)] 
tests: avoid false failures on darwin 19.2.0

With these adjustments, all tests pass on macOS Catalina.

* tests/dd/sparse.sh: Adjust so that systems like apfs that
don't create holes < 16 MiB do not fail erroneously.
* tests/touch/trailing-slash.sh: Darwin was seen to dereference
symlinks to files when given a trailing slash, so avoid
that particular case.

5 years agotests: fix test failure on FreeBSD 12
Bruno Haible [Sat, 29 Feb 2020 21:33:04 +0000 (22:33 +0100)] 
tests: fix test failure on FreeBSD 12

* tests/misc/csplit-io-err.sh: Limit the effect of the fwrite
override to streams != stderr, as fwrite is in the error() path there.

5 years agobuild: once again distribute .tar.gz files
Jan Nieuwenhuizen [Thu, 27 Feb 2020 21:40:23 +0000 (21:40 +0000)] 
build: once again distribute .tar.gz files

* configure.ac: Reenable distribution of gzip-compressed
tarballs, for Guix bootstrapping reasons as discussed at:
https://lists.gnu.org/r/coreutils/2020-02/msg00042.html
* THANKS.in: Remove me, as now a committer.
* NEWS (Build-related): Mention this.

5 years agomaint: ensure .deps/ in the project root is ignored by git
Pádraig Brady [Thu, 27 Feb 2020 16:44:03 +0000 (16:44 +0000)] 
maint: ensure .deps/ in the project root is ignored by git

* .gitignore: s|*/.deps/|.deps|

5 years agodoc: remove older ChangeLog items
Pádraig Brady [Thu, 27 Feb 2020 16:11:42 +0000 (16:11 +0000)] 
doc: remove older ChangeLog items

* Makefile.am: Update the oldest documented version
to 8.23 which is now about 5 years old.

5 years agols: issue error message on removed directory
Colin Watson [Tue, 11 Feb 2020 10:45:46 +0000 (10:45 +0000)] 
ls: issue error message on removed directory

If the current directory has been removed, then "ls" confusingly
produced no output and no error message, indistinguishable from
running on an empty directory.

* src/ls.c (print_dir): Report ENOENT on GNU/Linux if readdir
finds no directory entries at all, not even "." or "..",
and a recheck with the getdents syscall returns ENOENT.
We recheck with getdents() as POSIX states that
"The directory entries for dot and dot-dot are optional".
* tests/ls/removed-directory.sh: New file.
* tests/local.mk (all_tests): Add new test.
* NEWS: Mention the change in behavior.
Reported by Owen Thomas.

5 years agobuild: update to latest gnulib
Pádraig Brady [Tue, 25 Feb 2020 13:57:40 +0000 (13:57 +0000)] 
build: update to latest gnulib

* bootstrap.conf: Adjust for changes to fchmodat and fchownat,
which are now separated from chmodat and chownat respectively.

5 years agob2sum: sync better with upstream
Pádraig Brady [Tue, 25 Feb 2020 13:30:39 +0000 (13:30 +0000)] 
b2sum: sync better with upstream

* src/blake2/blake2-impl.h: Sync load16() implementation,
which doesn't change code generation.
Also leverage (builtin) memcpy to more efficiently
move data on little endian systems,
giving a 2% win with GCC 9.2.1 on an i3-2310M.

5 years agofactor: sync longlong.h adjustments from upstream
Pádraig Brady [Tue, 25 Feb 2020 11:33:04 +0000 (11:33 +0000)] 
factor: sync longlong.h adjustments from upstream

* src/longlong.h: Sync changes from:
https://gmplib.org/repo/gmp/log/tip/longlong.h
mips64: Provide r6 asm code as default expression yields.
arm32: Define sub_ddmmss separately for non-thumb (no rsc instruction).
powerpc: Add "CLOBBER" descriptions for some registers.
x86: Fix criterion for when to use mulx in umul_ppmm.

5 years agostat,tail: sync file system constants from the linux kernel
Pádraig Brady [Sun, 9 Feb 2020 14:10:50 +0000 (14:10 +0000)] 
stat,tail: sync file system constants from the linux kernel

* src/stat.c: Add magic constants for "binderfs", "dma-buf-fs",
"erofs", "ppc-cmm-fs", and "z3fold".
* NEWS: Mention the improvement.

5 years agouniq: avoid strcoll() to improve performance and consistency
Pádraig Brady [Sun, 23 Feb 2020 13:20:08 +0000 (13:20 +0000)] 
uniq: avoid strcoll() to improve performance and consistency

strcoll() is only significant to uniq(1) if it returns 0,
and it generally only does so with buggy locales or mismatched
locales and data.  Some systems may have strcoll()
return 0 for equivalent normalized unicode forms,
but for consistency across platforms strcoll() is avoided.
The various cases are defined in the new test.
This is consistent with newer POSIX standards as discussed at:
https://www.austingroupbugs.net/view.php?id=963

* src/uniq.c: s/xstrcoll/memcmp/.
* tests/local.mk: Reference the new test.
* tests/misc/uniq-collate.sh: Add a new test.
* NEWS: Mention the change in behavior.
Fixes https://bugs.gnu.org/38627

5 years agodoc: clarify that '%a' stat format outputs mode bits
Pádraig Brady [Sat, 15 Feb 2020 11:16:35 +0000 (11:16 +0000)] 
doc: clarify that '%a' stat format outputs mode bits

* src/stat.c (usage): Mention permission bits rather than
"access" so there is no confusion with ACLs etc.
Also indicate we output the file type with '%A'.
* doc/coreutils.texi (stat invocation): Likewise.
Also indicate '%A' is similar to `ls -ld` output.
Addresses https://bugs.gnu.org/39613

5 years agotests: fix test for symlink
Pádraig Brady [Mon, 10 Feb 2020 15:05:43 +0000 (15:05 +0000)] 
tests: fix test for symlink

* tests/cp/preserve-gid.sh: s/-l/-L/.
Reported by Kamil Dudka

5 years agotests: ensure tests/cp/preserve-gid.sh works with single binary
Kamil Dudka [Fri, 7 Feb 2020 16:05:06 +0000 (17:05 +0100)] 
tests: ensure tests/cp/preserve-gid.sh works with single binary

* tests/cp/preserve-gid.sh: If configured with --enable-single-binary
copy the coreutils single binary, instead of the cp one-line launcher.

Discussed at https://bugzilla.redhat.com/1800597
Fixes https://bugs.gnu.org/39485

5 years agomaint: avoid syntax-check failure in previous commit
Pádraig Brady [Sun, 9 Feb 2020 14:18:55 +0000 (14:18 +0000)] 
maint: avoid syntax-check failure in previous commit

* configure.ac: Restrict lines to 80 chars.

5 years agobuild: suppress new FP warning from gcc-10.0.1
Jim Meyering [Thu, 6 Feb 2020 17:00:26 +0000 (09:00 -0800)] 
build: suppress new FP warning from gcc-10.0.1

* configure.ac (GNULIB_WARN_CFLAGS): Add -Wno-return-local-addr
to avoid FP warning about careadlinkat.c. Discussed starting in
https://lists.gnu.org/r/coreutils/2020-02/msg00006.html

5 years agobuild: update to latest gnulib
Pádraig Brady [Sun, 2 Feb 2020 16:56:18 +0000 (16:56 +0000)] 
build: update to latest gnulib

Pick up recent build fixes to avoid sysctl.h inclusion on glibc systems,
restrict the max file size supported by read-file to PTRDIFF_MAX,
and to avoid a -Werror=unused failure in test-canonicalize.

5 years agotests: avoid false failure due to varying /proc/kallsyms
Pádraig Brady [Tue, 4 Feb 2020 00:37:23 +0000 (00:37 +0000)] 
tests: avoid false failure due to varying /proc/kallsyms

* tests/cp/proc-short-read.sh: Switch to using /proc/cpuinfo,
rather than /proc/kallsyms which was seen to vary in some cases.
Fixes https://bugs.gnu.org/39357

5 years agormdir: fix --ignore-fail-on-non-empty with permissions errors
Pádraig Brady [Fri, 31 Jan 2020 01:46:40 +0000 (20:46 -0500)] 
rmdir: fix --ignore-fail-on-non-empty with permissions errors

Since v6.10-21-ged5c4e7 `rmdir --ignore-fail-on-non-empty`
had reversed the failure status for directories that failed
to be removed for permissions reasons.  I.E. it would have
returned a failure status for such non empty dirs, and vice versa.

* src/rmdir.c (errno_may_be_non_empty): Rename from the
more confusing errno_may_be_empty(), and remove the EEXIST
case (specific to Solaris), which is moot here since
handled in errno_rmdir_non_empty().
(ignorable_failure): Fix the logic error so that
_non_ empty dirs are deemed to have ignorable failures.
(main): Fix clobbering of errno by is_empty_dir().
(remove_parents): Likewise.
* tests/rmdir/ignore.sh: Add a test case.
* THANKS.in: Add reporter who fixed the errno handling.
* NEWS: Mention the bug fix.
Fixes https://bugs.gnu.org/39364

5 years agobuild: avoid vector performance warnings in randperm
Pádraig Brady [Sun, 2 Feb 2020 16:24:18 +0000 (16:24 +0000)] 
build: avoid vector performance warnings in randperm

* configure.ac: Add -Wno-vector-operation-performance to suppress the
following gcc-9.2 error in gl/lib/randperm.c:
  error: vector operation will be expanded piecewise

5 years agobuild: avoid including sysctl.h on glibc
Pádraig Brady [Sun, 2 Feb 2020 15:52:59 +0000 (15:52 +0000)] 
build: avoid including sysctl.h on glibc

* src/uname.c: Avoid unneeded header with GLIBC,
which has been deprecated since glibc-2.30.
* src/uptime.c: Likewise.

5 years agols: support --time=creation to show/sort birth time
Pádraig Brady [Thu, 2 Jan 2020 16:20:13 +0000 (16:20 +0000)] 
ls: support --time=creation to show/sort birth time

* src/ls.c (usage): Reorganize help for --time,
and add description for --time=birth.
(do_statx): Store btime in mtime if available.
(get_stat_btime): A new function to read the creation time
from the appropriate stat structure member.
(cmp_btime): A new function to compare birth time.
(print_long_format): Output '?' when birth time unavailable.
* doc/coreutils.texi: Document --time={birth,creation}.
* tests/local.mk: Reference the new test.
* tests/ls/birthtime.sh: Add a new test.
* NEWS: Mention the new feature.

5 years agobuild: rearrange yes(1) code to prevent GCC 10 warning
Chris Meyering [Thu, 30 Jan 2020 06:34:48 +0000 (22:34 -0800)] 
build: rearrange yes(1) code to prevent GCC 10 warning

* src/yes.c (main): Convert for loop to do-while in order to indicate
that the loop will be run at least once.
This avoids the following warning after the second loop:
src/yes.c:110:20: error: writing 1 byte into a region of size 0

5 years agomaint: add lib/iconv_open-zos.h to .gitignore
Emil Engler [Wed, 1 Jan 2020 22:59:33 +0000 (23:59 +0100)] 
maint: add lib/iconv_open-zos.h to .gitignore

* .gitignore: Add file newly generated by gnulib commit 49e78fc

5 years agobuild: auto enable use of openssl with >= version 3
Pádraig Brady [Wed, 1 Jan 2020 17:43:53 +0000 (17:43 +0000)] 
build: auto enable use of openssl with >= version 3

* configure.ac: Set --with-openssl=auto-gpl-compat as the default,
so that openssl is used for md5sum etc., with openssl >= 3,
which is newly licensed under ASL v2.
* gnulib: Update to include "auto-gpl-compat" support.

5 years agomaint: adjust to split out xstrtol-error gnulib module
Pádraig Brady [Wed, 1 Jan 2020 14:36:12 +0000 (14:36 +0000)] 
maint: adjust to split out xstrtol-error gnulib module

* bootstrap.conf: Depend on the new module split from xstrtol.
* src/df.c: Include "xstrtol-error.h" for xstrtol_fatal.
* src/du.c: Likewise.
* src/ls.c: Likewise.
* src/od.c: Likewise.
* src/pr.c: Likewise.
* src/sort.c: Likewise.

5 years agomaint: update all copyright year number ranges
Pádraig Brady [Wed, 1 Jan 2020 14:16:56 +0000 (14:16 +0000)] 
maint: update all copyright year number ranges

Run "make update-copyright" and then...

* gnulib: Update to latest with copyright year adjusted.
* tests/init.sh: Sync with gnulib to pick up copyright year.
* bootstrap: Likewise.
* tests/sample-test: Adjust to use the single most recent year.

5 years agodoc: add example to demonstrate sub-second sleep times
Bernhard Voelker [Sun, 8 Dec 2019 16:29:57 +0000 (17:29 +0100)] 
doc: add example to demonstrate sub-second sleep times

* doc/coreutils.texi (sleep invocation): Add an example to demonstrate
how to use the floating-point and the scientific notation to sleep
for sub-second times, e.g. milli-, micro- and nanoseconds.

Inspired by Stephane Chazelas in:
  https://lists.gnu.org/r/coreutils/2019-12/msg00005.html

5 years agomaint: fix syntax-check failure from recent adjustment
Pádraig Brady [Mon, 2 Dec 2019 16:17:45 +0000 (16:17 +0000)] 
maint: fix syntax-check failure from recent adjustment

* cfg.mk (old_NEWS_hash): Regenerate after commit v8.31-56-gc1e1965.

5 years agochcon: do not validate security context if SELinux is disabled
Kamil Dudka [Mon, 2 Dec 2019 13:02:02 +0000 (14:02 +0100)] 
chcon: do not validate security context if SELinux is disabled

* src/chcon.c (main): Skip call of security_check_context()
in case SELinux is disabled to avoid unnecessary failure.

Bug: https://bugzilla.redhat.com/1777831

5 years agodoc: remove colon from node name
Paul Eggert [Tue, 12 Nov 2019 00:53:49 +0000 (16:53 -0800)] 
doc: remove colon from node name

* doc/sort-version.texi (Minus/Hyphen and Colon characters):
Rename from “Minus/Hyphen @samp{-} and Colon @samp{:} characters”,
as texi2any 6.6 complains about colons in node names.

5 years agoshred: modernize documentation
Paul Eggert [Tue, 12 Nov 2019 00:52:47 +0000 (16:52 -0800)] 
shred: modernize documentation

* doc/coreutils.texi (shred invocation):
Modernize discussion to today’s technology (Bug#38168).
* src/shred.c (usage): Omit lengthy duplication of the manual’s
discussion of file systems and storage devices, as that became out
of sync with the manual.  Instead, just cite the manual.

6 years agoall: improve parsing of numeric arguments
Paul Eggert [Tue, 22 Oct 2019 21:55:24 +0000 (14:55 -0700)] 
all: improve parsing of numeric arguments

This addresses a longstanding "update all callers" FIXME in
lib/xstrtol.c, by having programs check that numbers do not
have unknown suffixes.  The problem was also reported for
'shuf' by my student Maggie Huang while reimplementing a shuf
subset in Python as an exercise in UCLA Computer Science 35L:
https://web.cs.ucla.edu/classes/fall19/cs35L/assign/assign3.html
This patch also improves the portability of the code to unusual
platforms where ULONG_MAX < SIZE_MAX.
* NEWS: Mention user-visible changes.
* src/chgrp.c (parse_group):
* src/chroot.c (parse_additional_groups):
* src/du.c (main):
* src/install.c (get_ids):
* src/join.c (string_to_join_field):
* src/ls.c (decode_switches):
* src/md5sum.c (split_3):
* src/shuf.c (main):
* src/sort.c (specify_nthreads):
* src/uniq.c (size_opt, main):
Use uintmax_t instead of unsigned long, for portability
to oddball platforms where unsigned long is not wide enough.
* src/du.c (main):
* src/expr.c (mpz_init_set_str) [!HAVE_GMP]:
* src/install.c (get_ids):
* src/ls.c (decode_switches):
* src/mknod.c (main):
* src/ptx.c (main):
* src/shuf.c (main):
* src/sort.c (specify_nmerge, specify_nthreads):
Reject numbers with suffixes.
* src/md5sum.c (split_3): Simplify.

6 years agostdbuf: improve size checking
Paul Eggert [Tue, 22 Oct 2019 21:31:52 +0000 (14:31 -0700)] 
stdbuf: improve size checking

* bootstrap.conf (gnulib_modules): Add minmax.
* src/libstdbuf.c: Include stdint.h, minmax.h.
(apply_mode): Don’t assume SIZE_MAX <= ULONG_MAX.
Improve checking for invalid sizes.

6 years agoshuf: improve randperm overflow checking
Paul Eggert [Tue, 22 Oct 2019 19:58:07 +0000 (12:58 -0700)] 
shuf: improve randperm overflow checking

* gl/lib/randperm.c: Include randperm.h first, since it’s the API.
Include stdint.h, count-leading-zeros.h, verify.h.
(floor_lg): Rename from ceil_log (which was not actually
implementing the ceiling!) and implement the floor using
count_leading_zeros.
(randperm_bound): Use floor_lg, not ceil_log.  Use uintmax_t
instead of size_t in case the size gets large on a 32-bit host.
* gl/modules/randperm (Depends-on): Add count-leading-zeros, stdint.

6 years agobuild: don’t worry about logical-op checking
Paul Eggert [Tue, 22 Oct 2019 19:52:52 +0000 (12:52 -0700)] 
build: don’t worry about logical-op checking

* configure.ac: Remove code tailoring --enable-gcc-warnings
to GCC 4.7 and earlier, as developers no longer need to worry
about GCCs that old.

6 years agobuild: re-enable type-limits checking
Paul Eggert [Tue, 22 Oct 2019 18:34:56 +0000 (11:34 -0700)] 
build: re-enable type-limits checking

* configure.ac: When --enable-gcc-warnings is used, omit
-Wno-type-limits.  The need for -Wno-type-limits has passed, now
that intprops.h uses builtin primitives for GCC 5 and later, given
that recent GCCs issue type-limits warnings only for non-constant
expressions.  --enable-gcc-warnings is not intended for use with
old compilers, so we can drop -Wno-type-limits now.

6 years agoshuf: fix bug with ‘-r -n 0’
Paul Eggert [Mon, 21 Oct 2019 20:03:46 +0000 (13:03 -0700)] 
shuf: fix bug with ‘-r -n 0’

‘shuf -r -n 0 file’ would mistakenly read from standard input.
Problem reported by my student Jingnong Qu while reimplementing a
shuf subset in Python as an exercise in UCLA Computer Science 35L:
https://web.cs.ucla.edu/classes/fall19/cs35L/assign/assign3.html
* NEWS: Mention the fix.  Also, ASCIIfy a previous item.
* src/shuf.c (main): Fix bug.
* tests/misc/shuf.sh: Add a test case for the bug.

6 years agols: use statx instead of stat when available
Jeff Layton [Thu, 19 Sep 2019 15:59:45 +0000 (11:59 -0400)] 
ls: use statx instead of stat when available

statx allows ls to indicate interest in only certain inode metadata.
This is potentially a win on networked/clustered/distributed
file systems. In cases where we'd have to do a full, heavyweight stat()
call we can now do a much lighter statx() call.

As a real-world example, consider a file system like CephFS where one
client is actively writing to a file and another client does an
ls --color in the same directory. --color means that we need to fetch
the mode of the file.

Doing that with a stat() call means that we have to fetch the size and
mtime in addition to the mode. The MDS in that situation will have to
revoke caps in order to ensure that it has up-to-date values to report,
which disrupts the writer.

This has a measurable affect on performance. I ran a fio sequential
write test on one cephfs client and had a second client do "ls --color"
in a tight loop on the directory that held the file:

Baseline -- no activity on the second client:

WRITE: bw=76.7MiB/s (80.4MB/s), 76.7MiB/s-76.7MiB/s (80.4MB/s-80.4MB/s),
       io=4600MiB (4824MB), run=60016-60016msec

Without this patch series, we see a noticable performance hit:

WRITE: bw=70.4MiB/s (73.9MB/s), 70.4MiB/s-70.4MiB/s (73.9MB/s-73.9MB/s),
       io=4228MiB (4433MB), run=60012-60012msec

With this patch series, we gain most of that ground back:

WRITE: bw=75.9MiB/s (79.6MB/s), 75.9MiB/s-75.9MiB/s (79.6MB/s-79.6MB/s),
       io=4555MiB (4776MB), run=60019-60019msec

* src/stat.c: move statx to stat struct conversion to new header...
* src/statx.h: ...here.
* src/ls.c: Add wrapper functions for stat/lstat/fstat calls,
and add variants for when we are only interested in specific info.
Add statx-enabled functions and set the request mask based on the
output format and what values are needed.
* NEWS: Mention the Improvement.

6 years agotruncate: avoid integer-overflow assumptions
Paul Eggert [Thu, 3 Oct 2019 19:41:22 +0000 (12:41 -0700)] 
truncate: avoid integer-overflow assumptions

* src/truncate.c (do_ftruncate): Simplify overflow checking,
and don’t rely on theoretically-nonportable assumptions
like assuming that OFF_MAX < UINTMAX_MAX.

6 years agonumfmt: avoid unlikely integer overflow
Paul Eggert [Thu, 3 Oct 2019 19:38:15 +0000 (12:38 -0700)] 
numfmt: avoid unlikely integer overflow

* src/numfmt.c (parse_format_string): Report overflow if
pad < -LONG_MAX, since that can’t be negated.

6 years agonl: fix integer-overflow bug
Paul Eggert [Thu, 3 Oct 2019 19:37:12 +0000 (12:37 -0700)] 
nl: fix integer-overflow bug

Problem reported by Roland Illig (Bug#37585)
* src/nl.c (print_lineno): Don’t rely on undefined behavior when
checking for integer overflow.