diff --git a/README b/README index f14a3b8..ddd295b 100644 --- a/README +++ b/README @@ -69,6 +69,6 @@ The following functions are not portable at the moment: - cpu_{freq,perc,iowait} - entropy - swap_{free,perc,total,used} -- battery_{perc,power,state} +- battery_{power,state} - temp - vol_perc diff --git a/components/battery.c b/components/battery.c index 52ad343..4314e81 100644 --- a/components/battery.c +++ b/components/battery.c @@ -1,22 +1,50 @@ /* See LICENSE file for copyright and license details. */ +#include +#include #ifdef __linux__ #include -#include #include +#elif __OpenBSD__ +#include +#include +#include +#include +#endif #include "../util.h" const char * battery_perc(const char *bat) { +#ifdef __linux__ int perc; char path[PATH_MAX]; snprintf(path, sizeof(path), "%s%s%s", "/sys/class/power_supply/", bat, "/capacity"); return (pscanf(path, "%i", &perc) == 1) ? bprintf("%d", perc) : NULL; +#elif __OpenBSD__ + struct apm_power_info apm_info; + int fd; + + fd = open("/dev/apm", O_RDONLY); + if (fd < 0) { + warn("Failed to open file /dev/apm"); + return NULL; + } + + if (ioctl(fd, APM_IOC_GETPOWER, &apm_info) < 0) { + warn("Failed to get battery info"); + close(fd); + return NULL; + } + close(fd); + + return bprintf("%d", apm_info.battery_life); +#endif } +#ifdef __linux__ const char * battery_power(const char *bat) {