libbb: match_fstype() is unreadable in the extreme, fixing it
authorDenys Vlasenko <vda.linux@googlemail.com>
Sun, 29 Jan 2017 23:45:05 +0000 (00:45 +0100)
committerDenys Vlasenko <vda.linux@googlemail.com>
Sun, 29 Jan 2017 23:45:05 +0000 (00:45 +0100)
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
include/libbb.h
libbb/match_fstype.c
util-linux/mount.c
util-linux/umount.c

index 07fe20daccfdead2a584b3f39a5ab6b2855b57e9..b054e055907fe383e5788a5721a9fda7059b514a 100644 (file)
@@ -1312,8 +1312,8 @@ const struct hwtype *get_hwtype(const char *name) FAST_FUNC;
 const struct hwtype *get_hwntype(int type) FAST_FUNC;
 
 
+extern int fstype_matches(const char *fstype, const char *comma_list) FAST_FUNC;
 #ifdef HAVE_MNTENT_H
-extern int match_fstype(const struct mntent *mt, const char *fstypes) FAST_FUNC;
 extern struct mntent *find_mount_point(const char *name, int subdir_too) FAST_FUNC;
 #endif
 extern void erase_mtab(const char * name) FAST_FUNC;
index b066b421177505ef5da819596dea30d8db994a6d..6046bc6db882a822bcf986243d6077b5302c3d44 100644 (file)
 
 #include "libbb.h"
 
-#ifdef HAVE_MNTENT_H
-
-int FAST_FUNC match_fstype(const struct mntent *mt, const char *t_fstype)
+int FAST_FUNC fstype_matches(const char *fstype, const char *comma_list)
 {
        int match = 1;
 
-       if (!t_fstype)
+       if (!comma_list)
                return match;
 
-       if (t_fstype[0] == 'n' && t_fstype[1] == 'o') {
+       if (comma_list[0] == 'n' && comma_list[1] == 'o') {
                match--;
-               t_fstype += 2;
+               comma_list += 2;
        }
 
        while (1) {
-               char *after_mnt_type = is_prefixed_with(t_fstype, mt->mnt_type);
+               char *after_mnt_type = is_prefixed_with(comma_list, fstype);
                if (after_mnt_type
                 && (*after_mnt_type == '\0' || *after_mnt_type == ',')
                ) {
                        return match;
                }
-               t_fstype = strchr(t_fstype, ',');
-               if (!t_fstype)
+               comma_list = strchr(comma_list, ',');
+               if (!comma_list)
                        break;
-               t_fstype++;
+               comma_list++;
        }
 
        return !match;
 }
-
-#endif /* HAVE_MNTENT_H */
index 4f5dced1048b0968d92ee14e9ba577bb6bbe5938..f0245f7149266c52e11e42388fdfdf21dd3c6421 100644 (file)
@@ -2312,7 +2312,7 @@ int mount_main(int argc UNUSED_PARAM, char **argv)
                                bb_error_msg_and_die(bb_msg_you_must_be_root);
 
                        // Does type match? (NULL matches always)
-                       if (!match_fstype(mtcur, fstype))
+                       if (!fstype_matches(mtcur->mnt_type, fstype))
                                continue;
 
                        // Skip noauto and swap anyway
index 78eef57a5564bf551b1965a5d82452d0b34c8915..c958fd5524d160f492cf652e976029935c058a6b 100644 (file)
@@ -125,8 +125,8 @@ int umount_main(int argc UNUSED_PARAM, char **argv)
        } else {
                setup_common_bufsiz();
                while (getmntent_r(fp, &me, bb_common_bufsiz1, COMMON_BUFSIZE)) {
-                       /* Match fstype if passed */
-                       if (!match_fstype(&me, fstype))
+                       /* Match fstype (fstype==NULL matches always) */
+                       if (!fstype_matches(me.mnt_type, fstype))
                                continue;
                        m = xzalloc(sizeof(*m));
                        m->next = mtl;