From 0e54954068afeba6611e57e11254c98716602feb Mon Sep 17 00:00:00 2001 From: Elad Alfassa Date: Tue, 25 Jun 2013 00:59:28 +0300 Subject: [PATCH] [tools] Some new APIs in WillieMemory Close issue #294 And we are ready for 4.0 release! --- willie/tools.py | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/willie/tools.py b/willie/tools.py index af23732508..0622bab1be 100644 --- a/willie/tools.py +++ b/willie/tools.py @@ -263,12 +263,23 @@ def __setitem__(self, key, value): self.lock.release() return result - def contains(self, key): + def __contains__(self, key): """ - Check if a key is in the dict. Use this instead of the ``in`` - keyword if you want to be thread-safe. + Check if a key is in the dict, locking it for writes when doing so. """ self.lock.acquire() - result = (key in self) + result = dict.__contains__(self, key) self.lock.release() return result + + def contains(self, key): + """ Backwards compatability with 3.x, use `in` operator instead """ + return self.__contains__(key) + + def lock(): + """ Lock this instance from writes. Useful if you want to iterate """ + return self.lock.acquire() + + def unlock(): + """ Release the write lock """ + return self.lock.release()