Struct MPMCUniReceiver

Source
pub struct MPMCUniReceiver<T> { /* private fields */ }
Expand description

This is the receiving end of a standard mpmc view of the queue for when it’s statically know that there is only one receiver. It functions similarly to the BroadcastUniReceiver execpt there is only ever one stream. As a result, the type doesn’t need to be clone or sync

Implementations§

Source§

impl<T> MPMCUniReceiver<T>

Source

pub fn try_recv(&self) -> Result<T, TryRecvError>

Identical to MPMCReceiver::try_recv

Source

pub fn recv(&self) -> Result<T, RecvError>

Identical to MPMCReceiver::recv

Source

pub fn try_recv_view<R, F: FnOnce(&T) -> R>( &self, op: F, ) -> Result<R, (F, TryRecvError)>

Applies the passed function to the value in the queue without copying it out If there is no data in the queue or the writers have disconnected, returns an Err((F, TryRecvError))

§Example
use multiqueue2::mpmc_queue;

let (w, r) = mpmc_queue(10);
let single_r = r.into_single().unwrap();
for i in 0..5 {
    w.try_send(i).unwrap();
}

for i in 0..5 {
    let val = match single_r.try_recv_view(|x| 1 + *x) {
        Ok(val) => val,
        Err(_) => panic!("Queue shouldn't be disconncted or empty"),
    };
    assert_eq!(i + 1, val);
}
assert!(single_r.try_recv_view(|x| *x).is_err());
drop(w);
assert!(single_r.try_recv_view(|x| *x).is_err());
Source

pub fn recv_view<R, F: FnOnce(&T) -> R>( &self, op: F, ) -> Result<R, (F, RecvError)>

Applies the passed function to the value in the queue without copying it out If there is no data in the queue, blocks until an item is pushed into the queue or all writers disconnect

§Example
use multiqueue2::mpmc_queue;

let (w, r) = mpmc_queue(10);
let single_r = r.into_single().unwrap();
for i in 0..5 {
    w.try_send(i).unwrap();
}

for i in 0..5 {
    let val = match single_r.recv_view(|x| 1 + *x) {
        Ok(val) => val,
        Err(_) => panic!("Queue shouldn't be disconncted or empty"),
    };
    assert_eq!(i + 1, val);
}
drop(w);
assert!(single_r.recv_view(|x| *x).is_err());
Source

pub fn unsubscribe(self) -> bool

Removes the given reader from the queue subscription lib Returns true if this is the last reader in a given broadcast unit

§Examples
use multiqueue2::mpmc_queue;
let (writer, reader) = mpmc_queue(2);
writer.try_send(1).expect("This will succeed since queue is empty");
reader.try_recv().expect("This reader can read");
reader.unsubscribe();
// Fails since there's no readers left
assert!(writer.try_send(1).is_err());
Source

pub fn into_multi(self) -> MPMCReceiver<T>

Transforms the MPMCUniReceiver into a MPMCReceiver

§Example
use multiqueue2::mpmc_queue;

let (w, r) = mpmc_queue(10);
w.try_send(1).unwrap();
let single_r = r.into_single().unwrap();
let normal_r = single_r.into_multi();
normal_r.clone();
Source

pub fn iter_with<R, F: FnMut(&T) -> R>(self, op: F) -> MPMCUniIter<R, F, T>

Returns a non-owning iterator that iterates over the queue until it fails to receive an item, either through being empty or begin disconnected. This iterator will never block.

§Examples:
use multiqueue2::mpmc_queue;
let (w, r) = mpmc_queue(2);
let sr = r.into_single().unwrap();
w.try_send(1).unwrap();
w.try_send(2).unwrap();
w.unsubscribe();
for val in sr.iter_with(|x| 2 * *x).zip(1..2) {
    assert_eq!(val.0, val.1 * 2);
}
Source

pub fn try_iter_with<R, F: FnMut(&T) -> R>( &self, op: F, ) -> MPMCUniRefIter<'_, R, F, T>

Returns a non-owning iterator that iterates over the queue until it fails to receive an item, either through being empty or begin disconnected. This iterator will never block.

§Examples:
use multiqueue2::mpmc_queue;
let (w, r) = mpmc_queue(2);
let sr = r.into_single().unwrap();
for _ in 0 .. 3 {
    w.try_send(1).unwrap();
    w.try_send(2).unwrap();
    for val in sr.try_iter_with(|x| 2 * *x).zip(1..2) {
        assert_eq!(val.0, val.1*2);
    }
}

Trait Implementations§

Source§

impl<'a, T: 'a> IntoIterator for &'a MPMCUniReceiver<T>

Source§

type Item = T

The type of the elements being iterated over.
Source§

type IntoIter = MPSCRefIter<'a, T>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> MPSCRefIter<'a, T>

Creates an iterator from a value. Read more
Source§

impl<T> IntoIterator for MPMCUniReceiver<T>

Source§

type Item = T

The type of the elements being iterated over.
Source§

type IntoIter = MPSCIter<T>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> MPSCIter<T>

Creates an iterator from a value. Read more
Source§

impl<T: Send> Send for MPMCUniReceiver<T>

Auto Trait Implementations§

§

impl<T> !Freeze for MPMCUniReceiver<T>

§

impl<T> !RefUnwindSafe for MPMCUniReceiver<T>

§

impl<T> !Sync for MPMCUniReceiver<T>

§

impl<T> Unpin for MPMCUniReceiver<T>

§

impl<T> !UnwindSafe for MPMCUniReceiver<T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.