Skip to content

Commit

Permalink
* lisp/battery.el: Add `battery-upower' - very fast battery status
Browse files Browse the repository at this point in the history
  function using upowerd
  • Loading branch information
zevlg committed Nov 30, 2016
1 parent a283d65 commit fdd371c
Showing 1 changed file with 68 additions and 0 deletions.
68 changes: 68 additions & 0 deletions lisp/battery.el
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,11 @@
:type 'regexp
:group 'battery)

(defcustom battery-upower-device "battery_BAT1"
"*Upower battery device name."
:type 'string
:group 'battery)

(defcustom battery-status-function
(cond ((and (eq system-type 'gnu/linux)
(file-readable-p "/proc/apm"))
Expand Down Expand Up @@ -535,6 +540,69 @@ The following %-sequences are provided:
"BAT")
(t "N/A"))))))


;;; `upowerd' interface.
(defsubst battery-upower-prop (pname &optional device)
(dbus-get-property
:system
"org.freedesktop.UPower"
(concat "/org/freedesktop/UPower/devices/" (or device battery-upower-device))
"org.freedesktop.UPower"
pname))

(defun battery-upower ()
"Get battery status from dbus Upower interface.
This function works only in systems with `upowerd' daemon
running.
The following %-sequences are provided:
%c Current capacity (mWh)
%p Battery load percentage
%r Current rate
%B Battery status (verbose)
%L AC line status (verbose)
%s Remaining time (to charge or discharge) in seconds
%m Remaining time (to charge or discharge) in minutes
%h Remaining time (to charge or discharge) in hours
%t Remaining time (to charge or discharge) in the form `h:min'"
(let ((percents (battery-upower-prop "Percentage"))
(time-to-empty (battery-upower-prop "TimeToEmpty"))
(time-to-full (battery-upower-prop "TimeToFull"))
(state (battery-upower-prop "State"))
(online (battery-upower-prop "Online" "line_power_ACAD"))
(energy (battery-upower-prop "Energy"))
(energy-rate (battery-upower-prop "EnergyRate"))
(battery-states '((0 . "unknown") (1 . "charging")
(2 . "discharging") (3 . "empty")
(4 . "fully-charged") (5 . "pending-charge")
(6 . "pending-discharge")))
seconds minutes hours remaining-time)
(cond ((and online time-to-full)
(setq seconds time-to-full))
((and (not online) time-to-empty)
(setq seconds time-to-empty)))
(when seconds
(setq minutes (/ seconds 60)
hours (/ minutes 60)
remaining-time
(format "%d:%02d" (truncate hours)
(- (truncate minutes) (* 60 (truncate hours))))))
(list (cons ?c (or (and energy
(number-to-string (round (* 1000 energy))))
"N/A"))
(cons ?p (or (and percents (number-to-string (round percents)))
"N/A"))
(cons ?r (or (and energy-rate
(concat (number-to-string energy-rate) " W"))
"N/A"))
(cons ?B (or (and state (cdr (assoc state battery-states)))
"unknown"))
(cons ?L (or (and online "on-line") "off-line"))
(cons ?s (or (and seconds (number-to-string seconds)) "N/A"))
(cons ?m (or (and minutes (number-to-string minutes)) "N/A"))
(cons ?h (or (and hours (number-to-string hours)) "N/A"))
(cons ?t (or remaining-time "N/A")))))


;;; `apm' interface for BSD.
(defun battery-bsd-apm ()
Expand Down

0 comments on commit fdd371c

Please sign in to comment.