From 6fa5979ccb0a1bb10af49c6a2cf12afc76ca3459 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Thu, 1 Nov 2001 21:40:01 +0000 Subject: Include dirfd.h. (print_dir): If dirfd fails, resort to using stat. --- src/ls.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/ls.c b/src/ls.c index 0d57cb51c..80db94a58 100644 --- a/src/ls.c +++ b/src/ls.c @@ -108,6 +108,7 @@ int wcwidth (); #include "argmatch.h" #include "dirname.h" +#include "dirfd.h" #include "error.h" #include "hard-locale.h" #include "hash.h" @@ -2036,7 +2037,12 @@ print_dir (const char *name, const char *realname) if (LOOP_DETECT) { struct stat dir_stat; - if (fstat (dirfd (reading), &dir_stat) < 0) + int fd = dirfd (reading); + + /* If dirfd failed, endure the overhead of using stat. */ + if ((0 <= fd + ? fstat (fd, &dir_stat) + : stat (name, &dir_stat)) < 0) { error (0, errno, _("cannot determine device and inode of %s"), quotearg_colon (name)); -- cgit v1.2.3-54-g00ecf