class Gem::Resolver::Molinillo::DependencyGraph::AddEdgeNoCircular

@!visibility private (see DependencyGraph#add_edge_no_circular)

Attributes

destination[R]

@return [String] the name of the destination of the edge

origin[R]

@return [String] the name of the origin of the edge

requirement[R]

@return [Object] the requirement that the edge represents

Public Class Methods

action_name() click to toggle source

(see Action.action_name)

# File lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb, line 12
def self.action_name
  :add_vertex
end
new(origin, destination, requirement) click to toggle source

Initialize an action to add an edge to a dependency graph @param [String] origin the name of the origin of the edge @param [String] destination the name of the destination of the edge @param [Object] requirement the requirement that the edge represents

# File lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb, line 52
def initialize(origin, destination, requirement)
  @origin = origin
  @destination = destination
  @requirement = requirement
end

Public Instance Methods

down(graph) click to toggle source

(see Action#down)

# File lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb, line 25
def down(graph)
  edge = make_edge(graph)
  delete_first(edge.origin.outgoing_edges, edge)
  delete_first(edge.destination.incoming_edges, edge)
end
make_edge(graph) click to toggle source

@param [DependencyGraph] graph the graph to find vertices from @return [Edge] The edge this action adds

# File lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb, line 44
def make_edge(graph)
  Edge.new(graph.vertex_named(origin), graph.vertex_named(destination), requirement)
end
up(graph) click to toggle source

(see Action#up)

# File lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb, line 17
def up(graph)
  edge = make_edge(graph)
  edge.origin.outgoing_edges << edge
  edge.destination.incoming_edges << edge
  edge
end

Private Instance Methods

delete_first(array, item) click to toggle source
# File lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb, line 60
def delete_first(array, item)
  return unless index = array.index(item)
  array.delete_at(index)
end