From 22f465a819d927b809820e054ec6618983fa4b64 Mon Sep 17 00:00:00 2001 From: Moviuro Date: Mon, 15 Sep 2014 19:58:13 +0200 Subject: [PATCH] zshrc: added OpenBSD support for battery info --- etc/zsh/zshrc | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/etc/zsh/zshrc b/etc/zsh/zshrc index c41cdd7..eb3f2a6 100644 --- a/etc/zsh/zshrc +++ b/etc/zsh/zshrc @@ -1651,7 +1651,7 @@ PS4='+%N:%i:%_> ' # display battery status on right side of prompt using 'GRML_DISPLAY_BATTERY=1' in .zshrc.pre if [[ $GRML_DISPLAY_BATTERY -gt 0 ]] ; then - if ! islinux ; then + if ! islinux && ! isopenbsd ; then # not yet supported GRML_DISPLAY_BATTERY=0 fi @@ -1661,6 +1661,8 @@ battery() { if [[ $GRML_DISPLAY_BATTERY -gt 0 ]] ; then if islinux ; then batterylinux + elif isopenbsd ; then + batteryopenbsd fi fi } @@ -1692,6 +1694,35 @@ if (( $#batteries > 0 )) ; then fi } +batteryopenbsd(){ +GRML_BATTERY_LEVEL='' +local batfull batwarn batnow num +for num in 0 1 ; do + bat=$(sysctl -n hw.sensors.acpibat${num}) + if [[ ! -z $bat ]]; then + batfull=${"$(sysctl -n hw.sensors.acpibat${num}.amphour0)"%% *} + batwarn=${"$(sysctl -n hw.sensors.acpibat${num}.amphour1)"%% *} + batnow=${"$(sysctl -n hw.sensors.acpibat${num}.amphour3)"%% *} + case "$(sysctl -n hw.sensors.acpibat${num}.raw0)" in + *" discharging"*) + if (( batnow < batwarn )) ; then + GRML_BATTERY_LEVEL+=" !v" + else + GRML_BATTERY_LEVEL+=" v" + fi + ;; + *" charging"*) + GRML_BATTERY_LEVEL+=" ^" + ;; + *) + GRML_BATTERY_LEVEL+=" =" + ;; + esac + GRML_BATTERY_LEVEL+="${$(( 100 * batnow / batfull ))%%.*}%%" + fi +done +} + # set variable debian_chroot if running in a chroot with /etc/debian_chroot if [[ -z "$debian_chroot" ]] && [[ -r /etc/debian_chroot ]] ; then debian_chroot=$(