class TypeProf::Core::AST::LiteralNode::NilNode::TrueNode::FalseNode::IntegerNode::FloatNode::RationalNode::ComplexNode::SymbolNode::InterpolatedSymbolNode::StringNode::InterpolatedStringNode::RegexpNode::InterpolatedRegexpNode::MatchLastLineNode::InterpolatedMatchLastLineNode::RangeNode::ArrayNode
Attributes
elems[R]
splat[R]
Public Class Methods
new(raw_node, lenv, elems = raw_node.elements)
click to toggle source
Calls superclass method
TypeProf::Core::AST::Node::new
# File typeprof-0.30.1/lib/typeprof/core/ast/value.rb, line 235 def initialize(raw_node, lenv, elems = raw_node.elements) super(raw_node, lenv) @elems = elems.map {|n| AST.create_node(n, lenv) } @splat = @elems.any? {|e| e.is_a?(SplatNode) } end
Public Instance Methods
attrs(= { splat: })
click to toggle source
# File typeprof-0.30.1/lib/typeprof/core/ast/value.rb, line 244 def attrs = { splat: } def install0(genv) elems = @elems.map {|e| e.install(genv).new_vertex(genv, self) } unified_elem = Vertex.new(self) elems.each {|vtx| @changes.add_edge(genv, vtx, unified_elem) } base_ty = genv.gen_ary_type(unified_elem) if @splat Source.new(base_ty) else Source.new(Type::Array.new(genv, elems, base_ty)) end end end
install0(genv)
click to toggle source
# File typeprof-0.30.1/lib/typeprof/core/ast/value.rb, line 246 def install0(genv) elems = @elems.map {|e| e.install(genv).new_vertex(genv, self) } unified_elem = Vertex.new(self) elems.each {|vtx| @changes.add_edge(genv, vtx, unified_elem) } base_ty = genv.gen_ary_type(unified_elem) if @splat Source.new(base_ty) else Source.new(Type::Array.new(genv, elems, base_ty)) end end
subnodes(= { elems: })
click to toggle source
# File typeprof-0.30.1/lib/typeprof/core/ast/value.rb, line 243 def subnodes = { elems: } def attrs = { splat: } def install0(genv) elems = @elems.map {|e| e.install(genv).new_vertex(genv, self) } unified_elem = Vertex.new(self) elems.each {|vtx| @changes.add_edge(genv, vtx, unified_elem) } base_ty = genv.gen_ary_type(unified_elem) if @splat Source.new(base_ty) else Source.new(Type::Array.new(genv, elems, base_ty)) end end end class HashNode < Node def initialize(raw_node, lenv, keywords) super(raw_node, lenv) @keys = [] @vals = [] @keywords = keywords @splat = false raw_node.elements.each do |raw_elem| # TODO: Support :assoc_splat_node case raw_elem.type when :assoc_node @keys << AST.create_node(raw_elem.key, lenv) @vals << AST.create_node(raw_elem.value, lenv) when :assoc_splat_node @keys << nil @vals << AST.create_node(raw_elem.value, lenv) @splat = true else raise "unknown hash elem: #{ raw_elem.type }" end end end attr_reader :keys, :vals, :splat, :keywords def subnodes = { keys:, vals: } def attrs = { splat:, keywords: } def install0(genv) unified_key = Vertex.new(self) unified_val = Vertex.new(self) literal_pairs = {} @keys.zip(@vals) do |key, val| if key k = key.install(genv).new_vertex(genv, self) v = val.install(genv).new_vertex(genv, self) @changes.add_edge(genv, k, unified_key) @changes.add_edge(genv, v, unified_val) literal_pairs[key.lit] = v if key.is_a?(SymbolNode) else h = val.install(genv) # TODO: do we want to call to_hash on h? @changes.add_hash_splat_box(genv, h, unified_key, unified_val) end end if @splat Source.new(genv.gen_hash_type(unified_key, unified_val)) else Source.new(Type::Hash.new(genv, literal_pairs, genv.gen_hash_type(unified_key, unified_val))) end end end class LambdaNode < Node def install0(genv) Source.new(genv.proc_type) end end end