Bernhard Fischer provided a mountpoint(1) applet. This is apparently something
authorRob Landley <rob@landley.net>
Sat, 20 Aug 2005 05:07:08 +0000 (05:07 -0000)
committerRob Landley <rob@landley.net>
Sat, 20 Aug 2005 05:07:08 +0000 (05:07 -0000)
sysvinit provides, and which is used by the debian init scripts.

include/applets.h
include/usage.h
miscutils/Config.in
miscutils/Makefile.in
miscutils/mountpoint.c [new file with mode: 0644]

index e2fe25167ded1b37bc56dfc82d6eb338a73547b5..a4e78af575fd8592998e0fef55a0c6e50fd627b4 100644 (file)
 #ifdef CONFIG_MOUNT
        APPLET(mount, mount_main, _BB_DIR_BIN, _BB_SUID_NEVER)
 #endif
+#ifdef CONFIG_MOUNTPOINT
+       APPLET(mountpoint, mountpoint_main, _BB_DIR_BIN, _BB_SUID_NEVER)
+#endif
 #ifdef CONFIG_MSH
        APPLET_NOUSAGE("msh", msh_main, _BB_DIR_BIN, _BB_SUID_NEVER)
 #endif
index dc8058a20a7d172ae2a53ecc69362fe75931ec5f..66222781832dc525251aca445e51432a55052273 100644 (file)
        "$ mount /dev/fd0 /mnt -t msdos -o ro\n" \
        "$ mount /tmp/diskimage /opt -t ext2 -o loop\n"
 
+#define mountpoint_trivial_usage \
+       "[-q] <[-d] DIR | -x DEVICE>"
+#define mountpoint_full_usage \
+       "mountpoint checks if the directory is a mountpoint\n\n" \
+       "Options:\n"  \
+       "\t-q:\t\tBe more quiet\n" \
+       "\t-d:\t\tPrint major/minor device number of the filesystem\n" \
+       "\t-x:\t\tPrint major/minor device number of the blockdevice"
+#define mountpoint_example_usage \
+       "$ mountpoint /proc\n" \
+       "/proc is not a mountpoint\n" \
+       "$ mountpoint /sys\n" \
+       "/sys is a mountpoint\n"
+
 #define mt_trivial_usage \
        "[-f device] opcode value"
 #define mt_full_usage \
index 6c68cd08ed945bf4ee706332041203b92a413351..1f14d212fd39c7f76e2c9ef174cc1bfb5f14a737 100644 (file)
@@ -194,6 +194,12 @@ config CONFIG_FEATURE_MAKEDEVS_TABLE
 
 endchoice
 
+config CONFIG_MOUNTPOINT
+       bool "mountpoint"
+       default n
+       help
+         mountpoint checks if the directory is a mountpoint.
+
 config CONFIG_MT
        bool "mt"
        default n
index 8c53104ed63e5b7897a2d489aad4d72438e66700..ee1cc751989c75be5bcf141a0649721527491490 100644 (file)
@@ -34,6 +34,7 @@ MISCUTILS-$(CONFIG_EJECT)       += eject.o
 MISCUTILS-$(CONFIG_HDPARM)      += hdparm.o
 MISCUTILS-$(CONFIG_LAST)        += last.o
 MISCUTILS-$(CONFIG_MAKEDEVS)    += makedevs.o
+MISCUTILS-$(CONFIG_MOUNTPOINT) += mountpoint.o
 MISCUTILS-$(CONFIG_MT)          += mt.o
 MISCUTILS-$(CONFIG_RX)          += rx.o
 MISCUTILS-$(CONFIG_SETSID)      += setsid.o
diff --git a/miscutils/mountpoint.c b/miscutils/mountpoint.c
new file mode 100644 (file)
index 0000000..46b2d4e
--- /dev/null
@@ -0,0 +1,70 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * mountpoint implementation for busybox
+ *
+ * Copyright (C) 2005 Bernhard Fischer
+ *
+ * Licensed under the GPL v2, see the file LICENSE in this tarball.
+ *
+ * Based on sysvinit's mountpoint
+ */
+
+#include <sys/stat.h>
+#include <errno.h> /* errno */
+#include <string.h> /* strerror */
+#include <getopt.h> /* optind */
+#include "busybox.h"
+
+int mountpoint_main(int argc, char **argv)
+{
+       int opt = bb_getopt_ulflags(argc, argv, "qdx");
+#define OPT_q (1)
+#define OPT_d (2)
+#define OPT_x (4)
+
+       if (optind != argc - 1)
+               bb_show_usage();
+       {
+               char *arg = argv[optind];
+               struct stat st;
+
+               if ( (opt & OPT_x && stat(arg, &st) == 0) || (lstat(arg, &st) == 0) ) {
+                       if (opt & OPT_x) {
+                               if (S_ISBLK(st.st_mode))
+                               {
+                                       bb_printf("%u:%u\n", major(st.st_rdev),
+                                                               minor(st.st_rdev));
+                                       return EXIT_SUCCESS;
+                               } else {
+                                       if (opt & OPT_q)
+                                               putchar('\n');
+                                       else
+                                               bb_error_msg("%s: not a block device", arg);
+                               }
+                               return EXIT_FAILURE;
+                       } else
+                       if (S_ISDIR(st.st_mode)) {
+                               dev_t st_dev = st.st_dev;
+                               ino_t st_ino = st.st_ino;
+                               char *p;
+                               bb_xasprintf(&p, "%s/..", arg);
+                               if (stat(p, &st) == 0) {
+                                       short ret = (st_dev != st.st_dev) ||
+                                               (st_dev == st.st_dev && st_ino == st.st_ino);
+                                       if (opt & OPT_d)
+                                               bb_printf("%u:%u\n", major(st_dev), minor(st_dev));
+                                       else if (!(opt & OPT_q))
+                                               bb_printf("%s is %sa mountpoint\n", arg, ret?"":"not ");
+                                       return !ret;
+                               }
+                       } else {
+                               if (!(opt & OPT_q))
+                                       bb_error_msg("%s: not a directory", arg);
+                               return EXIT_FAILURE;
+                       }
+               }
+               if (!(opt & OPT_q))
+                       bb_perror_msg(arg);
+               return EXIT_FAILURE;
+       }
+}