mirror of
https://github.com/embassy-rs/embassy.git
synced 2024-11-22 23:02:30 +00:00
embassy-sync: Add capacity, free_capacity, len, is_empty and is_full functions to PriorityChannel
This commit is contained in:
parent
3d9b502c7a
commit
f361c2e81c
@ -8,6 +8,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
## Unreleased
|
## Unreleased
|
||||||
|
|
||||||
- Add `capacity`, `free_capacity`, `len`, `is_empty` and `is_full` functions to `Channel`.
|
- Add `capacity`, `free_capacity`, `len`, `is_empty` and `is_full` functions to `Channel`.
|
||||||
|
- Add `capacity`, `free_capacity`, `len`, `is_empty` and `is_full` functions to `PriorityChannel`.
|
||||||
|
|
||||||
## 0.5.0 - 2023-12-04
|
## 0.5.0 - 2023-12-04
|
||||||
|
|
||||||
|
@ -314,6 +314,18 @@ where
|
|||||||
Poll::Pending
|
Poll::Pending
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn len(&self) -> usize {
|
||||||
|
self.queue.len()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_empty(&self) -> bool {
|
||||||
|
self.queue.is_empty()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_full(&self) -> bool {
|
||||||
|
self.queue.len() == self.queue.capacity()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A bounded channel for communicating between asynchronous tasks
|
/// A bounded channel for communicating between asynchronous tasks
|
||||||
@ -433,6 +445,33 @@ where
|
|||||||
pub fn try_receive(&self) -> Result<T, TryReceiveError> {
|
pub fn try_receive(&self) -> Result<T, TryReceiveError> {
|
||||||
self.lock(|c| c.try_receive())
|
self.lock(|c| c.try_receive())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the maximum number of elements the channel can hold.
|
||||||
|
pub const fn capacity(&self) -> usize {
|
||||||
|
N
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the free capacity of the channel.
|
||||||
|
///
|
||||||
|
/// This is equivalent to `capacity() - len()`
|
||||||
|
pub fn free_capacity(&self) -> usize {
|
||||||
|
N - self.len()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the number of elements currently in the channel.
|
||||||
|
pub fn len(&self) -> usize {
|
||||||
|
self.lock(|c| c.len())
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns whether the channel is empty.
|
||||||
|
pub fn is_empty(&self) -> bool {
|
||||||
|
self.lock(|c| c.is_empty())
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns whether the channel is full.
|
||||||
|
pub fn is_full(&self) -> bool {
|
||||||
|
self.lock(|c| c.is_full())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Implements the DynamicChannel to allow creating types that are unaware of the queue size with the
|
/// Implements the DynamicChannel to allow creating types that are unaware of the queue size with the
|
||||||
|
Loading…
Reference in New Issue
Block a user