mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Merge pull request #6351 from bogdan/callbacks
AS::Callbacks remove useless code, improve performance
This commit is contained in:
commit
ad8b0a44fd
1 changed files with 3 additions and 16 deletions
|
@ -328,26 +328,17 @@ module ActiveSupport
|
||||||
# if it was not yet defined.
|
# if it was not yet defined.
|
||||||
# This generated method plays caching role.
|
# This generated method plays caching role.
|
||||||
def __define_callbacks(kind, object) #:nodoc:
|
def __define_callbacks(kind, object) #:nodoc:
|
||||||
name = __callback_runner_name(kind)
|
chain = object.send("_#{kind}_callbacks")
|
||||||
|
name = "_run_callbacks_#{chain.object_id}"
|
||||||
unless object.respond_to?(name, true)
|
unless object.respond_to?(name, true)
|
||||||
str = object.send("_#{kind}_callbacks").compile
|
|
||||||
class_eval <<-RUBY_EVAL, __FILE__, __LINE__ + 1
|
class_eval <<-RUBY_EVAL, __FILE__, __LINE__ + 1
|
||||||
def #{name}() #{str} end
|
def #{name}() #{chain.compile} end
|
||||||
protected :#{name}
|
protected :#{name}
|
||||||
RUBY_EVAL
|
RUBY_EVAL
|
||||||
end
|
end
|
||||||
name
|
name
|
||||||
end
|
end
|
||||||
|
|
||||||
def __reset_runner(symbol)
|
|
||||||
name = __callback_runner_name(symbol)
|
|
||||||
undef_method(name) if method_defined?(name)
|
|
||||||
end
|
|
||||||
|
|
||||||
def __callback_runner_name(kind)
|
|
||||||
"_run__#{self.name.hash.abs}__#{kind}__callbacks"
|
|
||||||
end
|
|
||||||
|
|
||||||
# This is used internally to append, prepend and skip callbacks to the
|
# This is used internally to append, prepend and skip callbacks to the
|
||||||
# CallbackChain.
|
# CallbackChain.
|
||||||
#
|
#
|
||||||
|
@ -359,7 +350,6 @@ module ActiveSupport
|
||||||
([self] + ActiveSupport::DescendantsTracker.descendants(self)).reverse.each do |target|
|
([self] + ActiveSupport::DescendantsTracker.descendants(self)).reverse.each do |target|
|
||||||
chain = target.send("_#{name}_callbacks")
|
chain = target.send("_#{name}_callbacks")
|
||||||
yield target, chain.dup, type, filters, options
|
yield target, chain.dup, type, filters, options
|
||||||
target.__reset_runner(name)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -447,12 +437,9 @@ module ActiveSupport
|
||||||
chain = target.send("_#{symbol}_callbacks").dup
|
chain = target.send("_#{symbol}_callbacks").dup
|
||||||
callbacks.each { |c| chain.delete(c) }
|
callbacks.each { |c| chain.delete(c) }
|
||||||
target.send("_#{symbol}_callbacks=", chain)
|
target.send("_#{symbol}_callbacks=", chain)
|
||||||
target.__reset_runner(symbol)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
self.send("_#{symbol}_callbacks=", callbacks.dup.clear)
|
self.send("_#{symbol}_callbacks=", callbacks.dup.clear)
|
||||||
|
|
||||||
__reset_runner(symbol)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Define sets of events in the object lifecycle that support callbacks.
|
# Define sets of events in the object lifecycle that support callbacks.
|
||||||
|
|
Loading…
Reference in a new issue