/udev-rs

Libudev bindings for Rust

Primary LanguageRustMIT LicenseMIT

udev

This crate provides a safe wrapper around the native libudev library. It applies the RAII pattern and Rust lifetimes to ensure safe usage of all libudev functionality. The RAII pattern ensures that all acquired resources are released when they're no longer needed, and Rust lifetimes ensure that resources are released in a proper order.

Dependencies

In order to use the libudev crate, you must have a Linux system with the libudev library installed where it can be found by pkg-config. To install libudev on Debian-based Linux distributions, execute the following command:

sudo apt-get install libudev-dev

libudev is a Linux-specific package. It is not available for Windows, OS X, or other operating systems.

Cross-Compiling

The libudev crate can be used when cross-compiling to a foreign target. Details on how to cross-compile libudev are explained in the libudev-sys crate's README.

Usage

Add udev as a dependency in Cargo.toml:

[dependencies]
udev = "0.4"

If you plan to support operating systems other than Linux, you'll need to add udev as a target-specific dependency:

[target.x86_64-unknown-linux-gnu.dependencies]
udev = "0.4"

Import the udev crate.

extern crate udev;

fn main() {
  let mut enumerator = udev::Enumerator::new().unwrap();

  enumerator.match_subsystem("tty").unwrap();

  for device in enumerator.scan_devices().unwrap() {
    println!("found device: {:?}", device.syspath());
  }
}

Contributors

License

Copyright © 2017 Victor Brekenfeld Copyright © 2015 David Cuddeback

Copyright for portions of the project are held by [David Cuddeback, 2015] as part of the project. All other copyright for the project are held by [Victor Brekenfeld, 2017].

Distributed under the MIT License.