aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/lib
diff options
context:
space:
mode:
authorSean Griffin <sean@seantheprogrammer.com>2015-10-20 15:04:05 -0600
committerSean Griffin <sean@seantheprogrammer.com>2015-10-20 15:04:05 -0600
commit7b92798d2fee012bf683c513fb3864a9143a6f71 (patch)
tree85573c9f8661cddb06011da1b76517ebf8f1d175 /activesupport/lib
parent3e29d96ecda48a287601ec09321f7444df8266be (diff)
parent47ab9a04d3317d7d42c7b2e5709b8e861422ebc3 (diff)
downloadrails-7b92798d2fee012bf683c513fb3864a9143a6f71.tar.gz
rails-7b92798d2fee012bf683c513fb3864a9143a6f71.tar.bz2
rails-7b92798d2fee012bf683c513fb3864a9143a6f71.zip
Merge pull request #21302 from theunraveler/delegate_reserved_argument_names
ActiveSupport: Fixing issue when delegating to methods named "block", "args", or "arg"
Diffstat (limited to 'activesupport/lib')
-rw-r--r--activesupport/lib/active_support/core_ext/module/delegation.rb11
1 files changed, 6 insertions, 5 deletions
diff --git a/activesupport/lib/active_support/core_ext/module/delegation.rb b/activesupport/lib/active_support/core_ext/module/delegation.rb
index 9dc0dee1bd..0d46248582 100644
--- a/activesupport/lib/active_support/core_ext/module/delegation.rb
+++ b/activesupport/lib/active_support/core_ext/module/delegation.rb
@@ -5,10 +5,11 @@ class Module
# option is not used.
class DelegationError < NoMethodError; end
- RUBY_RESERVED_WORDS = Set.new(
- %w(alias and BEGIN begin break case class def defined? do else elsif END
- end ensure false for if in module next nil not or redo rescue retry
- return self super then true undef unless until when while yield)
+ DELEGATION_RESERVED_METHOD_NAMES = Set.new(
+ %w(_ arg args alias and BEGIN begin block break case class def defined? do
+ else elsif END end ensure false for if in module next nil not or redo
+ rescue retry return self super then true undef unless until when while
+ yield)
).freeze
# Provides a +delegate+ class method to easily expose contained objects'
@@ -171,7 +172,7 @@ class Module
line = line.to_i
to = to.to_s
- to = "self.#{to}" if RUBY_RESERVED_WORDS.include?(to)
+ to = "self.#{to}" if DELEGATION_RESERVED_METHOD_NAMES.include?(to)
methods.each do |method|
# Attribute writer methods only accept one argument. Makes sure []=