aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/lib
diff options
context:
space:
mode:
authorPavel Pravosud <pavel@pravosud.com>2014-07-29 13:50:56 -0400
committerPavel Pravosud <pavel@pravosud.com>2014-07-29 16:11:48 -0400
commit0cb3cc4ff794b9c3e92afa97a6d3c8e3acbf16ac (patch)
tree260ed53e89080d117f00c537301f178263d3098a /activesupport/lib
parentd035124a20e2964074441fb1d4f7b4865eccc1fa (diff)
downloadrails-0cb3cc4ff794b9c3e92afa97a6d3c8e3acbf16ac.tar.gz
rails-0cb3cc4ff794b9c3e92afa97a6d3c8e3acbf16ac.tar.bz2
rails-0cb3cc4ff794b9c3e92afa97a6d3c8e3acbf16ac.zip
Add implicit receiver support to `Object#with_options`
Diffstat (limited to 'activesupport/lib')
-rw-r--r--activesupport/lib/active_support/core_ext/object/with_options.rb17
1 files changed, 15 insertions, 2 deletions
diff --git a/activesupport/lib/active_support/core_ext/object/with_options.rb b/activesupport/lib/active_support/core_ext/object/with_options.rb
index 42e388b065..42e87c4424 100644
--- a/activesupport/lib/active_support/core_ext/object/with_options.rb
+++ b/activesupport/lib/active_support/core_ext/object/with_options.rb
@@ -34,9 +34,22 @@ class Object
# body i18n.t :body, user_name: user.name
# end
#
+ # When you don't pass an explicit receiver, it executes the whole block
+ # in merging options context:
+ #
+ # class Account < ActiveRecord::Base
+ # with_options dependent: :destroy do
+ # has_many :customers
+ # has_many :products
+ # has_many :invoices
+ # has_many :expenses
+ # end
+ # end
+ #
# <tt>with_options</tt> can also be nested since the call is forwarded to its receiver.
# Each nesting level will merge inherited defaults in addition to their own.
- def with_options(options)
- yield ActiveSupport::OptionMerger.new(self, options)
+ def with_options(options, &block)
+ option_merger = ActiveSupport::OptionMerger.new(self, options)
+ block.arity.zero? ? option_merger.instance_eval(&block) : block.call(option_merger)
end
end