introducing LocalCacheProxy to skip pickling stuff

This commit is contained in:
Laura Klünder 2018-12-27 17:24:53 +01:00
parent 957ce0c0cd
commit 3eeda53ca8
3 changed files with 69 additions and 19 deletions

42
src/c3nav/mapdata/utils/cache/local.py vendored Normal file
View file

@ -0,0 +1,42 @@
from collections import OrderedDict
from django.core.cache import cache
class NoneFromCache:
pass
class LocalCacheProxy:
# django cache, buffered using a LRU cache
# only usable for stuff that never changes, obviously
def __init__(self, maxsize=128):
self._maxsize = maxsize
self._items = OrderedDict()
def get(self, key, default=None):
print('get')
try:
# first check out cache
result = self._items[key]
except KeyError:
# not in our cache
result = cache.get(key, default=NoneFromCache)
if result is not NoneFromCache:
self._items[key] = result
self._prune()
else:
result = default
else:
self._items.move_to_end(key, last=True)
return result
def _prune(self):
# remove old items
while len(self._items) > self._maxsize:
self._items.pop(next(iter(self._items.keys())))
def set(self, key, value, expire):
cache.set(key, value, expire)
self._items[key] = value
self._prune()