diff options
author | Yehuda Katz <wycats@gmail.com> | 2011-11-26 18:10:48 -0800 |
---|---|---|
committer | Yehuda Katz <wycats@gmail.com> | 2011-11-26 18:10:48 -0800 |
commit | 3c81fc3b91ddfd4d115a7001640588eb93249261 (patch) | |
tree | f76041fde5e2dc1e15e5130658a33d32682df8b8 | |
parent | 71b387d91e7d74ad3b90db7b9b9264936d6d3c4d (diff) | |
parent | ebf69ab1636df74c76332c53bcd3d8494fb91b45 (diff) | |
download | rails-3c81fc3b91ddfd4d115a7001640588eb93249261.tar.gz rails-3c81fc3b91ddfd4d115a7001640588eb93249261.tar.bz2 rails-3c81fc3b91ddfd4d115a7001640588eb93249261.zip |
Merge pull request #3767 from tadast/object_in
Object#in? also accepts multiple parameters
-rw-r--r-- | activesupport/lib/active_support/core_ext/object/inclusion.rb | 24 | ||||
-rw-r--r-- | activesupport/test/core_ext/object/inclusion_test.rb | 10 |
2 files changed, 27 insertions, 7 deletions
diff --git a/activesupport/lib/active_support/core_ext/object/inclusion.rb b/activesupport/lib/active_support/core_ext/object/inclusion.rb index b5671f66d0..f611cdd606 100644 --- a/activesupport/lib/active_support/core_ext/object/inclusion.rb +++ b/activesupport/lib/active_support/core_ext/object/inclusion.rb @@ -1,15 +1,25 @@ class Object - # Returns true if this object is included in the argument. Argument must be - # any object which responds to +#include?+. Usage: + # Returns true if this object is included in the argument(s). Argument must be + # any object which responds to +#include?+ or optionally, multiple arguments can be passed in. Usage: # # characters = ["Konata", "Kagami", "Tsukasa"] # "Konata".in?(characters) # => true + # + # character = "Konata" + # character.in?("Konata", "Kagami", "Tsukasa") # => true # - # This will throw an ArgumentError if the argument doesn't respond + # This will throw an ArgumentError if a single argument is passed in and it doesn't respond # to +#include?+. - def in?(another_object) - another_object.include?(self) - rescue NoMethodError - raise ArgumentError.new("The parameter passed to #in? must respond to #include?") + def in?(*args) + if args.length > 1 + args.include? self + else + another_object = args.first + if another_object.respond_to? :include? + another_object.include? self + else + raise ArgumentError.new("The single parameter passed to #in? must respond to #include?") + end + end end end diff --git a/activesupport/test/core_ext/object/inclusion_test.rb b/activesupport/test/core_ext/object/inclusion_test.rb index 1de857d678..568ebe9aab 100644 --- a/activesupport/test/core_ext/object/inclusion_test.rb +++ b/activesupport/test/core_ext/object/inclusion_test.rb @@ -2,6 +2,16 @@ require 'abstract_unit' require 'active_support/core_ext/object/inclusion' class InTest < Test::Unit::TestCase + def test_in_multiple_args + assert :b.in?(:a,:b) + assert !:c.in?(:a,:b) + end + + def test_in_multiple_arrays + assert [1,2].in?([1,2],[2,3]) + assert ![1,2].in?([1,3],[2,1]) + end + def test_in_array assert 1.in?([1,2]) assert !3.in?([1,2]) |