Crate pulsectl[][src]

Expand description

pulsectl is a high level wrapper around the PulseAudio bindings supplied by libpulse-binding to make application development easier. It provides simple access to sinks, inputs, sources and outputs allowing one to write audio control programs with ease. This library is only capable of modifying PulseAudio data (e.g., changing volume, routing applications, and muting).

This is a fork of JojiiOfficial/pulsectl-rust-fork which is then a fork of krruzic/pulsectl-rust.

Example

List all currently connected playback devices.

use pulsectl::controllers::SinkController;
use pulsectl::controllers::DeviceControl;

// create handler that calls functions on playback devices and apps
let mut handler = SinkController::create().unwrap();

let devices = handler
    .list_devices()
    .expect("Could not get list of playback devices.");

println!("Playback Devices: ");
for dev in devices.clone() {
    println!(
        "[{}] {}, Volume: {}",
        dev.index,
        dev.description.as_ref().unwrap(),
        dev.volume.print()
    );
}

For more detailed examples, check the examples directory.

Modules

controllers

Helpful wrappers when working with applications and devices.

Structs

Handler

The main wrapper of libpulse-binding API.

Enums

ControllerError

Error thrown while fetching data from pulseaudio.

Error

Error thrown when PulseAudio throws an error code.