| Index: client/third_party/cachetools/lru.py | 
| diff --git a/client/third_party/cachetools/lru.py b/client/third_party/cachetools/lru.py | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..b945797c1791a9c5c21f8e00b6d4ffd832673108 | 
| --- /dev/null | 
| +++ b/client/third_party/cachetools/lru.py | 
| @@ -0,0 +1,48 @@ | 
| +from __future__ import absolute_import | 
| + | 
| +import collections | 
| + | 
| +from .cache import Cache | 
| + | 
| + | 
| +class LRUCache(Cache): | 
| +    """Least Recently Used (LRU) cache implementation.""" | 
| + | 
| +    def __init__(self, maxsize, missing=None, getsizeof=None): | 
| +        Cache.__init__(self, maxsize, missing, getsizeof) | 
| +        self.__order = collections.OrderedDict() | 
| + | 
| +    def __getitem__(self, key, cache_getitem=Cache.__getitem__): | 
| +        value = cache_getitem(self, key) | 
| +        self.__update(key) | 
| +        return value | 
| + | 
| +    def __setitem__(self, key, value, cache_setitem=Cache.__setitem__): | 
| +        cache_setitem(self, key, value) | 
| +        self.__update(key) | 
| + | 
| +    def __delitem__(self, key, cache_delitem=Cache.__delitem__): | 
| +        cache_delitem(self, key) | 
| +        del self.__order[key] | 
| + | 
| +    def popitem(self): | 
| +        """Remove and return the `(key, value)` pair least recently used.""" | 
| +        try: | 
| +            key = next(iter(self.__order)) | 
| +        except StopIteration: | 
| +            raise KeyError('%s is empty' % self.__class__.__name__) | 
| +        else: | 
| +            return (key, self.pop(key)) | 
| + | 
| +    if hasattr(collections.OrderedDict, 'move_to_end'): | 
| +        def __update(self, key): | 
| +            try: | 
| +                self.__order.move_to_end(key) | 
| +            except KeyError: | 
| +                self.__order[key] = None | 
| +    else: | 
| +        def __update(self, key): | 
| +            try: | 
| +                self.__order[key] = self.__order.pop(key) | 
| +            except KeyError: | 
| +                self.__order[key] = None | 
|  |