summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Eggert <eggert@cs.ucla.edu>2005-08-16 20:33:40 +0000
committerPaul Eggert <eggert@cs.ucla.edu>2005-08-16 20:33:40 +0000
commit7b4c1ac12ac8b08f9537aeb847be4302cad7abbb (patch)
tree4bc450db9f9e115004c8bdc3558af378f4704064
parentc013687ab164a225a747d5aabb561167a73cf5b7 (diff)
downloadcoreutils-7b4c1ac12ac8b08f9537aeb847be4302cad7abbb.tar.xz
(show_dev): New arg STAT_FILE. All uses changed.
This sometimes gives better results on networked file systems that do not respect POSIX semantics. Problem reported by Bruno Haible.
-rw-r--r--src/df.c20
1 files changed, 13 insertions, 7 deletions
diff --git a/src/df.c b/src/df.c
index 03350c5e6..c48f21287 100644
--- a/src/df.c
+++ b/src/df.c
@@ -253,17 +253,22 @@ df_readable (bool negative, uintmax_t n, char *buf,
/* Display a space listing for the disk device with absolute file name DISK.
If MOUNT_POINT is non-NULL, it is the name of the root of the
file system on DISK.
+ If STAT_FILE is non-null, it is the name of a file within the file
+ system that the user originally asked for; this provides better
+ diagnostics, and sometimes it provides better results on networked
+ file systems that give different free-space results depending on
+ where in the file system you probe.
If FSTYPE is non-NULL, it is the type of the file system on DISK.
If MOUNT_POINT is non-NULL, then DISK may be NULL -- certain systems may
not be able to produce statistics in this case.
ME_DUMMY and ME_REMOTE are the mount entry flags. */
static void
-show_dev (const char *disk, const char *mount_point, const char *fstype,
+show_dev (char const *disk, char const *mount_point,
+ char const *stat_file, char const *fstype,
bool me_dummy, bool me_remote)
{
struct fs_usage fsu;
- const char *stat_file;
char buf[3][LONGEST_HUMAN_READABLE + 2];
int width;
int use_width;
@@ -290,7 +295,8 @@ show_dev (const char *disk, const char *mount_point, const char *fstype,
program reports on the file system that the special file is on.
It would be better to report on the unmounted file system,
but statfs doesn't do that on most systems. */
- stat_file = mount_point ? mount_point : disk;
+ if (!stat_file)
+ stat_file = mount_point ? mount_point : disk;
if (get_fs_usage (stat_file, disk, &fsu))
{
@@ -530,7 +536,7 @@ show_disk (char const *disk)
if (best_match)
{
- show_dev (best_match->me_devname, best_match->me_mountdir,
+ show_dev (best_match->me_devname, best_match->me_mountdir, NULL,
best_match->me_type, best_match->me_dummy,
best_match->me_remote);
return true;
@@ -628,7 +634,7 @@ show_point (const char *point, const struct stat *statp)
}
if (best_match)
- show_dev (best_match->me_devname, best_match->me_mountdir,
+ show_dev (best_match->me_devname, best_match->me_mountdir, point,
best_match->me_type, best_match->me_dummy, best_match->me_remote);
else
{
@@ -640,7 +646,7 @@ show_point (const char *point, const struct stat *statp)
char *mp = find_mount_point (point, statp);
if (mp)
{
- show_dev (NULL, mp, NULL, false, false);
+ show_dev (NULL, mp, NULL, NULL, false, false);
free (mp);
}
}
@@ -668,7 +674,7 @@ show_all_entries (void)
struct mount_entry *me;
for (me = mount_list; me; me = me->me_next)
- show_dev (me->me_devname, me->me_mountdir, me->me_type,
+ show_dev (me->me_devname, me->me_mountdir, NULL, me->me_type,
me->me_dummy, me->me_remote);
}