In Files

  • rinda/rinda.rb




Templates are used to match tuples in Rinda.

Public Instance Methods

===(tuple) click to toggle source

Alias for match.

               # File rinda/rinda.rb, line 169
def ===(tuple)
match(tuple) click to toggle source

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 ===.[:foo, 5]).match[:foo, 5]) # => true[:foo, nil]).match[:foo, 5]) # => true[String]).match['hello']) # => true[:foo]).match[:foo, 5]) # => false[:foo, 6]).match[:foo, 5]) # => false[:foo, nil]).match[:foo])    # => false[:foo, 6]).match[:foo])    # => false
               # File rinda/rinda.rb, line 148
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|
      it = tuple.fetch(k)
      return false
    next if v.nil?
    next if v == it
    next if v === it
    return false
  return true

Commenting is here to help enhance the documentation. For example, code samples, or clarification of the documentation.

If you have questions about Ruby or the documentation, please post to one of the Ruby mailing lists. You will get better, faster, help that way.

If you wish to post a correction of the docs, please do so, but also file bug report so that it can be corrected for the next release. Thank you.

If you want to help improve the Ruby documentation, please visit