diff options
-rw-r--r-- | Makefile | 15 | ||||
-rw-r--r-- | lowbat.1 | 28 | ||||
-rw-r--r-- | lowbat.c | 8 | ||||
-rwxr-xr-x | shlowbat | 4 |
4 files changed, 45 insertions, 10 deletions
@@ -7,20 +7,25 @@ TARGET = lowbat SRCS = lowbat.c OBJS = $(SRCS:.c=.o) -# Default target all: $(TARGET) -# Build target $(TARGET): $(OBJS) $(CC) $(CFLAGS) -o $@ $(OBJS) $(LDFLAGS) $(LIBS) -# Compile source files %.o: %.c $(CC) $(CFLAGS) -c $< -o $@ -# Clean up build files clean: rm -f $(TARGET) $(OBJS) -# Phony targets +install: all + mkdir -p /usr/local/bin + cp lowbat /usr/local/bin/lowbat + chmod 755 /usr/local/bin/lowbat + cp lowbat.1 /usr/local/share/man/man1/lowbat.1 + chmod 644 /usr/local/share/man/man1/lowbat.1 + +uninstall: + rm -f /usr/local/bin/lowbat /usr/local/share/man/man1/lowbat.1 + .PHONY: all clean diff --git a/lowbat.1 b/lowbat.1 new file mode 100644 index 0000000..1d0d66f --- /dev/null +++ b/lowbat.1 @@ -0,0 +1,28 @@ +.TH LOWBAT 1 lowbat\-1.0 +.SH NAME +lowbat - A minimal battery level monitor daemon, written in C +.SH DESCRIPTION +lowbat is configured by default to check the system battery level every 3 +seconds. It is able to detect each battery installed and the system, and +calculate the remaining capacity of all batteries combined. Batteries added to +the system during runtime will also be detected. +.P +The daemon will send a warning notification the user when their battery level +drops below 20% while the batteries are discharging, and another critical +warning at 5%. +.P +The current battery level will also be displayed in stdout. +.SH USAGE +Call the lowbat executable in your xinitrc or xprofile. +.SH CUSTOMIZATION +There are no runtime flags or configuration files. Simply modify the source +code to suit your needs. +.SH COPYRIGHT +Copyright 2024 Tim Keller. +MIT License. +.P +.BR <https://TJKeller.xyz> +.SH SEE ALSO +.BR notify-send(1) +.P +.BR <https://www.kernel.org/doc/Documentation/ABI/testing/sysfs-class-power> @@ -64,11 +64,13 @@ void load_installed_batteries() { closedir(dir); } -void notifysend(char *title, char *content) { +void notifysend(char *title, char *content, NotifyUrgency urgency) { NotifyNotification *notif; notify_init("lowbat"); notif = notify_notification_new(title, content, NULL); + notify_notification_set_timeout(notif, NOTIFY_EXPIRES_NEVER); + notify_notification_set_urgency(notif, urgency); notify_notification_show(notif, NULL); } @@ -133,12 +135,12 @@ int main() { if (discharging) { if (capacity <= 5 && !w_lowbat_crit) { sprintf(msg, "%d%% remains", capacity); // TODO snprintf me plz - notifysend("Critical Low Battery Warning", msg); + notifysend("Critical Low Battery Warning", msg, NOTIFY_URGENCY_CRITICAL); w_lowbat_crit = w_lowbat = 1; } else if (capacity <= 20 && !w_lowbat) { sprintf(msg, "%d%% remains", capacity); - notifysend("Low Battery Warning", msg); + notifysend("Low Battery Warning", msg, NOTIFY_URGENCY_NORMAL); w_lowbat = 1; } @@ -13,9 +13,9 @@ while true; do if is_discharging; then if [ $capacity -le 5 ] && [ $warning_level -lt 2 ]; then - notify_send "Critical Low Battery Warning" "${capacity}% remains" + notify-send -u critical -w "Critical Low Battery Warning" "${capacity}% remains" elif [ $capacity -le 20 ] && [ $warning_level -lt 1 ]; then - notify_send "Low Battery Warning" "${capacity}% remains" + notify-send -u normal -w "Low Battery Warning" "${capacity}% remains" fi else warning_level=0 |