1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/actionpack/lib/action_dispatch/middleware/reloader.rb

90 lines
2.7 KiB
Ruby
Raw Normal View History

module ActionDispatch
2010-12-20 17:55:21 -05:00
# ActionDispatch::Reloader provides prepare and cleanup callbacks,
# intended to assist with code reloading during development.
#
# Prepare callbacks are run before each request, and cleanup callbacks
# after each request. In this respect they are analogs of ActionDispatch::Callback's
# before and after callbacks. However, cleanup callbacks are not called until the
# request is fully complete -- that is, after #close has been called on
2010-12-21 22:32:34 -05:00
# the response body. This is important for streaming responses such as the
# following:
#
# self.response_body = lambda { |response, output|
# # code here which refers to application models
# }
#
# Cleanup callbacks will not be called until after the response_body lambda
# is evaluated, ensuring that it can refer to application models and other
# classes before they are unloaded.
#
# By default, ActionDispatch::Reloader is included in the middleware stack
# only in the development environment; specifically, when +config.cache_classes+
2010-12-20 17:55:21 -05:00
# is false. Callbacks may be registered even when it is not included in the
# middleware stack, but are executed only when <tt>ActionDispatch::Reloader.prepare!</tt>
# or <tt>ActionDispatch::Reloader.cleanup!</tt> are called manually.
#
class Reloader
include ActiveSupport::Callbacks
define_callbacks :prepare, :scope => :name
define_callbacks :cleanup, :scope => :name
2010-12-20 17:55:21 -05:00
# Add a prepare callback. Prepare callbacks are run before each request, prior
# to ActionDispatch::Callback's before callbacks.
def self.to_prepare(*args, &block)
2010-12-20 06:41:49 -05:00
set_callback(:prepare, *args, &block)
end
# Add a cleanup callback. Cleanup callbacks are run after each request is
# complete (after #close is called on the response body).
2010-12-20 06:41:49 -05:00
def self.to_cleanup(*args, &block)
set_callback(:cleanup, *args, &block)
end
2010-12-20 17:55:21 -05:00
# Execute all prepare callbacks.
def self.prepare!
2011-12-12 13:23:13 -05:00
new(nil).prepare!
end
2010-12-20 17:55:21 -05:00
# Execute all cleanup callbacks.
def self.cleanup!
2011-12-12 13:23:13 -05:00
new(nil).cleanup!
end
2011-12-12 13:23:13 -05:00
def initialize(app, condition=nil)
@app = app
2011-12-12 13:23:13 -05:00
@condition = condition || lambda { true }
@validated = true
end
def call(env)
2011-12-12 13:23:13 -05:00
@validated = @condition.call
prepare!
2012-01-16 06:35:44 -05:00
response = @app.call(env)
2012-01-16 06:35:44 -05:00
response[2] = ::Rack::BodyProxy.new(response[2]) { cleanup! }
response
rescue Exception
2011-12-12 13:23:13 -05:00
cleanup!
raise
end
2011-12-12 13:23:13 -05:00
def prepare! #:nodoc:
run_callbacks :prepare if validated?
end
def cleanup! #:nodoc:
run_callbacks :cleanup if validated?
ensure
@validated = true
end
private
def validated? #:nodoc:
@validated
end
end
end