Sha256: acc9a86925b1cb413bc40e4a91db00cc6738bb135273187546ee04ed75170427

Contents?: true

Size: 1.9 KB

Versions: 46

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

46 entries across 46 versions & 3 rubygems

Version Path
rubygems-update-3.0.9 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-2.7.11 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.8 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.7 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.6 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.5 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.4 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-2.7.10 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-2.0.2 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-2.7.9 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.3 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-2.0.1 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-2.0.0 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.2 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-2.0.0.pre.3 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.17.3 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.1 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
rubygems-update-3.0.0 bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-1.17.2 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb
bundler-2.0.0.pre.2 lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb