# Battery Library and CLI tool for monitoring [upowerd](https://upower.freedesktop.org/) devices. ## Installation 1. install dependencies :::code-group ```sh [ Arch] sudo pacman -Syu meson vala json-glib gobject-introspection ``` ```sh [ Fedora] sudo dnf install meson gcc valac json-glib-devel gobject-introspection-devel ``` ```sh [ Ubuntu] sudo apt install meson valac libjson-glib-dev gobject-introspection ``` ::: ::: info Although UPower is not a direct build dependency, it should be self-explanatory that the daemon is required to be available at runtime. ::: 2. clone repo ```sh git clone https://github.com/aylur/astal.git cd astal/lib/battery ``` 3. install ```sh meson setup build meson install -C build ``` :::tip Most distros recommend manual installs in `/usr/local`, which is what `meson` defaults to. If you want to install to `/usr` instead which most package managers do, set the `prefix` option: ```sh meson setup --prefix /usr build ``` ::: ## Usage You can browse the [Battery reference](https://aylur.github.io/libastal/battery). ### CLI ```sh astal-battery --help ``` ### Library :::code-group ```js [ JavaScript] import Battery from "gi://AstalBattery" const battery = Battery.get_default() print(battery.percentage) ``` ```py [ Python] from gi.repository import AstalBattery as Battery battery = Battery.get_default() print(battery.get_percentage()) ``` ```lua [ Lua] local Battery = require("lgi").require("AstalBattery") local battery = Battery.get_default() print(battery.percentage) ``` ```vala [ Vala] // Not yet documented ``` :::