From b66c716ad606ebe92ee8cc27f2e3dc2a34d50855 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Anders=20Fredrik=20Ki=C3=A6r?= <31612826+anders-kiaer@users.noreply.github.com> Date: Wed, 11 Dec 2019 10:00:01 +0100 Subject: [PATCH] Support mutable objects in webviz-store (#167) --- webviz_config/webviz_store.py | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/webviz_config/webviz_store.py b/webviz_config/webviz_store.py index e89a7e66..638ba6e3 100644 --- a/webviz_config/webviz_store.py +++ b/webviz_config/webviz_store.py @@ -16,7 +16,7 @@ class WebvizStorage: def __init__(self): self._use_storage = False self.storage_functions = set() - self.storage_function_argvalues = defaultdict(set) + self.storage_function_argvalues = defaultdict(dict) def register_function(self, func): """This function is automatically called by the function @@ -61,13 +61,15 @@ def register_function_arguments(self, functionarguments): """ for func, arglist in functionarguments: - argtuples = [ - WebvizStorage._dict_to_tuples(WebvizStorage.complete_kwargs(func, args)) - for args in arglist - ] - undec_func = WebvizStorage._undecorate(func) - self.storage_function_argvalues[undec_func].update(argtuples) + for args in arglist: + argtuples = WebvizStorage._dict_to_tuples( + WebvizStorage.complete_kwargs(func, args) + ) + if repr(argtuples) not in self.storage_function_argvalues[undec_func]: + self.storage_function_argvalues[undec_func][ + repr(argtuples) + ] = argtuples def _unique_path(self, func, argtuples): """Encodes the argumenttuples as bytes, and then does a sha256 on that. @@ -77,8 +79,7 @@ def _unique_path(self, func, argtuples): `__repr__` """ - args_as_bytes = str(argtuples).encode() - hashed_args = str(hashlib.sha256(args_as_bytes).hexdigest()) + hashed_args = hashlib.sha256(repr(argtuples).encode()).hexdigest() filename = f"{func.__module__}-{func.__name__}-{hashed_args}" @@ -153,10 +154,10 @@ def build_store(self): total_calls = sum( len(calls) for calls in self.storage_function_argvalues.values() ) - counter = 0 + counter = 0 for func in self.storage_functions: - for argtuples in self.storage_function_argvalues[func]: + for argtuples in self.storage_function_argvalues[func].values(): kwargs = dict(argtuples) print(