From 4864a6a8101f283451bc70505e1b81bc2a5eef56 2014-07-22 15:21:28 From: Jason Grout Date: 2014-07-22 15:21:28 Subject: [PATCH] Simplify the code for picking json serialization functions to expose the logic better --- diff --git a/IPython/html/widgets/widget.py b/IPython/html/widgets/widget.py index 48ab650..de4c42f 100644 --- a/IPython/html/widgets/widget.py +++ b/IPython/html/widgets/widget.py @@ -198,11 +198,10 @@ class Widget(LoggingConfigurable): state = {} for k in keys: f = self.trait_metadata(k, 'serialize') - value = getattr(self, k) - if f is not None: - state[k] = f(value) - else: - state[k] = self._serialize_trait(value) + if f is None: + f = self._serialize_trait + value = getattr(self, k) + state[k] = f(value) return state def send(self, content): @@ -289,10 +288,9 @@ class Widget(LoggingConfigurable): for name in self.keys: if name in sync_data: f = self.trait_metadata(name, 'deserialize') - if f is not None: - value = f(sync_data[name]) - else: - value = self._deserialize_trait(sync_data[name]) + if f is None: + f = self._deserialize_trait + value = f(sync_data[name]) with self._lock_property(name, value): setattr(self, name, value)