changeset 30257:597f6f4a8c4f

fts.c: sync with similar code from coreutils' remove.c * lib/fts.c (dirent_inode_sort_may_be_useful): Merge from coreutils. Guard also with "#if defined __linux__", since for now at least, this code is Linux-kernel-specific.
author Jim Meyering <meyering@redhat.com>
date Thu, 02 Oct 2008 10:00:46 +0200
parents 56ddb6d579cf
children 303ee2a73955
files ChangeLog lib/fts.c
diffstat 2 files changed, 39 insertions(+), 26 deletions(-) [+]
line wrap: on
line diff
--- a/ChangeLog	Wed Oct 01 13:54:44 2008 +0100
+++ b/ChangeLog	Thu Oct 02 10:00:46 2008 +0200
@@ -1,8 +1,16 @@
+2008-10-02  Jim Meyering  <meyering@redhat.com>
+
+	fts.c: sync with similar code from coreutils' remove.c
+	* lib/fts.c (dirent_inode_sort_may_be_useful): Merge from coreutils.
+	Guard also with "#if defined __linux__", since for now at least,
+	this code is Linux-kernel-specific.
+
 2008-10-02  Jim Meyering  <meyering@redhat.com>
 
 	fts: bug fixes
 	* lib/fts.c: Remove unnecessary "defined" in cpp directive.
 	Include <sys/vfs.h>, not <sys/statfs.h>.
+
 	* m4/fts.m4 (gl_FUNC_FTS_CORE): Fix typo s/vfs/vfs.h/.
 	Include <sys/vfs.h>, not <sys/statfs.h>.
 
--- a/lib/fts.c	Wed Oct 01 13:54:44 2008 +0100
+++ b/lib/fts.c	Thu Oct 02 10:00:46 2008 +0200
@@ -934,29 +934,19 @@
 	return (sp->fts_child);
 }
 
-#if HAVE_SYS_VFS_H && HAVE_FSTATFS && HAVE_STRUCT_STATFS_F_TYPE
-# include <sys/vfs.h>
-/* FIXME: what about when f_type is not an integral type?
-   deal with that if/when it's encountered.  */
-static bool
-fs_handles_readdir_ordered_dirents_efficiently (uintmax_t fs_type)
-{
-/* From coreutils' src/fs.h */
-#define S_MAGIC_TMPFS 0x1021994
-#define S_MAGIC_NFS 0x6969
-  switch (fs_type)
-    {
-    case S_MAGIC_TMPFS:
-    case S_MAGIC_NFS:
-      return true;
-    default:
-      return false;
-    }
-}
+#if defined __linux__ \
+  && HAVE_SYS_VFS_H && HAVE_FSTATFS && HAVE_STRUCT_STATFS_F_TYPE
+
+#include <sys/vfs.h>
 
-/* Return true if it is easy to determine the file system type of the
-   directory on which DIR_FD is open, and sorting dirents on inode numbers
-   is known to improve traversal performance with that type of file system.  */
+/* Linux-specific constants from coreutils' src/fs.h */
+# define S_MAGIC_TMPFS 0x1021994
+# define S_MAGIC_NFS 0x6969
+
+/* Return false if it is easy to determine the file system type of
+   the directory on which DIR_FD is open, and sorting dirents on
+   inode numbers is known not to improve traversal performance with
+   that type of file system.  Otherwise, return true.  */
 static bool
 dirent_inode_sort_may_be_useful (int dir_fd)
 {
@@ -966,12 +956,27 @@
      while the cost of *not* performing it can be O(N^2) with
      a very large constant.  */
   struct statfs fs_buf;
-  bool skip = (fstatfs (dir_fd, &fs_buf) == 0
-	       && fs_handles_readdir_ordered_dirents_efficiently (dir_fd));
-  return !skip;
+
+  /* If fstatfs fails, assume sorting would be useful.  */
+  if (fstatfs (dir_fd, &fs_buf) != 0)
+    return true;
+
+  /* FIXME: what about when f_type is not an integral type?
+     deal with that if/when it's encountered.  */
+  switch (fs_buf.f_type)
+    {
+    case S_MAGIC_TMPFS:
+    case S_MAGIC_NFS:
+      /* On a file system of any of these types, sorting
+	 is unnecessary, and hence wasteful.  */
+      return false;
+
+    default:
+      return true;
+    }
 }
 #else
-static bool dirent_inode_sort_may_be_useful (FTS const *sp) { return true; }
+static bool dirent_inode_sort_may_be_useful (int dir_fd) { return true; }
 #endif
 
 /* A comparison function to sort on increasing inode number.