Open
Description
Feature gate: #![feature(exclusive_wrapper)]
This is a tracking issue for the Exclusive
wrapper struct.
This structure can be used to upgrade non-Sync
objects into Sync
ones, by only offering mutable access to the underlying object. This can be useful with Send
-but-not-Sync
futures (like BoxFuture
s)
Public API
// core::sync
#[derive(Default)]
struct Exclusive<T: ?Sized> { ... }
impl<T: ?Sized> Sync for Exclusive {}
impl<T> Exclusive<T> {
pub const fn new(t: T) -> Self;
pub const fn into_inner(self) -> T;
}
impl<T: ?Sized> Exclusive<T> {
pub const fn get_mut(&mut self) -> &mut T;
pub const fn get_pin_mut(Pin<&mut self>) -> Pin<&mut T>;
pub const fn from_mut(&mut T) -> &mut Exclusive<T>;
pub const fn from_pin_mut(Pin<&mut T>) -> Pin<&mut Exclusive<T>>;
}
impl<T: Future> Future for Exclusive { ... }
impl<T> From<T> for Exclusive<T> { ... }
impl<T: ?Sized> Debug for Exclusive { ... }
Steps / History
- Implementation: [core] add
Exclusive
to sync #97629 - Determine other nice-to-have trait impls
- Final comment period (FCP)
- Stabilization PR
Unresolved Questions
- None yet.