Crates.io | starship-battery |
lib.rs | starship-battery |
version | 0.10.0 |
source | src |
created_at | 2021-11-09 00:35:06.100517 |
updated_at | 2024-09-06 11:44:44.428647 |
description | Cross-platform information about the notebook batteries |
homepage | |
repository | https://github.com/starship/rust-battery |
max_upload_size | |
id | 478693 |
size | 186,457 |
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!