Class: Rigor::AST::TypeNode
- Inherits:
-
Object
- Object
- Rigor::AST::TypeNode
- Includes:
- Node
- Defined in:
- lib/rigor/ast/type_node.rb
Overview
A virtual node that wraps a Rigor::Type. Allows callers to ask “what would the analyzer infer at this position if the value’s type were T?” without constructing a real Prism expression.
Rigor::Scope#type_of(TypeNode.new(t)) MUST return a structurally- equal t. The engine MUST NOT modify or annotate the wrapped type.
Inspired by PHPStan’s TypeExpr (a synthetic Expr that returns a specific Type from $scope->getType). The Rigor counterpart is spelled “TypeNode” to align with Prism’s “Node” suffix convention.
Instance Attribute Summary collapse
-
#type ⇒ Object
readonly
Returns the value of attribute type.
Instance Method Summary collapse
- #==(other) ⇒ Object (also: #eql?)
- #hash ⇒ Object
-
#initialize(type) ⇒ TypeNode
constructor
A new instance of TypeNode.
- #inspect ⇒ Object
Constructor Details
#initialize(type) ⇒ TypeNode
Returns a new instance of TypeNode.
20 21 22 23 24 25 |
# File 'lib/rigor/ast/type_node.rb', line 20 def initialize(type) raise ArgumentError, "TypeNode requires a non-nil Rigor::Type" if type.nil? @type = type freeze end |
Instance Attribute Details
#type ⇒ Object (readonly)
Returns the value of attribute type.
18 19 20 |
# File 'lib/rigor/ast/type_node.rb', line 18 def type @type end |
Instance Method Details
#==(other) ⇒ Object Also known as: eql?
27 28 29 |
# File 'lib/rigor/ast/type_node.rb', line 27 def ==(other) other.is_a?(TypeNode) && type == other.type end |
#hash ⇒ Object
32 33 34 |
# File 'lib/rigor/ast/type_node.rb', line 32 def hash [TypeNode, type].hash end |
#inspect ⇒ Object
36 37 38 |
# File 'lib/rigor/ast/type_node.rb', line 36 def inspect "#<Rigor::AST::TypeNode #{type.describe(:short)}>" end |