summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>1999-12-19 10:23:26 +0000
committerJim Meyering <jim@meyering.net>1999-12-19 10:23:26 +0000
commit3d58863d57a3eaf288309f85155a1968d0718aa2 (patch)
treee10c69497476669cece3b0f84f51fab85e284e5f
parenta5959989759307a7acd2321aa807217aae3cd12c (diff)
downloadcoreutils-3d58863d57a3eaf288309f85155a1968d0718aa2.tar.xz
[! LSTAT_FOLLOWS_SLASHED_SYMLINK]: Use lstat wrapper.
[Notice the new test in m4/lstat-slash.m4. ] (main): Back out change from 1999-02-19 that made ls remove trailing slashes from command line arguments to accommodate early versions of Linux. Now, `ls symlink-to-dir/' acts like `ls symlink-to-dir/.' thus following the symbolic link, as POSIX says it should. Suggestion from Bruno Haible and Andreas Schwab.
-rw-r--r--src/ls.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/src/ls.c b/src/ls.c
index f179faebd..692b4483e 100644
--- a/src/ls.c
+++ b/src/ls.c
@@ -143,6 +143,15 @@
# define S_ISDOOR(Mode) 0
#endif
+/* Arrange to make lstat calls go through the wrapper function
+ on systems with an lstat function that does not dereference symlinks
+ that are specified with a trailing slash. */
+#if ! LSTAT_FOLLOWS_SLASHED_SYMLINK
+int rpl_lstat PARAMS((const char *, struct stat *));
+# undef lstat
+# define lstat(Name, Stat_buf) rpl_lstat(Name, Stat_buf)
+#endif
+
enum filetype
{
symbolic_link,
@@ -202,7 +211,6 @@ time_t time ();
char *getgroup ();
char *getuser ();
-void strip_trailing_slashes ();
static size_t quote_name PARAMS ((FILE *out, const char *name,
struct quoting_options const *options));
@@ -796,7 +804,6 @@ main (int argc, char **argv)
dir_defaulted = 0;
for (; i < argc; i++)
{
- strip_trailing_slashes (argv[i]);
gobble_file (argv[i], 1, "");
}