A directed acyclic graph that is tuned to hold named dependencies

Constants

A directed edge of a {DependencyGraph} @attr [Vertex] origin The origin of the directed edge @attr [Vertex] destination The destination of the directed edge @attr [Object] requirement The requirement the directed edge represents

Attributes
Read

@return [{String => Vertex}] the vertices of the dependency graph, keyed

by {Vertex#name}
Class Methods

Initializes an empty dependency graph

Topologically sorts the given vertices. @param [Enumerable<Vertex>] vertices the vertices to be sorted, which must

all belong to the same graph.

@return [Array<Vertex>] The sorted vertices.

Instance Methods

@return [Boolean] whether the two dependency graphs are equal, determined

by a recursive traversal of each {#root_vertices} and its
{Vertex#successors}

@param [String] name @param [Object] payload @param [Array<String>] parent_names @param [Object] requirement the requirement that is requiring the child @return [void]

Adds a new {Edge} to the dependency graph @param [Vertex] origin @param [Vertex] destination @param [Object] requirement the requirement that this edge represents @return [Edge] the added edge

Adds a new {Edge} to the dependency graph without checking for circularity.

Adds a vertex with the given name, or updates the existing one. @param [String] name @param [Object] payload @return [Vertex] the vertex that was added to ‘self`

Detaches the {#vertex_named} ‘name` {Vertex} from the graph, recursively removing any non-root vertices that were orphaned in the process @param [String] name @return [void]

Enumerates through the vertices of the graph. @return [Array<Vertex>] The graph’s vertices.

Initializes a copy of a {DependencyGraph}, ensuring that all {#vertices} are properly copied. @param [DependencyGraph] other the graph to copy.

@return [String] a string suitable for debugging

@param [String] name @return [Vertex,nil] the root vertex with the given name

@visibility private

An alias for each

@param [String] name @return [Vertex,nil] the vertex with the given name