diff options
author | Carlos Antonio da Silva <carlosantoniodasilva@gmail.com> | 2013-04-17 16:08:34 -0700 |
---|---|---|
committer | Carlos Antonio da Silva <carlosantoniodasilva@gmail.com> | 2013-04-17 16:08:34 -0700 |
commit | 1c9136ddd2003923edb94c85447ab9272131794a (patch) | |
tree | 5d425cea250477e8389000a2b304d13ac1b150e7 | |
parent | e12f39f37407975f61e35dbbad583bc825ef4df8 (diff) | |
parent | fdb3e7341157f618f65683d08e1a55981a5d91d2 (diff) | |
download | rails-1c9136ddd2003923edb94c85447ab9272131794a.tar.gz rails-1c9136ddd2003923edb94c85447ab9272131794a.tar.bz2 rails-1c9136ddd2003923edb94c85447ab9272131794a.zip |
Merge pull request #10255 from wangjohn/increment_or_decrement_refactoring_in_local_cache
Refactoring increment and decrement in local cache
-rw-r--r-- | activesupport/lib/active_support/cache/strategy/local_cache.rb | 32 |
1 files changed, 14 insertions, 18 deletions
diff --git a/activesupport/lib/active_support/cache/strategy/local_cache.rb b/activesupport/lib/active_support/cache/strategy/local_cache.rb index 392c9283d7..fb42c4a41e 100644 --- a/activesupport/lib/active_support/cache/strategy/local_cache.rb +++ b/activesupport/lib/active_support/cache/strategy/local_cache.rb @@ -106,29 +106,13 @@ module ActiveSupport def increment(name, amount = 1, options = nil) # :nodoc: value = bypass_local_cache{super} - if local_cache - local_cache.mute do - if value - local_cache.write(name, value, options) - else - local_cache.delete(name, options) - end - end - end + increment_or_decrement(value, name, amount, options) value end def decrement(name, amount = 1, options = nil) # :nodoc: value = bypass_local_cache{super} - if local_cache - local_cache.mute do - if value - local_cache.write(name, value, options) - else - local_cache.delete(name, options) - end - end - end + increment_or_decrement(value, name, amount, options) value end @@ -157,6 +141,18 @@ module ActiveSupport end private + def increment_or_decrement(value, name, amount, options) + if local_cache + local_cache.mute do + if value + local_cache.write(name, value, options) + else + local_cache.delete(name, options) + end + end + end + end + def local_cache_key @local_cache_key ||= "#{self.class.name.underscore}_local_cache_#{object_id}".gsub(/[\/-]/, '_').to_sym end |