diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-05-08 12:02:17 -0700 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-05-08 12:02:17 -0700 |
commit | f4c96fe2fcb779ca881a03b8704ec28b1afaf8f3 (patch) | |
tree | ec1552da1cc672c458b3e0e97348cce44fba1cfc /activemodel/lib | |
parent | 1ff1236b079d379bbf0ceaf19d7efc3ee97d0406 (diff) | |
parent | eb93d16e49e0582a42b9f1460c41b517dd7044b3 (diff) | |
download | rails-f4c96fe2fcb779ca881a03b8704ec28b1afaf8f3.tar.gz rails-f4c96fe2fcb779ca881a03b8704ec28b1afaf8f3.tar.bz2 rails-f4c96fe2fcb779ca881a03b8704ec28b1afaf8f3.zip |
Merge pull request #10524 from wangjohn/define_method_for_callbacks
Using define method instead of class eval when defining model callbacks.
Diffstat (limited to 'activemodel/lib')
-rw-r--r-- | activemodel/lib/active_model/callbacks.rb | 30 |
1 files changed, 12 insertions, 18 deletions
diff --git a/activemodel/lib/active_model/callbacks.rb b/activemodel/lib/active_model/callbacks.rb index 16188aec6b..94d2181e4d 100644 --- a/activemodel/lib/active_model/callbacks.rb +++ b/activemodel/lib/active_model/callbacks.rb @@ -120,30 +120,24 @@ module ActiveModel private def _define_before_model_callback(klass, callback) #:nodoc: - klass.class_eval <<-CALLBACK, __FILE__, __LINE__ + 1 - def self.before_#{callback}(*args, &block) - set_callback(:#{callback}, :before, *args, &block) - end - CALLBACK + klass.define_singleton_method("before_#{callback}") do |*args, &block| + set_callback(:"#{callback}", :before, *args, &block) + end end def _define_around_model_callback(klass, callback) #:nodoc: - klass.class_eval <<-CALLBACK, __FILE__, __LINE__ + 1 - def self.around_#{callback}(*args, &block) - set_callback(:#{callback}, :around, *args, &block) - end - CALLBACK + klass.define_singleton_method("around_#{callback}") do |*args, &block| + set_callback(:"#{callback}", :around, *args, &block) + end end def _define_after_model_callback(klass, callback) #:nodoc: - klass.class_eval <<-CALLBACK, __FILE__, __LINE__ + 1 - def self.after_#{callback}(*args, &block) - options = args.extract_options! - options[:prepend] = true - options[:if] = Array(options[:if]) << "value != false" - set_callback(:#{callback}, :after, *(args << options), &block) - end - CALLBACK + klass.define_singleton_method("after_#{callback}") do |*args, &block| + options = args.extract_options! + options[:prepend] = true + options[:if] = Array(options[:if]) << "value != false" + set_callback(:"#{callback}", :after, *(args << options), &block) + end end end end |