]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
shuf: with -r, don't dump core if the input is empty
authorPaul Eggert <eggert@cs.ucla.edu>
Sun, 23 Feb 2014 23:34:48 +0000 (15:34 -0800)
committerPaul Eggert <eggert@cs.ucla.edu>
Sun, 23 Feb 2014 23:35:27 +0000 (15:35 -0800)
Problem reported by valiant xiao in <http://bugs.gnu.org/16855>.
* NEWS: Document this.
* src/shuf.c (main): With -r, report an error if the input is empty.
* tests/misc/shuf.sh: Test for the bug.

NEWS
src/shuf.c
tests/misc/shuf.sh

diff --git a/NEWS b/NEWS
index e72942b1020cf0ac85d24379f155605bd460add2..2df246d49d4b5a59a50f3594f2768ab86f568c4e 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -22,6 +22,9 @@ GNU coreutils NEWS                                    -*- outline -*-
   it would display an error, requiring --no-dereference to avoid the issue.
   [bug introduced in coreutils-5.3.0]
 
+  shuf -r no longer dumps core if the input is empty.
+  [bug introduced in coreutils-8.22]
+
 ** New features
 
   od accepts a new option: --endian=TYPE to handle inputs with different byte
index d4641fe19ea871596bfceb9ac521dddf09f47c4e..2a910728e97c8e77cd46d79921213445606c9e47 100644 (file)
@@ -576,11 +576,18 @@ main (int argc, char **argv)
   /* Generate output according to requested method */
   if (repeat)
     {
-      if (input_range)
-        i = write_random_numbers (randint_source, head_lines,
-                                  lo_input, hi_input, eolbyte);
+      if (head_lines == 0)
+        i = 0;
       else
-        i = write_random_lines (randint_source, head_lines, line, n_lines);
+        {
+          if (n_lines == 0)
+            error (EXIT_FAILURE, 0, _("No lines to repeat"));
+          if (input_range)
+            i = write_random_numbers (randint_source, head_lines,
+                                      lo_input, hi_input, eolbyte);
+          else
+            i = write_random_lines (randint_source, head_lines, line, n_lines);
+        }
     }
   else
     {
index d3ea1f2ee888670cf031489494144a9f9f42ccb6..d7251d1d6af3505925d7f08d6447c6b493546a95 100755 (executable)
@@ -43,6 +43,10 @@ compare in out1 || { fail=1; echo "not a permutation" 1>&2; }
 t=$(shuf -e a b c d e | sort | fmt)
 test "$t" = 'a b c d e' || { fail=1; echo "not a permutation" 1>&2; }
 
+# coreutils-8.22 dumps core.
+shuf -er
+test $? -eq 1 || fail=1
+
 # Before coreutils-6.3, this would infloop.
 # "seq 1860" produces 8193 (8K + 1) bytes of output.
 seq 1860 | shuf > /dev/null || fail=1