Merge pull request #1499 from mook/1498-bat-linux-path
[Battery - Linux] Ignore AC adapters, use battery status instead
This commit is contained in:
commit
d611cc2e43
|
@ -62,25 +62,22 @@ def _fetch_battery_info(pl):
|
||||||
pl.debug('Not using DBUS+UPower as no batteries were found')
|
pl.debug('Not using DBUS+UPower as no batteries were found')
|
||||||
|
|
||||||
if os.path.isdir('/sys/class/power_supply'):
|
if os.path.isdir('/sys/class/power_supply'):
|
||||||
online_path_verified = None
|
linux_capacity_fmt = '/sys/class/power_supply/{0}/capacity'
|
||||||
linux_supplier_fmt = '/sys/class/power_supply/{0}/capacity'
|
linux_status_fmt = '/sys/class/power_supply/{0}/status'
|
||||||
linux_ac_fmt = '/sys/class/power_supply/{0}/online'
|
|
||||||
for linux_supplier in os.listdir('/sys/class/power_supply'):
|
for linux_supplier in os.listdir('/sys/class/power_supply'):
|
||||||
cap_path = linux_supplier_fmt.format(linux_supplier)
|
cap_path = linux_capacity_fmt.format(linux_supplier)
|
||||||
online_path = linux_ac_fmt.format(linux_supplier)
|
status_path = linux_status_fmt.format(linux_supplier)
|
||||||
if linux_supplier.startswith('AC') and os.path.exists(online_path):
|
if not os.path.exists(cap_path):
|
||||||
pl.debug('Using /sys/class/power_supply with AC {0}', online_path)
|
continue
|
||||||
online_path_verified = online_path
|
|
||||||
elif linux_supplier.startswith('BAT') and os.path.exists(cap_path):
|
|
||||||
pl.debug('Using /sys/class/power_supply with battery {0}', linux_supplier)
|
pl.debug('Using /sys/class/power_supply with battery {0}', linux_supplier)
|
||||||
|
|
||||||
def _get_battery_status(pl):
|
def _get_battery_status(pl):
|
||||||
_ac_powered = None
|
|
||||||
with open(cap_path, 'r') as f:
|
with open(cap_path, 'r') as f:
|
||||||
_capacity = int(float(f.readline().split()[0]))
|
_capacity = int(float(f.readline().split()[0]))
|
||||||
if online_path_verified:
|
try:
|
||||||
with open(online_path_verified, 'r') as f:
|
with open(status_path, 'r') as f:
|
||||||
_ac_powered = int(f.readline()) == 1
|
_ac_powered = (f.readline().strip() != 'Discharging')
|
||||||
|
except IOError:
|
||||||
|
_ac_powered = None
|
||||||
return _capacity, _ac_powered
|
return _capacity, _ac_powered
|
||||||
return _get_battery_status
|
return _get_battery_status
|
||||||
pl.debug('Not using /sys/class/power_supply as no batteries were found')
|
pl.debug('Not using /sys/class/power_supply as no batteries were found')
|
||||||
|
|
Loading…
Reference in New Issue