Class Bundler::Molinillo::DependencyGraph
In: lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb
Parent: Object

A directed acyclic graph that is tuned to hold named dependencies

Methods

Included Modules

Enumerable TSort

Classes and Modules

Class Bundler::Molinillo::DependencyGraph::Vertex

Constants

Edge = Struct.new(:origin, :destination, :requirement)   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

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

Public Class methods

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.

Public 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

@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.

@return [String] a string suitable for debugging

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

tsort_each_node()

Alias for each

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

[Validate]