diff options
author | Pádraig Brady <P@draigBrady.com> | 2013-12-04 00:50:10 +0000 |
---|---|---|
committer | Pádraig Brady <P@draigBrady.com> | 2013-12-04 13:17:17 +0000 |
commit | 2091f44993c4d0ad16cbe272c247bb452ae74216 (patch) | |
tree | 3fe1e3c3d2d4ef7e1dbd0dc10f9500ced0b27edf | |
parent | 33660b4973baf66423207615bef0d277ca7a5938 (diff) | |
download | coreutils-2091f44993c4d0ad16cbe272c247bb452ae74216.tar.xz |
df: handle bind mounts when processing device nodes
* src/df.c (get_disk): Use the same heuristic used in
get_point() to select the shortest file system mount point,
in an attempt to show the base mounted file system.
* NEWS: Mention the bug fix.
-rw-r--r-- | NEWS | 4 | ||||
-rw-r--r-- | src/df.c | 13 |
2 files changed, 16 insertions, 1 deletions
@@ -12,6 +12,10 @@ GNU coreutils NEWS -*- outline -*- df displayed the symlink's device rather than that for the device node. [This bug was present in "the beginning".] + df now processes disk device nodes correctly in the presence of bind mounts. + Now df shows the base mounted file system rather than the last one mounted. + [This bug was present in "the beginning".] + install now removes the target file if the strip program failed for any reason. Before, that file was left behind, sometimes even with wrong permissions. @@ -1062,10 +1062,21 @@ get_disk (char const *disk) if (resolved && resolved[0] == '/') disk = resolved; + size_t best_match_len = SIZE_MAX; for (me = mount_list; me; me = me->me_next) { if (STREQ (disk, me->me_devname)) - best_match = me; + { + size_t len = strlen (me->me_mountdir); + if (len < best_match_len) + { + best_match = me; + if (len == 1) /* Traditional root. */ + break; + else + best_match_len = len; + } + } } free (resolved); |