nannou_audio 0.14.0

The audio API for Nannou, the creative coding framework.
Documentation
use crate::{DefaultFormatError, DeviceNameError, Format, SupportedFormatsError};
use cpal::traits::DeviceTrait;
use std::ops::Deref;

/// A device that can be used to spawn an audio stream.
pub struct Device {
    pub(crate) device: cpal::Device,
}

/// An iterator yielding all available audio devices.
pub struct Devices {
    pub(crate) devices: cpal::Devices,
}

/// An iterator yielding formats that are supported by the backend.
pub type SupportedInputFormats = cpal::SupportedInputFormats;

/// An iterator yielding formats that are supported by the backend.
pub type SupportedOutputFormats = cpal::SupportedOutputFormats;

impl Device {
    /// The unique name associated with this device.
    pub fn name(&self) -> Result<String, DeviceNameError> {
        self.device.name()
    }

    /// An iterator yielding formats that are supported by the backend.
    ///
    /// Can return an error if the device is no longer valid (e.g. it has been disconnected).
    pub fn supported_input_formats(&self) -> Result<SupportedInputFormats, SupportedFormatsError> {
        self.device.supported_input_formats()
    }

    /// An iterator yielding formats that are supported by the backend.
    ///
    /// Can return an error if the device is no longer valid (e.g. it has been disconnected).
    pub fn supported_output_formats(
        &self,
    ) -> Result<SupportedOutputFormats, SupportedFormatsError> {
        self.device.supported_output_formats()
    }

    /// The default format used for input streams.
    pub fn default_input_format(&self) -> Result<Format, DefaultFormatError> {
        self.device.default_input_format()
    }

    /// The default format used for output streams.
    pub fn default_output_format(&self) -> Result<Format, DefaultFormatError> {
        self.device.default_output_format()
    }

    /// The maximum number of output channels of any format supported by this device.
    pub fn max_supported_output_channels(&self) -> usize {
        self.supported_output_formats()
            .expect("failed to get supported output audio stream formats")
            .map(|fmt| fmt.channels as usize)
            .max()
            .unwrap_or(0)
    }

    /// The maximum number of input channels of any format supported by this device.
    pub fn max_supported_input_channels(&self) -> usize {
        self.supported_input_formats()
            .expect("failed to get supported input audio stream formats")
            .map(|fmt| fmt.channels as usize)
            .max()
            .unwrap_or(0)
    }
}

impl Deref for Device {
    type Target = cpal::Device;
    fn deref(&self) -> &Self::Target {
        &self.device
    }
}

impl Iterator for Devices {
    type Item = Device;
    fn next(&mut self) -> Option<Self::Item> {
        self.devices.next().map(|device| Device { device })
    }
}