Sha256: de2314eedd6b14d0973e70e0be3243c04c0a5e4581483b20723861906bf96ab7
Contents?: true
Size: 1.29 KB
Versions: 2
Compression:
Stored size: 1.29 KB
Contents
# frozen_string_literal: true module Tangle # # Protected methods of BaseGraph # module BaseGraphProtected protected def copy_vertices_and_edges(from) @vertices = from.instance_variable_get(:@vertices).dup @vertices_by_name = from.instance_variable_get(:@vertices_by_name).dup @edges = from.instance_variable_get(:@edges).dup end def select_vertices!(selected = nil) vertices.each do |vertex| delete_vertex(vertex) if block_given? && !yield(vertex) next if selected.nil? delete_vertex(vertex) unless selected.any? { |vtx| vtx.eql?(vertex) } end end def insert_vertex(vertex, name = nil) @vertices[vertex] = Set[] @vertices_by_name[name] = vertex unless name.nil? end def delete_vertex(vertex) @vertices[vertex].each do |edge| delete_edge(edge) if edge.include?(vertex) end @vertices.delete(vertex) @vertices_by_name.delete_if { |_, vtx| vtx.eql?(vertex) } end # Insert a prepared edge into the graph # def insert_edge(edge) @edges << edge edge.each_vertex { |vertex| @vertices.fetch(vertex) << edge } end def delete_edge(edge) edge.each_vertex { |vertex| @vertices.fetch(vertex).delete(edge) } @edges.delete(edge) end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
tangle-0.11.0 | lib/tangle/base_graph_protected.rb |
tangle-0.10.2 | lib/tangle/base_graph_protected.rb |