diff options
author | wangjohn <wangjohn@mit.edu> | 2013-04-27 01:07:20 -0400 |
---|---|---|
committer | wangjohn <wangjohn@mit.edu> | 2013-04-28 07:36:34 -0400 |
commit | 3182295ce2fa01b02cb9af0b977a9cf83cc5d9aa (patch) | |
tree | dcc01546081b14e1becba8f34218c21e84f5f6c4 /activesupport | |
parent | 607f136d52e984323cbe2938c04c660ca55a5039 (diff) | |
download | rails-3182295ce2fa01b02cb9af0b977a9cf83cc5d9aa.tar.gz rails-3182295ce2fa01b02cb9af0b977a9cf83cc5d9aa.tar.bz2 rails-3182295ce2fa01b02cb9af0b977a9cf83cc5d9aa.zip |
Making the retrieval of the cache store class a method, also wrote
comments for the expand_cache_key method.
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/lib/active_support/cache.rb | 33 |
1 files changed, 23 insertions, 10 deletions
diff --git a/activesupport/lib/active_support/cache.rb b/activesupport/lib/active_support/cache.rb index 2368e5ebd4..6c220ae625 100644 --- a/activesupport/lib/active_support/cache.rb +++ b/activesupport/lib/active_support/cache.rb @@ -56,16 +56,7 @@ module ActiveSupport case store when Symbol - store_class_name = store.to_s.camelize - store_class = - begin - require "active_support/cache/#{store}" - rescue LoadError => e - raise "Could not find cache store adapter for #{store} (#{e})" - else - ActiveSupport::Cache.const_get(store_class_name) - end - store_class.new(*parameters) + retrieve_store_class(store).new(*parameters) when nil ActiveSupport::Cache::MemoryStore.new else @@ -73,6 +64,18 @@ module ActiveSupport end end + # Expands out the +key+ argument into a key that can be used for the + # cache store. Optionally accepts a namespace, and all keys will be + # scoped within that namespace. + # + # If the +key+ argument provided is an array, or responds to +to_a+, then + # each of elements in the array will be turned into parameters/keys and + # concatenated into a single key. For example: + # + # expand_cache_key([:foo, :bar]) # => "foo/bar" + # expand_cache_key([:foo, :bar], "namespace") # => "namespace/foo/bar" + # + # The +key+ argument can also respond to +cache_key+ or +to_param+. def expand_cache_key(key, namespace = nil) expanded_cache_key = namespace ? "#{namespace}/" : "" @@ -94,6 +97,16 @@ module ActiveSupport else key.to_param end.to_s end + + # Obtains the specified cache store class, given the name of the +store+. + # Raises an error when the store class cannot be found. + def retrieve_store_class(store) + require "active_support/cache/#{store}" + rescue LoadError => e + raise "Could not find cache store adapter for #{store} (#{e})" + else + ActiveSupport::Cache.const_get(store.to_s.camelize) + end end # An abstract cache store class. There are multiple cache store |