diff options
-rw-r--r-- | actionpack/CHANGELOG | 2 | ||||
-rw-r--r-- | actionpack/lib/action_controller/session_management.rb | 47 |
2 files changed, 31 insertions, 18 deletions
diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG index dcf160414f..00bb2f3fd7 100644 --- a/actionpack/CHANGELOG +++ b/actionpack/CHANGELOG @@ -1,5 +1,7 @@ *SVN* +* Speed improvement for session_options. #2287. [skaes@web.de] + * Make cacheing binary files friendly with Windows. #1975. [Rich Olson] * Convert boolean form options form the tag_helper. #809. [Michael Schuerig <michael@schuerig.de>] diff --git a/actionpack/lib/action_controller/session_management.rb b/actionpack/lib/action_controller/session_management.rb index b0a457932d..6752d66e85 100644 --- a/actionpack/lib/action_controller/session_management.rb +++ b/actionpack/lib/action_controller/session_management.rb @@ -77,26 +77,36 @@ module ActionController #:nodoc: write_inheritable_array("session_options", [options]) end + def cached_session_options + @session_options ||= read_inheritable_attribute("session_options") || [] + end + def session_options_for(request, action) #:nodoc: - options = {} + if (session_options = cached_session_options).empty? + {} + else + options = {} - action = action.to_s - (read_inheritable_attribute("session_options") || []).each do |opts| - next if opts[:if] && !opts[:if].call(request) - if opts[:only] && opts[:only].include?(action) - options.merge!(opts) - elsif opts[:except] && !opts[:except].include?(action) - options.merge!(opts) - elsif !opts[:only] && !opts[:except] - options.merge!(opts) + action = action.to_s + session_options.each do |opts| + next if opts[:if] && !opts[:if].call(request) + if opts[:only] && opts[:only].include?(action) + options.merge!(opts) + elsif opts[:except] && !opts[:except].include?(action) + options.merge!(opts) + elsif !opts[:only] && !opts[:except] + options.merge!(opts) + end + end + + if options.empty? then options + else + options.delete :only + options.delete :except + options.delete :if + options[:disabled] ? false : options end end - - options.delete :only - options.delete :except - options.delete :if - - options[:disabled] ? false : options end end @@ -108,8 +118,9 @@ module ActionController #:nodoc: private def clear_persistant_model_associations #:doc: - session = @session.instance_variable_get("@data") - session.each { |key, obj| obj.clear_association_cache if obj.respond_to?(:clear_association_cache) } if session + if session = @session.instance_variable_get("@data") + session.each { |key, obj| obj.clear_association_cache if obj.respond_to?(:clear_association_cache) } + end end end end |