aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2013-05-08 12:02:17 -0700
committerRafael Mendonça França <rafaelmfranca@gmail.com>2013-05-08 12:02:17 -0700
commitf4c96fe2fcb779ca881a03b8704ec28b1afaf8f3 (patch)
treeec1552da1cc672c458b3e0e97348cce44fba1cfc
parent1ff1236b079d379bbf0ceaf19d7efc3ee97d0406 (diff)
parenteb93d16e49e0582a42b9f1460c41b517dd7044b3 (diff)
downloadrails-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.
-rw-r--r--activemodel/lib/active_model/callbacks.rb30
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