From 05479b21611031cabf8051ce90ec61aa3d00c74c Mon Sep 17 00:00:00 2001 From: Moviuro Date: Tue, 16 Sep 2014 13:42:50 +0200 Subject: [PATCH] zshrc: added FreeBSD support for battery info --- etc/zsh/zshrc | 31 ++++++++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/etc/zsh/zshrc b/etc/zsh/zshrc index eb3f2a6..a810b26 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 && ! isopenbsd ; then + if ! islinux && ! isopenbsd && ! isfreebsd ; then # not yet supported GRML_DISPLAY_BATTERY=0 fi @@ -1663,6 +1663,8 @@ if [[ $GRML_DISPLAY_BATTERY -gt 0 ]] ; then batterylinux elif isopenbsd ; then batteryopenbsd + elif isfreebsd ; then + batteryfreebsd fi fi } @@ -1723,6 +1725,33 @@ for num in 0 1 ; do done } +batteryfreebsd(){ +GRML_BATTERY_LEVEL='' +local num +local -A table +for num in 0 1 ; do + table=( ${=${${${${${(M)${(f)"$(acpiconf -i $num)"}:#(State|Remaining capacity):*}%%( ##|%)}//:[ $'\t']##/@}// /-}//@/ }} ) + if [[ $table[State] != "not-present" ]] ; then + case $table[State] in + *discharging*) + if (( $table[Remaining-capacity] < 20 )) ; then + GRML_BATTERY_LEVEL+=" !v" + else + GRML_BATTERY_LEVEL+=" v" + fi + ;; + *charging*) + GRML_BATTERY_LEVEL+=" ^" + ;; + *) + GRML_BATTERY_LEVEL+=" =" + ;; + esac + GRML_BATTERY_LEVEL+="$table[Remaining-capacity]%%" + 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=$(