Class: Mutant::Expression
- Inherits:
-
Object
- Object
- Mutant::Expression
- Includes:
- AbstractType, Adamantium
- Defined in:
- lib/mutant/expression.rb,
lib/mutant/expression/method.rb,
lib/mutant/expression/methods.rb,
lib/mutant/expression/namespace.rb
Overview
Abstract base class for match expression
Defined Under Namespace
Classes: Method, Methods, Namespace
Constant Summary collapse
- SCOPE_NAME_PATTERN =
/[A-Za-z][A-Za-z\d_]*/.freeze
- METHOD_NAME_PATTERN =
Regexp.union( /[A-Za-z_][A-Za-z\d_]*[!?=]?/, *AST::Types::OPERATOR_METHODS.map(&:to_s) ).freeze
- SCOPE_PATTERN =
/#{SCOPE_NAME_PATTERN}(?:#{SCOPE_OPERATOR}#{SCOPE_NAME_PATTERN})*/.freeze
- REGISTRY =
{}
Instance Attribute Summary collapse
-
#syntax ⇒ String
readonly
private
Return syntax.
Class Method Summary collapse
-
.parse(input) ⇒ Expression
private
Parse input into expression or raise.
-
.try_parse(input) ⇒ Expression?
private
Parse input into expression.
Instance Method Summary collapse
-
#initialize ⇒ Expression
constructor
private
Initialize expression.
-
#match_length(other) ⇒ Fixnum
private
Return match length for expression.
-
#prefix?(other) ⇒ Boolean
private
Test if expression is prefix.
Constructor Details
#initialize ⇒ Expression
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Initialize expression
26 27 28 29 |
# File 'lib/mutant/expression.rb', line 26 def initialize(*) super @syntax = match.to_s end |
Instance Attribute Details
#syntax ⇒ String (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Return syntax
37 38 39 |
# File 'lib/mutant/expression.rb', line 37 def syntax @syntax end |
Class Method Details
.parse(input) ⇒ Expression
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Parse input into expression or raise
90 91 92 |
# File 'lib/mutant/expression.rb', line 90 def self.parse(input) try_parse(input) or raise "Expression: #{input.inspect} is not valid" end |
.try_parse(input) ⇒ Expression?
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Parse input into expression
106 107 108 109 110 111 112 113 114 115 |
# File 'lib/mutant/expression.rb', line 106 def self.try_parse(input) expressions = expressions(input) case expressions.length when 0 when 1 expressions.first else fail "Ambigous expression: #{input.inspect}" end end |
Instance Method Details
#match_length(other) ⇒ Fixnum
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Return match length for expression
47 48 49 50 51 52 53 |
# File 'lib/mutant/expression.rb', line 47 def match_length(other) if eql?(other) syntax.length else 0 end end |
#prefix?(other) ⇒ Boolean
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Test if expression is prefix
63 64 65 |
# File 'lib/mutant/expression.rb', line 63 def prefix?(other) !match_length(other).zero? end |