Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/segevfiner/keepawake-rs
Keep your computer awake
https://github.com/segevfiner/keepawake-rs
awake caffeinate gnome-session-inhibit idle power-management rust sleep systemd-inhibit
Last synced: about 11 hours ago
JSON representation
Keep your computer awake
- Host: GitHub
- URL: https://github.com/segevfiner/keepawake-rs
- Owner: segevfiner
- License: mit
- Created: 2022-09-27T13:56:43.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-04-17T09:07:06.000Z (9 months ago)
- Last Synced: 2025-01-01T12:10:00.354Z (7 days ago)
- Topics: awake, caffeinate, gnome-session-inhibit, idle, power-management, rust, sleep, systemd-inhibit
- Language: Rust
- Homepage: https://crates.io/crates/keepawake
- Size: 189 KB
- Stars: 26
- Watchers: 2
- Forks: 16
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# keepawake-rs
[![Crates.io](https://img.shields.io/crates/v/keepawake)](https://crates.io/crates/keepawake)
[![docs.rs](https://img.shields.io/docsrs/keepawake)](https://docs.rs/keepawake)
[![CI](https://github.com/segevfiner/keepawake-rs/actions/workflows/ci.yml/badge.svg)](https://github.com/segevfiner/keepawake-rs/actions/workflows/ci.yml)Keep your computer awake. Like [`caffeinate`], [`systemd-inhibit`]/[`gnome-session-inhibit`], or [PowerToys Awake], but cross-platform and written in [Rust].
Also available as a [Rust crate], and as a [C library](#c-library-experimental) (experimental).
[`caffeinate`]: https://ss64.com/osx/caffeinate.html
[`systemd-inhibit`]: https://www.freedesktop.org/software/systemd/man/systemd-inhibit.html
[`gnome-session-inhibit`]: https://manpages.ubuntu.com/manpages/jammy/man1/gnome-session-inhibit.1.html
[PowerToys Awake]: https://learn.microsoft.com/en-us/windows/powertoys/awake
[Rust]: https://www.rust-lang.org/
[Rust crate]: https://docs.rs/keepawake## Usage
```
Keep your computer awakeUsage: keepawake [OPTIONS] [COMMAND]...
Arguments:
[COMMAND]... Run the command and wait for it to exit, keeping the computer awake while it runsOptions:
-d, --display Keep display on
-i, --idle Keep system from idle sleeping
-s, --sleep Keep system from sleeping (Functionality and conditions for this to work vary by OS)
--completions Generate shell completions [possible values: bash, elvish, fish, powershell, zsh]
-w Wait for the process with the specified pid to exit. This option is ignored when used with the COMMAND argument
-h, --help Print help information
-V, --version Print version information
```See [docs.rs/keepawake](https://docs.rs/keepawake) for library crate documentation and usage.
## Installation
### Cargo
```sh
cargo install keepawake -F bin
```### Binaries
Download from https://github.com/segevfiner/keepawake-rs/releases/latest.## Completions
Use: `keepawake --completions ` to generate a completion script, you will have to install it
as appropriate for the specific shell you are using.## C library (experimental)
Built using [cargo-c].```sh
# build the library, create the .h header, create the .pc file
$ cargo cbuild --destdir=${D} --prefix=/usr --libdir=/usr/lib64
``````sh
# build the library, create the .h header, create the .pc file and install all of it
$ cargo cinstall --destdir=${D} --prefix=/usr --libdir=/usr/lib64
```See the generated header file for details on the API. See [cargo-c] for futher details on cargo-c usage.
[cargo-c]: https://crates.io/crates/cargo-c
## Notes
Preventing the computer from explicitly sleeping, and/or by closing the lid, is often restricted in various ways by the OS, e.g. Only on AC power, not in any PC running Windows with [Modern Standby](https://learn.microsoft.com/en-us/windows-hardware/design/device-experiences/modern-standby). Also note that Modern Standby ignores/terminates power requests on DC (Battery) power, [PowerSetRequest - Remarks](https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-powersetrequest#remarks).## License
MIT License.