| Crates.io | starship-battery |
| lib.rs | starship-battery |
| version | 0.10.2 |
| created_at | 2021-11-09 00:35:06.100517+00 |
| updated_at | 2025-06-13 18:04:03.626795+00 |
| description | Cross-platform information about the notebook batteries |
| homepage | |
| repository | https://github.com/starship/rust-battery |
| max_upload_size | |
| id | 478693 |
| size | 191,964 |
Rust crate providing cross-platform information about the notebook batteries.
battery provides a cross-platform unified API to a notebook batteries state.
Its main goal is to wrap the OS-specific interfaces, cover all the hacks and legacy cases and get the batteries information (such as state of charge, energy rate, voltage and temperature) as a typed values, recalculated as necessary to be returned as a SI measurement units.
Do note that iOS implementation uses IOKit bindings, your application might be automatically rejected by Apple based on that fact. Use it on your own risk.
As a prerequisite, battery crate requires at least Rustc version 1.69 or greater.
Add the following line into a Cargo.toml:
[dependencies]
battery = "0.8.3"
fn main() -> Result<(), battery::Error> {
let manager = battery::Manager::new()?;
for (idx, maybe_battery) in manager.batteries()?.enumerate() {
let battery = maybe_battery?;
println!("Battery #{}:", idx);
println!("Vendor: {:?}", battery.vendor());
println!("Model: {:?}", battery.model());
println!("State: {:?}", battery.state());
println!("Time to full charge: {:?}", battery.time_to_full());
println!("");
}
Ok(())
}
See the battery/examples/ folder in the repository
for additional examples.
This an incomplete list of the battery crate users. If you are using it too,
send me a message and I'll add your project here!
starship is a Rust port of the minimalistic, powerful,
and extremely customizable prompt Spaceship ZSH.
It is using the battery crate to show the the current battery level and status in a shell prompt.
Here is what @matchai says:
I really appreciate how easily we were able to get your library up and running! Battery APIs were a headache for us in predecessors of this project 😅
And there is this tweet also!