X-Git-Url: https://git.madduck.net/etc/taskwarrior.git/blobdiff_plain/2f50a72c1d1400edddd58ad654611422c92d852a..d409220d5abb52c0bb0022bf8b24728636a96a5b:/tasklib/task.py?ds=inline diff --git a/tasklib/task.py b/tasklib/task.py index 1fa3faa..d9b2678 100644 --- a/tasklib/task.py +++ b/tasklib/task.py @@ -42,16 +42,22 @@ class TaskResource(object): except ValueError: pass - hydrate_func = getattr(self, 'deserialize_{0}'.format(key), - lambda x: x) - return hydrate_func(self._data.get(key)) + return self._deserialize(key, self._data.get(key)) def __setitem__(self, key, value): if key in self.read_only_fields: raise RuntimeError('Field \'%s\' is read-only' % key) + self._data[key] = self._serialize(key, value) + + def _deserialize(self, key, value): + hydrate_func = getattr(self, 'deserialize_{0}'.format(key), + lambda x: x) + return hydrate_func(value) + + def _serialize(self, key, value): dehydrate_func = getattr(self, 'serialize_{0}'.format(key), lambda x: x) - self._data[key] = dehydrate_func(value) + return dehydrate_func(value) def __str__(self): s = six.text_type(self.__unicode__()) @@ -86,7 +92,7 @@ class TaskAnnotation(TaskResource): class Task(TaskResource): - read_only_fields = ['id', 'entry', 'urgency', 'uuid'] + read_only_fields = ['id', 'entry', 'urgency', 'uuid', 'modified'] class DoesNotExist(Exception): pass @@ -113,10 +119,18 @@ class Task(TaskResource): def __init__(self, warrior, data={}, **kwargs): self.warrior = warrior - # We keep data for backwards compatibility - kwargs.update(data) + # We serialize the data in kwargs so that users of the library + # do not have to pass different data formats via __setitem__ and + # __init__ methods, that would be confusing - self._load_data(kwargs) + # Rather unfortunate syntax due to python2.6 comaptiblity + self._load_data(dict((key, self._serialize(key, value)) + for (key, value) in six.iteritems(kwargs))) + + # We keep data for backwards compatibility + # TODO: Should we keep this using unserialized access to _data dict? + self._data.update(data) + self._original_data.update(data) def __unicode__(self): return self['description'] @@ -140,7 +154,8 @@ class Task(TaskResource): @property def _modified_fields(self): - for key in self._data.keys(): + writable_fields = set(self._data.keys()) - set(self.read_only_fields) + for key in writable_fields: if self._data.get(key) != self._original_data.get(key): yield key @@ -165,6 +180,8 @@ class Task(TaskResource): return self['uuid'] is not None or self['id'] is not None def serialize_due(self, date): + if not date: + return None return date.strftime(DATE_FORMAT) def deserialize_due(self, date_str): @@ -302,7 +319,8 @@ class Task(TaskResource): elif field == 'depends': args.append('{0}:{1}'.format(field, self.format_depends())) else: - args.append('{0}:{1}'.format(field, self._data[field])) + # Use empty string to substitute for None value + args.append('{0}:{1}'.format(field, self._data[field] or '')) # If we're modifying saved task, simply pass on all modified fields if self.saved: