X-Git-Url: https://git.madduck.net/etc/taskwarrior.git/blobdiff_plain/48dea7bc1e7e94eb4fc51f0278bac76e005e78e2..8a2ba91cb471ad97094311172b86b9bf3afed725:/tasklib/task.py diff --git a/tasklib/task.py b/tasklib/task.py index 708c9c7..cbc1192 100644 --- a/tasklib/task.py +++ b/tasklib/task.py @@ -237,8 +237,15 @@ class SerializingObject(object): return ','.join(task['uuid'] for task in value) def deserialize_depends(self, raw_uuids): - raw_uuids = raw_uuids or '' # Convert None to empty string - uuids = raw_uuids.split(',') + raw_uuids = raw_uuids or [] # Convert None to empty list + + # TW 2.4.4 encodes list of dependencies as a single string + if type(raw_uuids) is not list: + uuids = raw_uuids.split(',') + # TW 2.4.5 and later exports them as a list, no conversion needed + else: + uuids = raw_uuids + return set(self.warrior.tasks.get(uuid=uuid) for uuid in uuids if uuid) def datetime_normalizer(self, value): @@ -670,7 +677,13 @@ class Task(TaskResource): "task: %s" % '\n'.join(id_lines)) # Circumvent the ID storage, since ID is considered read-only - self._data['id'] = int(id_lines[0].split(' ')[2].rstrip('.')) + identifier = id_lines[0].split(' ')[2].rstrip('.') + + # Identifier can be either ID or UUID for completed tasks + try: + self._data['id'] = int(identifier) + except ValueError: + self._data['uuid'] = identifier # Refreshing is very important here, as not only modification time # is updated, but arbitrary attribute may have changed due hooks @@ -740,6 +753,14 @@ class Task(TaskResource): # of newly saved tasks. Any other place in the code is fine # with using UUID only. args = [self['uuid'] or self['id'], 'export'] + output = self.warrior.execute_command(args) + + # If more than 1 task has been matched, raise exception + if len(output) > 1: + raise TaskWarriorException( + "Unique identifier {0} matches multiple tasks: {1}".format( + self['uuid'] or self['id'], output)) + new_data = json.loads(self.warrior.execute_command(args)[0]) if only_fields: to_update = dict(