summaryrefslogtreecommitdiff
path: root/dwmstatus.c
diff options
context:
space:
mode:
authorChristoph Lohmann <20h@r-36.net>2022-08-18 13:48:00 +0200
committerChristoph Lohmann <20h@r-36.net>2022-08-18 13:48:00 +0200
commit19953a7de2c6fc8cf6c3e88f8cd51e7e8e54d190 (patch)
treeadff6f93c766357b39357825452604e714623bae /dwmstatus.c
parent51bc02f6ea93e54c976aa76f5a43dd032e637f51 (diff)
Add xkbmap handler.
Diffstat (limited to 'dwmstatus.c')
-rw-r--r--dwmstatus.c40
1 files changed, 30 insertions, 10 deletions
diff --git a/dwmstatus.c b/dwmstatus.c
index d2a4b03..a4d8d55 100644
--- a/dwmstatus.c
+++ b/dwmstatus.c
@@ -175,17 +175,39 @@ gettemperature(char *base, char *sensor)
return smprintf("%02.0f°C", atof(co) / 1000);
}
+char *
+execscript(char *cmd)
+{
+ FILE *fp;
+ char retval[1025], rv;
+
+ memset(retval, 0, sizeof(retval));
+
+ fp = popen(cmd, "r");
+ if (fp == NULL)
+ return smprintf("");
+
+ rv = fgets(retval, sizeof(retval)-1, fp);
+ pclose(fp);
+ if (rv == NULL)
+ return smprintf("");
+ retval[strlen(retval)-1] = '\0';
+
+ return smprintf("%s", retval);
+}
+
int
main(void)
{
char *status;
char *avgs;
char *bat;
- char *bat1;
char *tmar;
char *tmutc;
char *tmbln;
- char *t0, *t1, *t2;
+ char *t0;
+ char *t1;
+ char *kbmap;
if (!(dpy = XOpenDisplay(NULL))) {
fprintf(stderr, "dwmstatus: cannot open display.\n");
@@ -195,25 +217,23 @@ main(void)
for (;;sleep(60)) {
avgs = loadavg();
bat = getbattery("/sys/class/power_supply/BAT0");
- bat1 = getbattery("/sys/class/power_supply/BAT1");
tmar = mktimes("%H:%M", tzargentina);
tmutc = mktimes("%H:%M", tzutc);
tmbln = mktimes("KW %W %a %d %b %H:%M %Z %Y", tzberlin);
- t0 = gettemperature("/sys/devices/virtual/hwmon/hwmon0", "temp1_input");
- t1 = gettemperature("/sys/devices/virtual/hwmon/hwmon2", "temp1_input");
- t2 = gettemperature("/sys/devices/virtual/hwmon/hwmon4", "temp1_input");
+ kbmap = execscript("setxkbmap -query | grep layout | cut -d':' -f 2- | tr -d ' '");
+ t0 = gettemperature("/sys/devices/virtual/thermal/thermal_zone0", "temp");
+ t1 = gettemperature("/sys/devices/virtual/thermal/thermal_zone1", "temp");
- status = smprintf("T:%s|%s|%s L:%s B:%s|%s A:%s U:%s %s",
- t0, t1, t2, avgs, bat, bat1, tmar, tmutc,
+ status = smprintf("K:%s T:%s|%s L:%s B:%s A:%s U:%s %s",
+ kbmap, t0, t1, avgs, bat, tmar, tmutc,
tmbln);
setstatus(status);
+ free(kbmap);
free(t0);
free(t1);
- free(t2);
free(avgs);
free(bat);
- free(bat1);
free(tmar);
free(tmutc);
free(tmbln);