DependencyGraph

Struct DependencyGraph 

Source
pub struct DependencyGraph<K: Eq + Hash, V> { /* private fields */ }

Implementations§

Source§

impl<K: Eq + Hash + Clone + Debug, V> DependencyGraph<K, V>

Source

pub fn new() -> DependencyGraph<K, V>

Constructs a dependency graph and populates it with a root node.

Source

pub fn insert_node(&mut self, key: K, data: V)

Insert a node into the graph with |key| and attach |data| to the node.

If the node already exists, it is replaced.

Source

pub fn insert_edge_from_root( &mut self, to: &K, ) -> Result<(), DependencyError<K>>

Inserts an edge from the root of the graph to the node with key |to|.

If |to| doesn’t exist in the graph, return a MissingDependency error.

Source

pub fn insert_edge( &mut self, from: &K, to: &K, ) -> Result<(), DependencyError<K>>

Inserts an edge from the root of the graph from the node with key |from| to the node with key |to|.

If either |from| or |to| doesn’t exist in the graph, return a MissingDependency error.

Source

pub fn resolve(self) -> Result<Vec<V>, DependencyError<K>>

Resolve the dependency graph, returning the data associated with each node in a path from the root node to its dependencies. For each node in the path all of its dependencies must appear after its position in the path. Any node that has no dependency chain from the root is pruned from the path.

If no such path is possible return a CircularDependency error.

Auto Trait Implementations§

§

impl<K, V> Freeze for DependencyGraph<K, V>

§

impl<K, V> RefUnwindSafe for DependencyGraph<K, V>

§

impl<K, V> Send for DependencyGraph<K, V>
where K: Send, V: Send,

§

impl<K, V> Sync for DependencyGraph<K, V>
where K: Sync, V: Sync,

§

impl<K, V> Unpin for DependencyGraph<K, V>
where K: Unpin, V: Unpin,

§

impl<K, V> UnwindSafe for DependencyGraph<K, V>
where K: UnwindSafe, V: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> GetTypeId for T
where T: Any,

Source§

fn typeid(&self) -> TypeId

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.