mirror of
https://github.com/django/django.git
synced 2025-10-31 09:41:08 +00:00
Fixed #14315 -- Made memcached backend handle negative incr/decr values
Thanks Michael Manfre for the report and initial patch and Tobias McNulty for the review.
This commit is contained in:
6
django/core/cache/backends/memcached.py
vendored
6
django/core/cache/backends/memcached.py
vendored
@@ -90,6 +90,9 @@ class BaseMemcachedCache(BaseCache):
|
||||
|
||||
def incr(self, key, delta=1, version=None):
|
||||
key = self.make_key(key, version=version)
|
||||
# memcached doesn't support a negative delta
|
||||
if delta < 0:
|
||||
return self._cache.decr(key, -delta)
|
||||
try:
|
||||
val = self._cache.incr(key, delta)
|
||||
|
||||
@@ -105,6 +108,9 @@ class BaseMemcachedCache(BaseCache):
|
||||
|
||||
def decr(self, key, delta=1, version=None):
|
||||
key = self.make_key(key, version=version)
|
||||
# memcached doesn't support a negative delta
|
||||
if delta < 0:
|
||||
return self._cache.incr(key, -delta)
|
||||
try:
|
||||
val = self._cache.decr(key, delta)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user