]>
git.madduck.net Git - etc/taskwarrior.git/commitdiff
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
8dec670 )
class DoesNotExist(Exception):
pass
class DoesNotExist(Exception):
pass
+ class CompletedTask(Exception):
+ """
+ Raised when the operation cannot be performed on the completed task.
+ """
+ pass
+
+ class DeletedTask(Exception):
+ """
+ Raised when the operation cannot be performed on the deleted task.
+ """
+ pass
+
def __init__(self, warrior, data={}):
self.warrior = warrior
self._load_data(data)
def __init__(self, warrior, data={}):
self.warrior = warrior
self._load_data(data)
def __unicode__(self):
return self['description']
def __unicode__(self):
return self['description']
+ @property
+ def completed(self):
+ return self['status'] == six.text_type('completed')
+
+ @property
+ def deleted(self):
+ return self['status'] == six.text_type('deleted')
+
+ @property
+ def waiting(self):
+ return self['status'] == six.text_type('waiting')
+
+ @property
+ def pending(self):
+ return self['status'] == six.text_type('pending')
+
def serialize_due(self, date):
return date.strftime(DATE_FORMAT)
def serialize_due(self, date):
return date.strftime(DATE_FORMAT)
return ','.join(tags) if tags else ''
def delete(self):
return ','.join(tags) if tags else ''
def delete(self):
+ # Refresh the status, and raise exception if the task is deleted
+ self.refresh(only_fields=['status'])
+
+ if self.deleted:
+ raise self.DeletedTask("Task was already deleted")
+
self.warrior.execute_command([self['id'], 'delete'], config_override={
'confirmation': 'no',
})
self.warrior.execute_command([self['id'], 'delete'], config_override={
'confirmation': 'no',
})
+ # Refresh the status again, so that we have updated info stored
+ self.refresh(only_fields=['status'])
+
+
+ # Refresh, and raise exception if task is already completed/deleted
+ self.refresh(only_fields=['status'])
+
+ if self.completed:
+ raise self.CompletedTask("Cannot complete a completed task")
+ elif self.deleted:
+ raise self.DeletedTask("Deleted task cannot be completed")
+
self.warrior.execute_command([self['id'], 'done'])
self.warrior.execute_command([self['id'], 'done'])
+ # Refresh the status again, so that we have updated info stored
+ self.refresh(only_fields=['status'])
+
def save(self):
args = [self['id'], 'modify'] if self['id'] else ['add']
args.extend(self._get_modified_fields_as_args())
def save(self):
args = [self['id'], 'modify'] if self['id'] else ['add']
args.extend(self._get_modified_fields_as_args())