pub struct Count<T, const TOTAL: u64 = 2> { /* private fields */ }Implementations§
Source§impl<T, const TOTAL: u64> Count<T, TOTAL>
impl<T, const TOTAL: u64> Count<T, TOTAL>
Sourcepub open spec fn valid(self, id: Loc, frac: int) -> bool
pub open spec fn valid(self, id: Loc, frac: int) -> bool
{
&&& self.id() == id
&&& self.frac() == frac
}Sourcepub proof fn new(tracked v: T) -> tracked result : Self
pub proof fn new(tracked v: T) -> tracked result : Self
requires
TOTAL > 0,ensuresresult.frac() == TOTAL as int,result.resource() == v,Sourcepub proof fn agree(tracked &self, tracked other: &Self)
pub proof fn agree(tracked &self, tracked other: &Self)
requires
self.id() == other.id(),ensuresself.resource() == other.resource(),Sourcepub proof fn split(tracked &mut self, n: int) -> tracked result : Self
pub proof fn split(tracked &mut self, n: int) -> tracked result : Self
requires
0 < n < old(self).frac(),ensuresresult.id() == final(self).id(),final(self).id() == old(self).id(),final(self).resource() == old(self).resource(),result.resource() == old(self).resource(),final(self).frac() + result.frac() == old(self).frac(),result.frac() == n,Sourcepub proof fn combine(tracked &mut self, tracked other: Self)
pub proof fn combine(tracked &mut self, tracked other: Self)
requires
old(self).id() == other.id(),ensuresfinal(self).id() == old(self).id(),final(self).resource() == old(self).resource(),final(self).resource() == other.resource(),final(self).frac() == old(self).frac() + other.frac(),Sourcepub proof fn take_resource(tracked self) -> tracked pair : (T, EmptyCount<T, TOTAL>)
pub proof fn take_resource(tracked self) -> tracked pair : (T, EmptyCount<T, TOTAL>)
requires
self.frac() == TOTAL,ensurespair.0 == self.resource(),pair.1.id() == self.id(),Auto Trait Implementations§
impl<T, const TOTAL: u64> Freeze for Count<T, TOTAL>
impl<T, const TOTAL: u64> RefUnwindSafe for Count<T, TOTAL>where
T: RefUnwindSafe,
impl<T, const TOTAL: u64> Send for Count<T, TOTAL>
impl<T, const TOTAL: u64> Sync for Count<T, TOTAL>
impl<T, const TOTAL: u64> Unpin for Count<T, TOTAL>where
T: Unpin,
impl<T, const TOTAL: u64> UnsafeUnpin for Count<T, TOTAL>
impl<T, const TOTAL: u64> UnwindSafe for Count<T, TOTAL>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more