summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/df.c96
1 files changed, 73 insertions, 23 deletions
diff --git a/src/df.c b/src/df.c
index 35c069d26..88f7d043d 100644
--- a/src/df.c
+++ b/src/df.c
@@ -15,8 +15,8 @@
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
-/* Usage: df [-aikP] [-t fstype] [--all] [--inodes] [--type fstype]
- [--kilobytes] [--portability] [path...]
+/* Usage: df [-aikP] [-t fstype] [-x fstype] [--all] [--inodes]
+ [--type fstype] [--exclude-type fstype] [--kilobytes] [--portability] [path...]
Options:
-a, --all List all filesystems, even zero-size ones.
@@ -24,7 +24,9 @@
-k, --kilobytes Print sizes in 1K blocks instead of 512-byte blocks.
-P, --portability Use the POSIX output format (one line per filesystem).
-t, --type fstype Limit the listing to filesystems of type `fstype'.
- Multiple -t options can be given.
+ -x, --exclude-type fstype
+ Limit the listing to filesystems not of type `fstype'.
+ Multiple -t and/or -x options can be given.
By default, all filesystem types are listed.
Written by David MacKenzie <djm@gnu.ai.mit.edu> */
@@ -41,7 +43,9 @@ char *xmalloc ();
char *xstrdup ();
void error ();
-static int fs_to_list ();
+static int selected_fstype ();
+static int excluded_fstype ();
+static void add_excluded_fs_type ();
static void add_fs_type ();
static void print_header ();
static void show_entry ();
@@ -72,14 +76,14 @@ char *program_name;
/* A filesystem type to display. */
-struct fs_select
+struct fs_type_list
{
char *fs_name;
- struct fs_select *fs_next;
+ struct fs_type_list *fs_next;
};
/* Linked list of filesystem types to display.
- If `fs_list' is NULL, list all types.
+ If `fs_select_list' is NULL, list all types.
This table is generated dynamically from command-line options,
rather than hardcoding into the program what it thinks are the
valid filesystem types; let the user specify any filesystem type
@@ -87,9 +91,14 @@ struct fs_select
will be shown.
Some filesystem types:
- 4.2 4.3 ufs nfs swap ignore io vm */
+ 4.2 4.3 ufs nfs swap ignore io vm efs dbg */
-static struct fs_select *fs_list;
+static struct fs_type_list *fs_select_list;
+
+/* Linked list of filesystem types to omit.
+ If the list is empty, don't exclude any types. */
+
+static struct fs_type_list *fs_exclude_list;
/* Linked list of mounted filesystems. */
static struct mount_entry *mount_list;
@@ -101,6 +110,7 @@ static struct option const long_options[] =
{"kilobytes", no_argument, &kilobyte_blocks, 1},
{"portability", no_argument, &posix_format, 1},
{"type", required_argument, 0, 't'},
+ {"exclude-type", required_argument, 0, 'x'},
{NULL, 0, NULL, 0}
};
@@ -113,14 +123,15 @@ main (argc, argv)
struct stat *stats;
program_name = argv[0];
- fs_list = NULL;
+ fs_select_list = NULL;
+ fs_exclude_list = NULL;
inode_format = 0;
show_all_fs = 0;
kilobyte_blocks = getenv ("POSIXLY_CORRECT") == 0;
posix_format = 0;
exit_status = 0;
- while ((i = getopt_long (argc, argv, "aikPt:v", long_options, (int *) 0))
+ while ((i = getopt_long (argc, argv, "aikPt:vx:", long_options, (int *) 0))
!= EOF)
{
switch (i)
@@ -144,6 +155,9 @@ main (argc, argv)
break;
case 'v': /* For SysV compatibility. */
break;
+ case 'x':
+ add_excluded_fs_type (optarg);
+ break;
default:
usage ();
}
@@ -167,7 +181,10 @@ main (argc, argv)
}
}
- mount_list = read_filesystem_list (fs_list != NULL, show_all_fs);
+ mount_list =
+ read_filesystem_list ((fs_select_list != NULL || fs_exclude_list != NULL),
+ show_all_fs);
+
if (mount_list == NULL)
error (1, errno, "cannot read table of mounted filesystems");
@@ -294,7 +311,7 @@ show_dev (disk, mount_point, fstype)
long inodes_percent_used;
char *stat_file;
- if (!fs_to_list (fstype))
+ if (!selected_fstype (fstype) || excluded_fstype (fstype))
return;
/* If MOUNT_POINT is NULL, then the filesystem is not mounted, and this
@@ -363,37 +380,70 @@ static void
add_fs_type (fstype)
char *fstype;
{
- struct fs_select *fsp;
+ struct fs_type_list *fsp;
+
+ fsp = (struct fs_type_list *) xmalloc (sizeof (struct fs_type_list));
+ fsp->fs_name = fstype;
+ fsp->fs_next = fs_select_list;
+ fs_select_list = fsp;
+}
+
+/* Add FSTYPE to the list of filesystem types to be omitted. */
+
+static void
+add_excluded_fs_type (fstype)
+ char *fstype;
+{
+ struct fs_type_list *fsp;
- fsp = (struct fs_select *) xmalloc (sizeof (struct fs_select));
+ fsp = (struct fs_type_list *) xmalloc (sizeof (struct fs_type_list));
fsp->fs_name = fstype;
- fsp->fs_next = fs_list;
- fs_list = fsp;
+ fsp->fs_next = fs_exclude_list;
+ fs_exclude_list = fsp;
}
/* If FSTYPE is a type of filesystem that should be listed,
return nonzero, else zero. */
static int
-fs_to_list (fstype)
+selected_fstype (fstype)
char *fstype;
{
- struct fs_select *fsp;
+ struct fs_type_list *fsp;
- if (fs_list == NULL || fstype == NULL)
+ if (fs_select_list == NULL || fstype == NULL)
return 1;
- for (fsp = fs_list; fsp; fsp = fsp->fs_next)
+ for (fsp = fs_select_list; fsp; fsp = fsp->fs_next)
if (!strcmp (fstype, fsp->fs_name))
return 1;
return 0;
}
+
+/* If FSTYPE is a type of filesystem that should be omitted,
+ return nonzero, else zero. */
+
+static int
+excluded_fstype (fstype)
+ char *fstype;
+{
+ struct fs_type_list *fsp;
+
+ if (fs_exclude_list == NULL || fstype == NULL)
+ return 0;
+ for (fsp = fs_exclude_list; fsp; fsp = fsp->fs_next)
+ if (!strcmp (fstype, fsp->fs_name))
+ return 1;
+ return 0;
+}
+
static void
usage ()
{
fprintf (stderr, "\
-Usage: %s [-aikPv] [-t fstype] [--all] [--inodes] [--type fstype]\n\
- [--kilobytes] [--portability] [path...]\n",
+Usage: %s [-aikPv] [-t fstype] [-x fstype] [--all] [--inodes]\n\
+\t[--type fstype] [--exclude-type fstype] [--kilobytes] [--portability]\n\
+\t[path...]\n",
program_name);
exit (1);
}