72 releases

0.9.1 Jul 26, 2019
0.8.6 Jun 23, 2019
0.8.2 Mar 3, 2019
0.8.0 Dec 24, 2018
0.0.2 Jul 25, 2015

#6 in Unix APIs

Download history 513/week @ 2019-04-12 450/week @ 2019-04-19 467/week @ 2019-04-26 1095/week @ 2019-05-03 811/week @ 2019-05-10 831/week @ 2019-05-17 533/week @ 2019-05-24 699/week @ 2019-05-31 1053/week @ 2019-06-07 877/week @ 2019-06-14 1634/week @ 2019-06-21 1026/week @ 2019-06-28 1455/week @ 2019-07-05 1303/week @ 2019-07-12 1100/week @ 2019-07-19

4,297 downloads per month
Used in 9 crates

MIT license

215KB
5K SLoC

sysinfo Build status

A system handler to interact with processes.

Support the following platforms:

  • Linux
  • Raspberry
  • Mac OSX
  • Windows

It also compiles for Android but never been tested on it.

Running on Raspberry

It'll be difficult to build on Raspberry. A good way-around is to be build on Linux before sending it to your Raspberry:

rustup target add armv7-unknown-linux-gnueabihf
cargo build --target=armv7-unknown-linux-gnueabihf

Code example

You have an example into the examples folder. Just run cargo run inside the examples folder to start it. Otherwise, here is a little code sample:

extern crate sysinfo;

use sysinfo::{NetworkExt, System, SystemExt};

let mut sys = System::new();

// We display the disks:
println!("=> disk list:");
for disk in sys.get_disks() {
    println!("{:?}", disk);
}

// Network data:
println!("input data : {} B", sys.get_network().get_income());
println!("output data: {} B", sys.get_network().get_outcome());

// Components temperature:
for component in sys.get_components_list() {
    println!("{:?}", component);
}

// Memory information:
println!("total memory: {} kB", sys.get_total_memory());
println!("used memory : {} kB", sys.get_used_memory());
println!("total swap  : {} kB", sys.get_total_swap());
println!("used swap   : {} kB", sys.get_used_swap());

// Number of processors
println!("NB processors: {}", sys.get_processor_list().len());

// To refresh all system information:
sys.refresh_all();

C interface

It's possible to use this crate directly from C. Take a look at the Makefile and at the examples/src/simple.c file.

To build the C example, just run:

> make
> ./simple
# If needed:
> LD_LIBRARY_PATH=target/release/ ./simple

Donations

If you appreciate my work and want to support me, you can do it here:

Become a patron

Dependencies

~1.1–2MB
~32K SLoC