[hackers] [ubase] Don't print errors for already mounted filesystems || sin

From: <git_AT_suckless.org>
Date: Tue, 18 Mar 2014 15:46:39 +0100

commit 6505db4709b30a2ab85e12124e73238ac6ce07a6
Author: sin <sin_AT_2f30.org>
Date: Tue Mar 18 16:38:31 2014 +0200

    Don't print errors for already mounted filesystems

diff --git a/mount.c b/mount.c
index 6e2a6ec..ea33125 100644
--- a/mount.c
+++ b/mount.c
_AT_@ -66,6 +66,29 @@ parseopts(char *popts, unsigned long *flags, char *data, size_t bufsiz)
         }
 }
 
+static int
+mounted(const char *dir)
+{
+ FILE *fp;
+ struct mntent *me;
+ struct stat st1, st2;
+
+ if (stat(dir, &st1) < 0)
+ eprintf("stat %s:", dir);
+ fp = setmntent("/proc/mounts", "r");
+ if (!fp)
+ eprintf("setmntent %s:", "/proc/mounts");
+ while ((me = getmntent(fp)) != NULL) {
+ if (stat(me->mnt_dir, &st2) < 0)
+ eprintf("stat %s:", me->mnt_dir);
+ if (st1.st_dev == st2.st_dev &&
+ st1.st_ino == st2.st_ino)
+ return 1;
+ }
+ endmntent(fp);
+ return 0;
+}
+
 static void
 usage(void)
 {
_AT_@ -172,7 +195,8 @@ mountall:
                 flags = 0;
                 parseopts(me->mnt_opts, &flags, data, datasiz);
                 if(mount(me->mnt_fsname, me->mnt_dir, me->mnt_type, flags, data) < 0) {
- weprintf("mount: %s:", me->mnt_fsname);
+ if (mounted(me->mnt_dir) == 0)
+ weprintf("mount: %s:", me->mnt_fsname);
                         if(status != 64)
                                 status = 32; /* all failed */
                 } else {
Received on Tue Mar 18 2014 - 15:46:39 CET

This archive was generated by hypermail 2.3.0 : Tue Mar 18 2014 - 15:48:14 CET