Sha256: c0fdffa664266fc47fa6b0daffe93a2bcc859c6947647268b2ff0cefce911d7c

Contents?: true

Size: 1.5 KB

Versions: 92

Compression:

Stored size: 1.5 KB

Contents

# frozen_string_literal: true

require_relative 'action'
module Gem::Resolver::Molinillo
  class DependencyGraph
    # @!visibility private
    # @see DependencyGraph#detach_vertex_named
    class DetachVertexNamed < Action
      # @!group Action

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

      # (see Action#up)
      def up(graph)
        return [] unless @vertex = graph.vertices.delete(name)

        removed_vertices = [@vertex]
        @vertex.outgoing_edges.each do |e|
          v = e.destination
          v.incoming_edges.delete(e)
          if !v.root? && v.incoming_edges.empty?
            removed_vertices.concat graph.detach_vertex_named(v.name)
          end
        end

        @vertex.incoming_edges.each do |e|
          v = e.origin
          v.outgoing_edges.delete(e)
        end

        removed_vertices
      end

      # (see Action#down)
      def down(graph)
        return unless @vertex
        graph.vertices[@vertex.name] = @vertex
        @vertex.outgoing_edges.each do |e|
          e.destination.incoming_edges << e
        end
        @vertex.incoming_edges.each do |e|
          e.origin.outgoing_edges << e
        end
      end

      # @!group DetachVertexNamed

      # @return [String] the name of the vertex to detach
      attr_reader :name

      # Initialize an action to detach a vertex from a dependency graph
      # @param [String] name the name of the vertex to detach
      def initialize(name)
        @name = name
      end
    end
  end
end

Version data entries

92 entries across 92 versions & 1 rubygems

Version Path
rubygems-update-3.2.11 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.10 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.9 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.8 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.7 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.6 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.5 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.4 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.3 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.2 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.1 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb
rubygems-update-3.2.0 lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb