Class: Fast::Find

Inherits:
Object
  • Object
show all
Defined in:
lib/fast.rb

Overview

Find is the top level class that respond to #match?(node) interface. It matches recurively and check deeply depends of the token type.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(token) ⇒ Find

Returns a new instance of Find.



342
343
344
# File 'lib/fast.rb', line 342

def initialize(token)
  self.token = token
end

Instance Attribute Details

#tokenObject

Returns the value of attribute token.



341
342
343
# File 'lib/fast.rb', line 341

def token
  @token
end

Instance Method Details

#==(other) ⇒ Object



389
390
391
392
393
# File 'lib/fast.rb', line 389

def ==(other)
  return false if other.nil? || !other.respond_to?(:token)

  token == other.token
end

#compare_symbol_or_head(expression, node) ⇒ Object



364
365
366
367
368
369
370
371
372
373
# File 'lib/fast.rb', line 364

def compare_symbol_or_head(expression, node)
  case node
  when Parser::AST::Node
    node.type == expression.to_sym
  when String
    node == expression.to_s
  else
    node == expression
  end
end

#debug(expression, node, match) ⇒ Object



381
382
383
# File 'lib/fast.rb', line 381

def debug(expression, node, match)
  puts "#{expression} == #{node} # => #{match}"
end

#debug_match_recursive(expression, node) ⇒ Object



375
376
377
378
379
# File 'lib/fast.rb', line 375

def debug_match_recursive(expression, node)
  match = original_match_recursive(expression, node)
  debug(expression, node, match)
  match
end

#match?(node) ⇒ Boolean

Returns:

  • (Boolean)


346
347
348
# File 'lib/fast.rb', line 346

def match?(node)
  match_recursive(valuate(token), node)
end

#match_recursive(expression, node) ⇒ Object



350
351
352
353
354
355
356
357
358
359
360
361
362
# File 'lib/fast.rb', line 350

def match_recursive(expression, node)
  case expression
  when Proc then expression.call(node)
  when Find then expression.match?(node)
  when Symbol then compare_symbol_or_head(expression, node)
  when Enumerable
    expression.each_with_index.all? do |exp, i|
      match_recursive(exp, i.zero? ? node : node.children[i - 1])
    end
  else
    node == expression
  end
end

#to_sObject



385
386
387
# File 'lib/fast.rb', line 385

def to_s
  "f[#{[*token].map(&:to_s).join(', ')}]"
end