commit 62f40164309cd6f22be9fae89c071221944618e4
parent c2808b6d99f30e30b059906e7801cc8a2b76189f
Author: parazyd <parazyd@dyne.org>
Date: Fri, 30 Dec 2016 12:16:07 +0100
add vol_perc notes, add braces to singleline statements
Diffstat:
3 files changed, 19 insertions(+), 5 deletions(-)
diff --git a/README.md b/README.md
@@ -50,6 +50,16 @@ If you use any other status bar or window manager you will have to figure it out
slstatus -o | other_status_bar &
+### Specific function quirks
+
+- Volume percentage
+
+If there is no `/dev/mixer` on your system and you use ALSA, it means you have to load the OSS compatibility module by issuing:
+
+```
+# modprobe snd-pcm-oss
+```
+
## Contributing
Hunt FIXME's in the code or do WTF you want! If it is useful, I will merge.
diff --git a/config.def.h b/config.def.h
@@ -34,7 +34,7 @@
- uid (uid of current user) [argument: NULL]
- uptime (uptime) [argument: NULL]
- username (username of current user) [argument: NULL]
-- vol_perc (oss/alsa volume and mute status in percent) [argument: /dev/mixer]
+- vol_perc (oss/alsa volume status (see README)) [argument: /dev/mixer]
- wifi_perc (wifi signal in percent) [argument: wifi card interface name]
- wifi_essid (wifi essid) [argument: wifi card interface name] */
static const struct arg args[] = {
diff --git a/slstatus.c b/slstatus.c
@@ -628,14 +628,18 @@ vol_perc(const char *card)
}
ioctl(afd, MIXER_READ(SOUND_MIXER_DEVMASK), &devmask);
- for (i = 0; i < (sizeof(vnames) / sizeof((vnames[0]))); i++)
- if (devmask & (1 << i))
- if (!strcmp("vol", vnames[i]))
+ for (i = 0; i < (sizeof(vnames) / sizeof((vnames[0]))); i++) {
+ if (devmask & (1 << i)) {
+ if (!strcmp("vol", vnames[i])) {
ioctl(afd, MIXER_READ(i), &v);
+ }
+ }
+ }
close(afd);
- if (v == 0)
+ if (v == 0) {
return smprintf("mute");
+ }
return smprintf("%d%%", v & 0xff);
}