Sha256: 1d0d0c179353513e7adf985a7fc1f763cfbbfd8f143b237c71e59f98e500c384

Contents?: true

Size: 1.9 KB

Versions: 13

Compression:

Stored size: 1.9 KB

Contents

# frozen_string_literal: true
require 'bundler/vendor/molinillo/lib/molinillo/dependency_graph/action'
module Bundler::Molinillo
  class DependencyGraph
    # @!visibility private
    # (see DependencyGraph#add_edge_no_circular)
    class AddEdgeNoCircular < Action
      # @!group Action

      # (see Action.action_name)
      def self.action_name
        :add_vertex
      end

      # (see Action#up)
      def up(graph)
        edge = make_edge(graph)
        edge.origin.outgoing_edges << edge
        edge.destination.incoming_edges << edge
        edge
      end

      # (see Action#down)
      def down(graph)
        edge = make_edge(graph)
        delete_first(edge.origin.outgoing_edges, edge)
        delete_first(edge.destination.incoming_edges, edge)
      end

      # @!group AddEdgeNoCircular

      # @return [String] the name of the origin of the edge
      attr_reader :origin

      # @return [String] the name of the destination of the edge
      attr_reader :destination

      # @return [Object] the requirement that the edge represents
      attr_reader :requirement

      # @param  [DependencyGraph] graph the graph to find vertices from
      # @return [Edge] The edge this action adds
      def make_edge(graph)
        Edge.new(graph.vertex_named(origin), graph.vertex_named(destination), requirement)
      end

      # 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
      def initialize(origin, destination, requirement)
        @origin = origin
        @destination = destination
        @requirement = requirement
      end

      private

      def delete_first(array, item)
        return unless index = array.index(item)
        array.delete_at(index)
      end
    end
  end
end

Version data entries

13 entries across 13 versions & 2 rubygems

Version Path
bundler-1.15.4 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.3 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.2 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.1 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.0 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.0.pre.4 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
enju_leaf-1.2.1 vendor/bundle/ruby/2.3/gems/bundler-1.14.6/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.0.pre.3 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.0.pre.2 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.15.0.pre.1 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.14.6 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.14.5 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.14.4 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb