From: eplanet Date: Wed, 7 Nov 2018 21:39:22 +0000 (+0100) Subject: Read /proc/mounts if /etc/mtab can't be read X-Git-Url: https://git.sur5r.net/?p=i3%2Fi3status;a=commitdiff_plain;h=e5455251481d396f11dc87c734a91a319c44773c Read /proc/mounts if /etc/mtab can't be read --- diff --git a/src/print_disk_info.c b/src/print_disk_info.c index bc43da0..03c95e5 100644 --- a/src/print_disk_info.c +++ b/src/print_disk_info.c @@ -145,15 +145,22 @@ void print_disk_info(yajl_gen json_gen, char *buffer, const char *path, const ch if (strlen(sanitized) > 1 && sanitized[strlen(sanitized) - 1] == '/') sanitized[strlen(sanitized) - 1] = '\0'; FILE *mntentfile = setmntent("/etc/mtab", "r"); - struct mntent *m; + if (mntentfile == NULL) { + mntentfile = setmntent("/proc/mounts", "r"); + } + if (mntentfile == NULL) { + fprintf(stderr, "i3status: files /etc/mtab and /proc/mounts aren't accessible\n"); + } else { + struct mntent *m; - while ((m = getmntent(mntentfile)) != NULL) { - if (strcmp(m->mnt_dir, sanitized) == 0) { - mounted = true; - break; + while ((m = getmntent(mntentfile)) != NULL) { + if (strcmp(m->mnt_dir, sanitized) == 0) { + mounted = true; + break; + } } + endmntent(mntentfile); } - endmntent(mntentfile); free(sanitized); } #endif