Sha256: 81335e1877725f0bd5dbe6acb53d7d61b27e53e6a16cda62f810500632d9056d
Contents?: true
Size: 1.91 KB
Versions: 1
Compression:
Stored size: 1.91 KB
Contents
module Steep module AST module Types class Intersection attr_reader :types attr_reader :location def initialize(types:, location: nil) @types = types @location = location end def self.build(types:, location: nil) types.flat_map do |type| if type.is_a?(Intersection) type.types else [type] end end.map do |type| case type when AST::Types::Any return AST::Types::Any.new(location: location) when AST::Types::Bot return AST::Types::Bot.new(location: location) when AST::Types::Top nil else type end end.compact.uniq.yield_self do |tys| if tys.size == 1 tys.first else new(types: tys.sort_by(&:hash), location: location) end end end def ==(other) other.is_a?(Intersection) && other.types == types end def hash self.class.hash ^ types.hash end alias eql? == def subst(s) self.class.build(location: location, types: types.map {|ty| ty.subst(s) }) end def to_s "(#{types.map(&:to_s).sort.join(" & ")})" end def free_variables() @fvs ||= begin set = Set.new types.each do |type| set.merge(type.free_variables) end set end end include Helper::ChildrenLevel def level [0] + level_of_children(types) end def with_location(new_location) self.class.new(types: types, location: new_location) end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
steep-0.27.0 | lib/steep/ast/types/intersection.rb |