commit 78ddef361c0a87e1a76c0ff15e75de63b8954818
parent 7f42fe77c38b4a4b3bf3aed810f51d0bd23f52dd
Author: Hiltjo Posthuma <hiltjo@codemadness.org>
Date: Sun, 10 May 2015 14:16:58 +0200
mountpoint: -q should not print errors
Diffstat:
1 file changed, 20 insertions(+), 5 deletions(-)
diff --git a/mountpoint.c b/mountpoint.c
@@ -42,20 +42,29 @@ main(int argc, char *argv[])
if (argc < 1)
usage();
- if (stat(argv[0], &st1) < 0)
+ if (stat(argv[0], &st1) < 0) {
+ if (qflag)
+ return 1;
eprintf("stat %s:", argv[0]);
+ }
if (xflag) {
- if (!S_ISBLK(st1.st_mode))
+ if (!S_ISBLK(st1.st_mode)) {
+ if (qflag)
+ return 1;
eprintf("stat: %s: not a block device\n",
argv[0]);
+ }
printf("%u:%u\n", major(st1.st_rdev),
minor(st1.st_rdev));
return 0;
}
- if (!S_ISDIR(st1.st_mode))
+ if (!S_ISDIR(st1.st_mode)) {
+ if (qflag)
+ return 1;
eprintf("stat %s: not a directory\n", argv[0]);
+ }
if (dflag) {
printf("%u:%u\n", major(st1.st_dev),
@@ -64,11 +73,17 @@ main(int argc, char *argv[])
}
fp = setmntent("/proc/mounts", "r");
- if (!fp)
+ if (!fp) {
+ if (qflag)
+ return 1;
eprintf("setmntent %s:", "/proc/mounts");
+ }
while ((me = getmntent(fp)) != NULL) {
- if (stat(me->mnt_dir, &st2) < 0)
+ if (stat(me->mnt_dir, &st2) < 0) {
+ if (qflag)
+ return 1;
eprintf("stat %s:", me->mnt_dir);
+ }
if (st1.st_dev == st2.st_dev &&
st1.st_ino == st2.st_ino)
break;