pub struct RegionGuard<'a>(/* private fields */);Expand description
A RegionGuard is a Visitor wrapper that automatically leaves the current region when it is dropped.
Methods from Deref<Target = Visitor>§
pub const MAGIC_BINARY_CURRENT: &'static str = "FBAF"
pub const MAGIC_ASCII_CURRENT: &'static str = "FTAX"
Sourcepub fn find_field(&mut self, name: &str) -> Option<&mut Field>
pub fn find_field(&mut self, name: &str) -> Option<&mut Field>
Tries to find a field by its name.
Sourcepub fn find_node(&self, name: &str) -> Option<&VisitorNode>
pub fn find_node(&self, name: &str) -> Option<&VisitorNode>
Tries to find a node by its name.
Sourcepub fn is_reading(&self) -> bool
pub fn is_reading(&self) -> bool
True if this Visitor is changing the values that it visits. In other words,
x.visit("MyValue", &mut visitor) will result in x being mutated to match whatever value
is stored in visitor.
False if this visitor is copying and storing the values that it visits. In other words,
x.visit("MyValue", &mut visitor) will result in x being unchanged, but visitor will
be mutated to store the value of x under the name “MyValue”.
Sourcepub fn has_region(&self, name: &str) -> bool
pub fn has_region(&self, name: &str) -> bool
Returns true of a region with the given name exists as a child of the current node.
When reading, has_region returning true means that enter_region will succeed.
When writing, has_region returning true means that enter_region will fail.
Sourcepub fn enter_region(
&mut self,
name: &str,
) -> Result<RegionGuard<'_>, VisitError>
pub fn enter_region( &mut self, name: &str, ) -> Result<RegionGuard<'_>, VisitError>
If Visitor::is_reading, find a node with the given name that is a child of the current node, and return a Visitor for the found node. Return an error if no node with that name exists.
If not reading, create a node with the given name as a chld of the current node, and return a visitor for the new node. Return an error if a node with that name already exists.
Return a string representing all the regions from the root to the current node.
Sourcepub fn current_region(&self) -> Result<&str, PoolError>
pub fn current_region(&self) -> Result<&str, PoolError>
The name of the current region. This should never be None if the Visitor is operating normally,
because there should be no way to leave the initial __ROOT__ region.
Sourcepub fn debug_to<W>(&self, w: &mut W) -> Result<(), VisitError>where
W: Write,
pub fn debug_to<W>(&self, w: &mut W) -> Result<(), VisitError>where
W: Write,
Write the content of the current node in human-readable form.
Sourcepub fn save_ascii_to_string(&self) -> String
pub fn save_ascii_to_string(&self) -> String
Create a string containing all the data of this Visitor in ascii form. The string is formatted to be human-readable with each node on its own line and tabs to indent child nodes.
Sourcepub fn save_ascii_to_file(
&self,
path: impl AsRef<Path>,
) -> Result<(), VisitError>
pub fn save_ascii_to_file( &self, path: impl AsRef<Path>, ) -> Result<(), VisitError>
Create a string containing all the data of this Visitor in ascii form and saves it to the given path. The string is formatted to be human-readable with each node on its own line and tabs to indent child nodes.
Sourcepub fn save_ascii_to_memory(&self, dest: impl Write) -> Result<(), VisitError>
pub fn save_ascii_to_memory(&self, dest: impl Write) -> Result<(), VisitError>
Create a string containing all the data of this Visitor in ascii form and writes it to the given writer. The string is formatted to be human-readable with each node on its own line and tabs to indent child nodes.
Sourcepub fn save_binary_to_memory(&self, dest: impl Write) -> Result<(), VisitError>
pub fn save_binary_to_memory(&self, dest: impl Write) -> Result<(), VisitError>
Write the data of this Visitor to the given writer. Begin by writing Visitor::MAGIC_BINARY_CURRENT.
Sourcepub fn save_binary_to_vec(&self) -> Result<Vec<u8>, VisitError>
pub fn save_binary_to_vec(&self) -> Result<Vec<u8>, VisitError>
Encode the data of this visitor into bytes and push the bytes into the given Vec<u8>.
Begin by writing Visitor::MAGIC_BINARY_CURRENT.
Sourcepub fn save_binary_to_file(
&self,
path: impl AsRef<Path>,
) -> Result<(), VisitError>
pub fn save_binary_to_file( &self, path: impl AsRef<Path>, ) -> Result<(), VisitError>
Create a file at the given path and write the data of this visitor into that file in a non-human-readable binary format so that the data can be reconstructed using Visitor::load_binary_from_file. Begin by writing Visitor::MAGIC_BINARY_CURRENT.
Trait Implementations§
Source§impl Deref for RegionGuard<'_>
impl Deref for RegionGuard<'_>
Source§impl DerefMut for RegionGuard<'_>
impl DerefMut for RegionGuard<'_>
Auto Trait Implementations§
impl<'a> Freeze for RegionGuard<'a>
impl<'a> !RefUnwindSafe for RegionGuard<'a>
impl<'a> !Send for RegionGuard<'a>
impl<'a> !Sync for RegionGuard<'a>
impl<'a> Unpin for RegionGuard<'a>
impl<'a> !UnwindSafe for RegionGuard<'a>
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
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
Source§impl<T, U> ObjectOrVariant<T> for Uwhere
PhantomData<U>: ObjectOrVariantHelper<T, U>,
impl<T, U> ObjectOrVariant<T> for Uwhere
PhantomData<U>: ObjectOrVariantHelper<T, U>,
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.