Struct scopeguard::ScopeGuard[][src]

pub struct ScopeGuard<T, F, S: Strategy = Always> where
    F: FnMut(&mut T), 
{ /* fields omitted */ }

ScopeGuard is a scope guard that may own a protected value.

If you place a guard in a local variable, the closure can run regardless how you leave the scope — through regular return or panic (except if panic or other code aborts; so as long as destructors run). It is run only once.

The S parameter for Strategy determines if the closure actually runs.

The guard's closure will be called with a mut ref to the held value in the destructor. It's called only once.

The ScopeGuard implements Deref so that you can access the inner value.

Methods

impl<T, F, S> ScopeGuard<T, F, S> where
    F: FnMut(&mut T),
    S: Strategy
[src]

Create a ScopeGuard that owns v (accessible through deref) and calls dropfn when its destructor runs.

The Strategy decides whether the scope guard's closure should run.

Trait Implementations

impl<T, F, S: Strategy> Deref for ScopeGuard<T, F, S> where
    F: FnMut(&mut T), 
[src]

The resulting type after dereferencing.

Dereferences the value.

impl<T, F, S: Strategy> DerefMut for ScopeGuard<T, F, S> where
    F: FnMut(&mut T), 
[src]

Mutably dereferences the value.

impl<T, F, S: Strategy> Drop for ScopeGuard<T, F, S> where
    F: FnMut(&mut T), 
[src]

Executes the destructor for this type. Read more

impl<T, F, S> Debug for ScopeGuard<T, F, S> where
    T: Debug,
    F: FnMut(&mut T),
    S: Strategy + Debug
[src]

Formats the value using the given formatter. Read more

Auto Trait Implementations

impl<T, F, S> Send for ScopeGuard<T, F, S> where
    F: Send,
    S: Send,
    T: Send

impl<T, F, S> Sync for ScopeGuard<T, F, S> where
    F: Sync,
    S: Sync,
    T: Sync