Update cpal to 946d646

This commit is contained in:
Alex Butler 2020-02-08 14:20:17 +00:00
parent b5071c947d
commit 3a29a5390e
No known key found for this signature in database
GPG key ID: E1355A2F8E415521
2 changed files with 18 additions and 33 deletions

View file

@ -83,13 +83,14 @@
#![cfg_attr(test, deny(missing_docs))] #![cfg_attr(test, deny(missing_docs))]
pub use cpal::{ pub use cpal::{
traits::DeviceTrait, Device, Devices, DevicesError, Format, InputDevices, OutputDevices, traits::DeviceTrait, Device, Devices, DevicesError, InputDevices, OutputDevices,
SupportedStreamConfig,
}; };
mod conversions; mod conversions;
mod stream;
mod sink; mod sink;
mod spatial_sink; mod spatial_sink;
mod stream;
pub mod buffer; pub mod buffer;
pub mod decoder; pub mod decoder;
@ -100,7 +101,7 @@ pub mod static_buffer;
pub use crate::conversions::Sample; pub use crate::conversions::Sample;
pub use crate::decoder::Decoder; pub use crate::decoder::Decoder;
pub use crate::stream::{OutputStream, StreamError};
pub use crate::sink::Sink; pub use crate::sink::Sink;
pub use crate::source::Source; pub use crate::source::Source;
pub use crate::spatial_sink::SpatialSink; pub use crate::spatial_sink::SpatialSink;
pub use crate::stream::{OutputStream, StreamError};

View file

@ -89,7 +89,7 @@ impl error::Error for StreamError {
pub(crate) trait CpalDeviceExt { pub(crate) trait CpalDeviceExt {
fn new_output_stream_with_format( fn new_output_stream_with_format(
&self, &self,
format: cpal::Format, format: cpal::SupportedStreamConfig,
) -> Result<(Arc<DynamicMixerController<f32>>, cpal::Stream), cpal::BuildStreamError>; ) -> Result<(Arc<DynamicMixerController<f32>>, cpal::Stream), cpal::BuildStreamError>;
fn new_output_stream(&self) -> (Arc<DynamicMixerController<f32>>, cpal::Stream); fn new_output_stream(&self) -> (Arc<DynamicMixerController<f32>>, cpal::Stream);
@ -98,16 +98,16 @@ pub(crate) trait CpalDeviceExt {
impl CpalDeviceExt for cpal::Device { impl CpalDeviceExt for cpal::Device {
fn new_output_stream_with_format( fn new_output_stream_with_format(
&self, &self,
format: cpal::Format, format: cpal::SupportedStreamConfig,
) -> Result<(Arc<DynamicMixerController<f32>>, cpal::Stream), cpal::BuildStreamError> { ) -> Result<(Arc<DynamicMixerController<f32>>, cpal::Stream), cpal::BuildStreamError> {
let (mixer_tx, mut mixer_rx) = let (mixer_tx, mut mixer_rx) =
dynamic_mixer::mixer::<f32>(format.channels, format.sample_rate.0); dynamic_mixer::mixer::<f32>(format.channels(), format.sample_rate().0);
let error_callback = |err| eprintln!("an error occurred on output stream: {}", err); let error_callback = |err| eprintln!("an error occurred on output stream: {}", err);
match format.data_type { match format.sample_format() {
cpal::SampleFormat::F32 => self.build_output_stream::<f32, _, _>( cpal::SampleFormat::F32 => self.build_output_stream::<f32, _, _>(
&format.shape(), &format.config(),
move |data| { move |data| {
data.iter_mut() data.iter_mut()
.for_each(|d| *d = mixer_rx.next().unwrap_or(0f32)) .for_each(|d| *d = mixer_rx.next().unwrap_or(0f32))
@ -115,7 +115,7 @@ impl CpalDeviceExt for cpal::Device {
error_callback, error_callback,
), ),
cpal::SampleFormat::I16 => self.build_output_stream::<i16, _, _>( cpal::SampleFormat::I16 => self.build_output_stream::<i16, _, _>(
&format.shape(), &format.config(),
move |data| { move |data| {
data.iter_mut() data.iter_mut()
.for_each(|d| *d = mixer_rx.next().map(|s| s.to_i16()).unwrap_or(0i16)) .for_each(|d| *d = mixer_rx.next().map(|s| s.to_i16()).unwrap_or(0i16))
@ -123,7 +123,7 @@ impl CpalDeviceExt for cpal::Device {
error_callback, error_callback,
), ),
cpal::SampleFormat::U16 => self.build_output_stream::<u16, _, _>( cpal::SampleFormat::U16 => self.build_output_stream::<u16, _, _>(
&format.shape(), &format.config(),
move |data| { move |data| {
data.iter_mut().for_each(|d| { data.iter_mut().for_each(|d| {
*d = mixer_rx *d = mixer_rx
@ -141,7 +141,7 @@ impl CpalDeviceExt for cpal::Device {
fn new_output_stream(&self) -> (Arc<DynamicMixerController<f32>>, cpal::Stream) { fn new_output_stream(&self) -> (Arc<DynamicMixerController<f32>>, cpal::Stream) {
// Determine the format to use for the new stream. // Determine the format to use for the new stream.
let default_format = self let default_format = self
.default_output_format() .default_output_config()
.expect("The device doesn't support any format!?"); .expect("The device doesn't support any format!?");
self.new_output_stream_with_format(default_format) self.new_output_stream_with_format(default_format)
@ -157,18 +157,20 @@ impl CpalDeviceExt for cpal::Device {
} }
/// All the supported output formats with sample rates /// All the supported output formats with sample rates
fn supported_output_formats(device: &cpal::Device) -> impl Iterator<Item = cpal::Format> { fn supported_output_formats(
device: &cpal::Device,
) -> impl Iterator<Item = cpal::SupportedStreamConfig> {
const HZ_44100: cpal::SampleRate = cpal::SampleRate(44_100); const HZ_44100: cpal::SampleRate = cpal::SampleRate(44_100);
let mut supported: Vec<_> = device let mut supported: Vec<_> = device
.supported_output_formats() .supported_output_configs()
.expect("No supported output formats") .expect("No supported output formats")
.collect(); .collect();
supported.sort_by(|a, b| b.cmp_default_heuristics(a)); supported.sort_by(|a, b| b.cmp_default_heuristics(a));
supported.into_iter().flat_map(|sf| { supported.into_iter().flat_map(|sf| {
let max_rate = sf.max_sample_rate; let max_rate = sf.max_sample_rate();
let min_rate = sf.min_sample_rate; let min_rate = sf.min_sample_rate();
let mut formats = vec![sf.clone().with_max_sample_rate()]; let mut formats = vec![sf.clone().with_max_sample_rate()];
if HZ_44100 < max_rate && HZ_44100 > min_rate { if HZ_44100 < max_rate && HZ_44100 > min_rate {
formats.push(sf.clone().with_sample_rate(HZ_44100)) formats.push(sf.clone().with_sample_rate(HZ_44100))
@ -177,21 +179,3 @@ fn supported_output_formats(device: &cpal::Device) -> impl Iterator<Item = cpal:
formats formats
}) })
} }
trait SupportedFormatExt {
fn with_sample_rate(self, sample_rate: cpal::SampleRate) -> cpal::Format;
}
impl SupportedFormatExt for cpal::SupportedFormat {
fn with_sample_rate(self, sample_rate: cpal::SampleRate) -> cpal::Format {
let Self {
channels,
data_type,
..
} = self;
cpal::Format {
channels,
sample_rate,
data_type,
}
}
}