Struct ksched::sync::RwLockUpgradableReadGuard[][src]

pub struct RwLockUpgradableReadGuard<'a, T: ?Sized>(_);
Expand description

A guard that releases the upgradable read lock when dropped.

Implementations

impl<'a, T: ?Sized> RwLockUpgradableReadGuard<'a, T>[src]

pub fn downgrade(self) -> RwLockReadGuard<'a, T>[src]

Downgrades into a regular reader guard.

Examples

use ksched::sync::{RwLock, RwLockUpgradableReadGuard};

let lock = RwLock::new(1);

let reader = lock.upgradable_read().await;
assert_eq!(*reader, 1);

assert!(lock.try_upgradable_read().is_none());

let reader = RwLockUpgradableReadGuard::downgrade(reader);

assert!(lock.try_upgradable_read().is_some());

pub fn try_upgrade(self) -> Result<RwLockWriteGuard<'a, T>, Self>[src]

Attempts to upgrade into a write lock.

If a write lock could not be acquired at this time, then None is returned. Otherwise, an upgraded guard is returned that releases the write lock when dropped.

This function can only fail if there are other active read locks.

Examples

use ksched::sync::{RwLock, RwLockUpgradableReadGuard};

let lock = RwLock::new(1);

let reader = lock.upgradable_read().await;
assert_eq!(*reader, 1);

let reader2 = lock.read().await;
let reader = RwLockUpgradableReadGuard::try_upgrade(reader).unwrap_err();

drop(reader2);
let writer = RwLockUpgradableReadGuard::try_upgrade(reader).unwrap();

pub async fn upgrade(self) -> RwLockWriteGuard<'a, T>[src]

Upgrades into a write lock.

No writer can acquire this lock until the upgrade has finished.

Examples

use ksched::sync::{RwLock, RwLockUpgradableReadGuard};

let lock = RwLock::new(1);

let reader = lock.upgradable_read().await;
assert_eq!(*reader, 1);

let mut writer = RwLockUpgradableReadGuard::upgrade(reader).await;
*writer = 2;

Trait Implementations

impl<T: Debug + ?Sized> Debug for RwLockUpgradableReadGuard<'_, T>[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result[src]

Formats the value using the given formatter. Read more

impl<T: ?Sized> Deref for RwLockUpgradableReadGuard<'_, T>[src]

type Target = T

The resulting type after dereferencing.

fn deref(&self) -> &T[src]

Dereferences the value.

impl<T: Display + ?Sized> Display for RwLockUpgradableReadGuard<'_, T>[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result[src]

Formats the value using the given formatter. Read more

impl<T: ?Sized> Drop for RwLockUpgradableReadGuard<'_, T>[src]

fn drop(&mut self)[src]

Executes the destructor for this type. Read more

impl<T: Send + Sync + ?Sized> Send for RwLockUpgradableReadGuard<'_, T>[src]

impl<T: Sync + ?Sized> Sync for RwLockUpgradableReadGuard<'_, T>[src]

Auto Trait Implementations

impl<'a, T> !RefUnwindSafe for RwLockUpgradableReadGuard<'a, T>

impl<'a, T: ?Sized> Unpin for RwLockUpgradableReadGuard<'a, T>

impl<'a, T> !UnwindSafe for RwLockUpgradableReadGuard<'a, T>

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> ToString for T where
    T: Display + ?Sized
[src]

pub default fn to_string(&self) -> String[src]

Converts the given value to a String. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.