18 releases

Uses old Rust 2015

0.6.0 Sep 10, 2024
0.5.5 Oct 31, 2023
0.5.4 Dec 9, 2022
0.5.2 Aug 16, 2022
0.1.2 May 23, 2017

#7 in Unix APIs

Download history 42170/week @ 2024-08-20 44420/week @ 2024-08-27 44923/week @ 2024-09-03 38704/week @ 2024-09-10 31687/week @ 2024-09-17 40476/week @ 2024-09-24 47311/week @ 2024-10-01 36529/week @ 2024-10-08 49229/week @ 2024-10-15 44283/week @ 2024-10-22 50959/week @ 2024-10-29 39435/week @ 2024-11-05 69989/week @ 2024-11-12 55678/week @ 2024-11-19 39272/week @ 2024-11-26 57560/week @ 2024-12-03

228,484 downloads per month
Used in 192 crates (48 directly)

MIT license

90KB
2K SLoC

This crate provides a safe interface for reading and writing information to the kernel using the sysctl interface.

Build Status

Current Version

FreeBSD, Linux, macOS, iOS, tvOS, and visionOS are supported. Contributions for improvements and other platforms are welcome.

Documentation

Documentation is available on docs.rs

Usage

Add to Cargo.toml

[dependencies]
sysctl = "*"

macOS/iOS

  • Due to limitations in the sysctl(3) API, many of the methods of the Ctl take a mutable reference to self on macOS/iOS.
  • Sysctl descriptions are not available on macOS/iOS and Linux.
  • Some tests failures are ignored, as the respective sysctls do not exist on macos.

Example

sysctl comes with several examples, see the examples folder:

  • value.rs: shows how to get a sysctl value
  • value_as.rs: parsing values as structures
  • value_string.rs: parsing values as string. Use this for cross platform compatibility since all sysctls are strings on Linux.
  • value_oid_as.rs: getting a sysctl from OID constants from the libc crate.
  • set_value.rs: shows how to set a sysctl value
  • struct.rs: reading data into a struct
  • temperature.rs: parsing temperatures
  • iterate.rs: showcases iteration over the sysctl tree

Run with:

$ cargo run --example iterate

Or to use in your program:

extern crate sysctl;
use sysctl::Sysctl;

fn main() {
    let ctl = sysctl::Ctl::new("kern.osrevision").unwrap();
    println!("Description: {}", ctl.description().unwrap());
    println!("Value: {}", ctl.value_string().unwrap());
}

Dependencies

~0.4–7.5MB
~59K SLoC