Struct xml::namespace::NamespaceStack [] [src]

pub struct NamespaceStack(pub Vec<Namespace>);

Namespace stack is a sequence of namespaces.

Namespace stack is used to represent cumulative namespace consisting of combined namespaces from nested elements.

Methods

impl NamespaceStack
[src]

fn empty() -> NamespaceStack

Returns an empty namespace stack.

fn default() -> NamespaceStack

Returns a namespace stack with default items in it.

Default items are the following:

  • xmlhttp://www.w3.org/XML/1998/namespace;
  • xmlnshttp://www.w3.org/2000/xmlns/.

fn push_empty(&mut self) -> &mut NamespaceStack

Adds an empty namespace to the top of this stack.

fn pop(&mut self) -> Namespace

Removes the topmost namespace in this stack.

Panics if the stack is empty.

fn try_pop(&mut self) -> Option<Namespace>

Removes the topmost namespace in this stack.

Returns Some(namespace) if this stack is not empty and None otherwise.

fn peek_mut(&mut self) -> &mut Namespace

Borrows the topmost namespace mutably, leaving the stack intact.

Panics if the stack is empty.

fn peek(&self) -> &Namespace

Borrows the topmost namespace immutably, leaving the stack intact.

Panics if the stack is empty.

fn put_checked<P, U>(&mut self, prefix: P, uri: U) -> bool where P: Into<String> + AsRef<str>, U: Into<String> + AsRef<str>

Puts a mapping into the topmost namespace if this stack does not already contain one.

Returns a boolean flag indicating whether the insertion has completed successfully. Note that both key and value are matched and the mapping is inserted if either namespace prefix is not already mapped, or if it is mapped, but to a different URI.

Parameters

  • prefix --- namespace prefix;
  • uri --- namespace URI.

Return value

true if prefix has been inserted successfully; false if the prefix was already present in the namespace stack.

fn put<P, U>(&mut self, prefix: P, uri: U) -> bool where P: Into<String>, U: Into<String>

Puts a mapping into the topmost namespace in this stack.

This method does not override a mapping in the topmost namespace if it is already present, however, it does not depend on other namespaces in the stack, so it is possible to put a mapping which is present in lower namespaces.

Returns a boolean flag indicating whether the insertion has completed successfully.

Parameters

  • prefix --- namespace prefix;
  • uri --- namespace URI.

Return value

true if prefix has been inserted successfully; false if the prefix was already present in the namespace.

fn get<'a, P: ?Sized + AsRef<str>>(&'a self, prefix: &P) -> Option<&'a str>

Performs a search for the given prefix in the whole stack.

This method walks the stack from top to bottom, querying each namespace in order for the given prefix. If none of the namespaces contains the prefix, None is returned.

Parameters

  • prefix --- namespace prefix.

fn squash(&self) -> Namespace

Combines this stack of namespaces into a single namespace.

Namespaces are combined in left-to-right order, that is, rightmost namespace elements take priority over leftmost ones.

fn checked_target(&mut self) -> CheckedTarget

Returns an object which implements Extend using put_checked() instead of put().

See CheckedTarget for more information.

fn iter(&self) -> NamespaceStackMappings

Returns an iterator over all mappings in this namespace stack.

Trait Implementations

impl Debug for NamespaceStack
[src]

fn fmt(&self, __arg_0: &mut Formatter) -> Result

Formats the value using the given formatter.

impl PartialEq for NamespaceStack
[src]

fn eq(&self, __arg_0: &NamespaceStack) -> bool

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, __arg_0: &NamespaceStack) -> bool

This method tests for !=.

impl Eq for NamespaceStack
[src]

impl Clone for NamespaceStack
[src]

fn clone(&self) -> NamespaceStack

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)
1.0.0

Performs copy-assignment from source. Read more

impl<'a> IntoIterator for &'a NamespaceStack
[src]

type Item = UriMapping<'a>

The type of the elements being iterated over.

type IntoIter = NamespaceStackMappings<'a>

Which kind of iterator are we turning this into?

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more

impl<'a> Extend<UriMapping<'a>> for NamespaceStack
[src]

fn extend<T>(&mut self, iterable: T) where T: IntoIterator<Item=UriMapping<'a>>

Extends a collection with the contents of an iterator. Read more