4a59de
From 113d6b31623db33fbea65e586f5bfaf1ea1c8d30 Mon Sep 17 00:00:00 2001
4a59de
From: Kamil Dudka <kdudka@redhat.com>
4a59de
Date: Wed, 11 May 2011 16:46:32 +0200
4a59de
Subject: [PATCH 2/4] findutils-4.4.2-autofs.patch
4a59de
4a59de
---
4a59de
 find/fstype.c |   69 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
4a59de
 1 files changed, 69 insertions(+), 0 deletions(-)
4a59de
4a59de
diff --git a/find/fstype.c b/find/fstype.c
4a59de
index c6dbe8b..9cbf620 100644
4a59de
--- a/find/fstype.c
4a59de
+++ b/find/fstype.c
4a59de
@@ -187,7 +187,72 @@ must_read_fs_list (bool need_fs_type)
4a59de
   return entries;
4a59de
 }
4a59de
 
4a59de
+/* Return the device number from MOUNT_OPTIONS, if possible.
4a59de
+   Otherwise return (dev_t) -1. Taken from 'mountlist' module
4a59de
+   from gnulib.  */
4a59de
+static dev_t
4a59de
+dev_from_mount_options (char const *mount_options)
4a59de
+{
4a59de
+  /* GNU/Linux allows file system implementations to define their own
4a59de
+     meaning for "dev=" mount options, so don't trust the meaning
4a59de
+     here.  */
4a59de
+# ifndef __linux__
4a59de
+
4a59de
+  static char const dev_pattern[] = ",dev=";
4a59de
+  char const *devopt = strstr (mount_options, dev_pattern);
4a59de
+
4a59de
+  if (devopt)
4a59de
+    {
4a59de
+      char const *optval = devopt + sizeof dev_pattern - 1;
4a59de
+      char *optvalend;
4a59de
+      unsigned long int dev;
4a59de
+      errno = 0;
4a59de
+      dev = strtoul (optval, &optvalend, 16);
4a59de
+      if (optval != optvalend
4a59de
+	  && (*optvalend == '\0' || *optvalend == ',')
4a59de
+	  && ! (dev == ULONG_MAX && errno == ERANGE)
4a59de
+	  && dev == (dev_t) dev)
4a59de
+	return dev;
4a59de
+    }
4a59de
 
4a59de
+# endif
4a59de
+  (void) mount_options;
4a59de
+  return -1;
4a59de
+}
4a59de
+
4a59de
+/* Return true if the file described by STATP is on autofs file system
4a59de
+   and call set_fstype_devno () if the autofs file system is matched.  */
4a59de
+static bool
4a59de
+filesystem_check_autofs (const struct stat *statp)
4a59de
+{
4a59de
+  FILE *fp;
4a59de
+  struct mntent *mnt;
4a59de
+  struct mount_entry entry;
4a59de
+  bool match = false;
4a59de
+
4a59de
+  /* open /proc/mounts because autofs is not listed in /etc/mtab */
4a59de
+  fp = setmntent ("/proc/mounts", "r");
4a59de
+  if (fp == NULL)
4a59de
+    return false;
4a59de
+
4a59de
+  while ((mnt = getmntent (fp)))
4a59de
+    {
4a59de
+      if (0 != strcmp ("autofs", mnt->mnt_type))
4a59de
+	  continue;
4a59de
+
4a59de
+      entry.me_mountdir = mnt->mnt_dir;
4a59de
+      entry.me_dev = dev_from_mount_options (mnt->mnt_opts);
4a59de
+      set_fstype_devno (&entry);
4a59de
+      if (entry.me_dev == statp->st_dev)
4a59de
+	{
4a59de
+	  match = true;
4a59de
+	  break;
4a59de
+	}
4a59de
+    }
4a59de
+
4a59de
+  endmntent (fp);
4a59de
+  return match;
4a59de
+}
4a59de
 
4a59de
 /* Return a newly allocated string naming the type of file system that the
4a59de
    file PATH, described by STATP, is on.
4a59de
@@ -238,6 +303,10 @@ file_system_type_uncached (const struct stat *statp, const char *path)
4a59de
     }
4a59de
   free_file_system_list (entries);
4a59de
 
4a59de
+  /* check for autofs */
4a59de
+  if (type == NULL && filesystem_check_autofs (statp))
4a59de
+    type = xstrdup ("autofs");
4a59de
+
4a59de
   /* Don't cache unknown values. */
4a59de
   fstype_known = (type != NULL);
4a59de
 
4a59de
-- 
4a59de
1.7.4.4
4a59de