]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
stat: interpret "-" as standard input
authorJim Meyering <meyering@redhat.com>
Tue, 15 Sep 2009 21:07:18 +0000 (23:07 +0200)
committerJim Meyering <meyering@redhat.com>
Tue, 29 Sep 2009 14:04:12 +0000 (16:04 +0200)
* src/stat.c (do_stat): Interpret a command line argument of "-"
to mean "standard input", like many other tools do.
(do_statfs): Fail upon any attempt to use "-".
* NEWS (Changes in behavior): Mention it.
* tests/misc/stat-hyphen: New test, to exercise the above.
* tests/Makefile.am (TESTS): Add misc/stat-hyphen.

NEWS
src/stat.c
tests/Makefile.am
tests/misc/stat-hyphen [new file with mode: 0755]

diff --git a/NEWS b/NEWS
index 075c0fa5a2e566f78942144cbc7577d8a0aabe6d..f1f73472d8eeed258cacdefa6f9a25e9362d71aa 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -48,6 +48,11 @@ GNU coreutils NEWS                                    -*- outline -*-
   GNU/Linux where link(2) creates hard links to symlinks, and -L on
   BSD systems where link(2) follows symlinks.
 
+  stat: without -f, a command-line argument of "-" now means standard input.
+  With --file-system (-f), an argument of "-" is now rejected.
+  If you really must operate on a file named "-", specify it as
+  "./-" or use "--" to separate options from arguments.
+
 ** Improvements
 
   rm: rewrite to use gnulib's fts
index 7d42598f16b92e0f9e521f31d0e834148767f7df..14654b174cd9423c4d2f2a59eca043dedad517d8 100644 (file)
@@ -829,6 +829,13 @@ do_statfs (char const *filename, bool terse, char const *format)
 {
   STRUCT_STATVFS statfsbuf;
 
+  if (STREQ (filename, "-"))
+    {
+      error (0, 0, _("using %s to denote standard input does not work"
+                     " in file system mode"), quote (filename));
+      return false;
+    }
+
   if (STATFS (filename, &statfsbuf) != 0)
     {
       error (0, errno, _("cannot read file system information for %s"),
@@ -857,7 +864,15 @@ do_stat (char const *filename, bool terse, char const *format)
 {
   struct stat statbuf;
 
-  if ((follow_links ? stat : lstat) (filename, &statbuf) != 0)
+  if (STREQ (filename, "-"))
+    {
+      if (fstat (STDIN_FILENO, &statbuf) != 0)
+        {
+          error (0, errno, _("cannot stat standard input"));
+          return false;
+        }
+    }
+  else if ((follow_links ? stat : lstat) (filename, &statbuf) != 0)
     {
       error (0, errno, _("cannot stat %s"), quote (filename));
       return false;
index 2acad6bd6c67f8d20cbe7e2e42a6f66615b8567b..5fd541a4a5051720ed1ec227dfc1cc60202330cd 100644 (file)
@@ -216,6 +216,7 @@ TESTS =                                             \
   misc/split-fail                              \
   misc/split-l                                 \
   misc/stat-fmt                                        \
+  misc/stat-hyphen                             \
   misc/stat-printf                             \
   misc/stdbuf                                  \
   misc/stty                                    \
diff --git a/tests/misc/stat-hyphen b/tests/misc/stat-hyphen
new file mode 100755 (executable)
index 0000000..f0757fe
--- /dev/null
@@ -0,0 +1,35 @@
+#!/bin/sh
+# demonstrate that stat - works and stat -f - does not.
+
+# Copyright (C) 2009 Free Software Foundation, Inc.
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+if test "$VERBOSE" = yes; then
+  set -x
+  stat --version
+fi
+
+. $srcdir/test-lib.sh
+
+printf -- '-\n' > exp || framework_failure
+touch f || framework_failure
+
+fail=0
+stat --format=%n - < f > out || fail=1
+stat -f - < f && fail=1
+
+compare out exp || fail=1
+
+Exit $fail