diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-02-22 14:14:42 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-02-22 14:14:42 +0000 |
commit | e2724aa1856253f4fc48ddc251583042c5f06029 (patch) | |
tree | 65fe55277e080282e6e2306f31a23d369a854aa1 /actionpack | |
parent | 752f9ab8739bef4d7acab21af5858f5d5d9db6eb (diff) | |
download | rails-e2724aa1856253f4fc48ddc251583042c5f06029.tar.gz rails-e2724aa1856253f4fc48ddc251583042c5f06029.tar.bz2 rails-e2724aa1856253f4fc48ddc251583042c5f06029.zip |
Made the sharing of request and response safer
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@744 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/lib/action_controller/components.rb | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/actionpack/lib/action_controller/components.rb b/actionpack/lib/action_controller/components.rb index 6371a4255d..d6ee700b09 100644 --- a/actionpack/lib/action_controller/components.rb +++ b/actionpack/lib/action_controller/components.rb @@ -1,4 +1,5 @@ module ActionController #:nodoc: + # TODO: Cookies and session variables set in render_component that happens inside a view should be copied over. module Components #:nodoc: def self.append_features(base) super @@ -14,16 +15,16 @@ module ActionController #:nodoc: protected def render_component(options = {}) #:doc: - response = component_response(options) - logger.info "Rendering component (#{options.inspect}): " + response = component_response(options, true) + logger.info "Start rendering component (#{options.inspect}): " result = render_text(response.body, response.headers["Status"]) logger.info("\n\nEnd of component rendering") return result end private - def component_response(options) - component_class(options).process(component_request(options), @response) + def component_response(options, reuse_response = false) + component_class(options).process(component_request(options), reuse_response ? @response : component_response) end def component_class(options) @@ -31,12 +32,16 @@ module ActionController #:nodoc: end def component_request(options) - component_request = @request.dup + component_request = Marshal::load(Marshal::dump(@request)) component_request.send( :instance_variable_set, :@parameters, (options[:params] || {}).merge({ "controller" => options[:controller], "action" => options[:action] }) ) return component_request end + + def component_response + Marshal::load(Marshal::dump(@response)) + end end end |