From e6292a46505188a6f2581b2dc31cf5fedd6ebfef Mon Sep 17 00:00:00 2001 From: Robbert van der Helm Date: Tue, 1 Mar 2022 16:16:13 +0100 Subject: [PATCH] Add a usage example to Buffer::iter_blocks() --- src/buffer.rs | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/buffer.rs b/src/buffer.rs index 34eac5b9..b9789946 100644 --- a/src/buffer.rs +++ b/src/buffer.rs @@ -258,6 +258,20 @@ impl<'a> Buffer<'a> { /// [crate::Smoother::next_block()]. Before using this, you will need to call /// [crate::Plugin::initialize_block_smoothers()] with the same `max_block_size` in your /// initialization function first. + /// + /// You can use this to obtain block-slices from a buffer so you can pass them to a libraryq: + /// + /// ```ignore + /// for block in buffer.iter_blocks(128) { + /// let mut block_channels = block.into_iter(); + /// let stereo_slice = &[ + /// block_channels.next().unwrap(), + /// block_channels.next().unwrap(), + /// ]; + /// + /// // Do something cool with `stereo_slice` + /// } + /// ```` pub fn iter_blocks<'slice>(&'slice mut self, max_block_size: usize) -> BlocksIter<'slice, 'a> { BlocksIter { buffers: self.output_slices.as_mut_slice(),