Class: Rinda::Template

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

Overview

Templates are used to match tuples in Rinda.

Instance Method Summary collapse

Methods inherited from Tuple

#[], #each, #fetch, #initialize, #size, #value

Constructor Details

This class inherits a constructor from Rinda::Tuple

Instance Method Details

#===(tuple) ⇒ Object

Alias for #match.



170
171
172
# File 'lib/rinda/rinda.rb', line 170

def ===(tuple)
  match(tuple)
end

#match(tuple) ⇒ Object

Matches this template against tuple. The tuple must be the same size as the template. An element with a nil value in a template acts as a wildcard, matching any value in the corresponding position in the tuple. Elements of the template match the tuple if the are #== or #===.

Template.new([:foo, 5]).match   Tuple.new([:foo, 5]) # => true
Template.new([:foo, nil]).match Tuple.new([:foo, 5]) # => true
Template.new([String]).match    Tuple.new(['hello']) # => true

Template.new([:foo]).match      Tuple.new([:foo, 5]) # => false
Template.new([:foo, 6]).match   Tuple.new([:foo, 5]) # => false
Template.new([:foo, nil]).match Tuple.new([:foo])    # => false
Template.new([:foo, 6]).match   Tuple.new([:foo])    # => false


149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
# File 'lib/rinda/rinda.rb', line 149

def match(tuple)
  return false unless tuple.respond_to?(:size)
  return false unless tuple.respond_to?(:fetch)
  return false unless self.size == tuple.size
  each do |k, v|
    begin
      it = tuple.fetch(k)
    rescue
      return false
    end
    next if v.nil?
    next if v == it
    next if v === it
    return false
  end
  return true
end