]>
git.madduck.net Git - etc/taskwarrior.git/blobdiff - tasklib/task.py
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:
REPR_OUTPUT_SIZE = 10
PENDING = 'pending'
COMPLETED = 'completed'
REPR_OUTPUT_SIZE = 10
PENDING = 'pending'
COMPLETED = 'completed'
+DELETED = 'deleted'
+WAITING = 'waiting'
+RECURRING = 'recurring'
logger = logging.getLogger(__name__)
logger = logging.getLogger(__name__)
return len(self.viewed_dict)
def __unicode__(self):
return len(self.viewed_dict)
def __unicode__(self):
- return u'ReadOnlyDictView: {0}'.format(repr(self.viewed_dict ))
+ return six.u('ReadOnlyDictView: {0}'.format(repr(self.viewed_dict) ))
# their data dics are the same
return self.task == other.task and self._data == other._data
# their data dics are the same
return self.task == other.task and self._data == other._data
+ def __ne__(self, other):
+ return not self.__eq__(other)
+
# If the tasks are not saved, compare the actual instances
return id(self) == id(other)
# If the tasks are not saved, compare the actual instances
return id(self) == id(other)
+ def __ne__(self, other):
+ return not self.__eq__(other)
+
def __hash__(self):
if self['uuid']:
# For saved Tasks, just define equality by equality of uuids
def __hash__(self):
if self['uuid']:
# For saved Tasks, just define equality by equality of uuids
def pending(self):
return self['status'] == six.text_type('pending')
def pending(self):
return self['status'] == six.text_type('pending')
+ @property
+ def recurring(self):
+ return self['status'] == six.text_type('recurring')
+
@property
def active(self):
return self['start'] is not None
@property
def active(self):
return self['start'] is not None
def delete(self):
if not self.saved:
def delete(self):
if not self.saved:
- raise Task.NotSaved("Task needs to be saved before it can be deleted")
+ raise Task.NotSaved(
+ "Task needs to be saved before it can be deleted")
# Refresh the status, and raise exception if the task is deleted
self.refresh(only_fields=['status'])
# Refresh the status, and raise exception if the task is deleted
self.refresh(only_fields=['status'])
def start(self):
if not self.saved:
def start(self):
if not self.saved:
- raise Task.NotSaved("Task needs to be saved before it can be started")
+ raise Task.NotSaved(
+ "Task needs to be saved before it can be started")
# Refresh, and raise exception if task is already completed/deleted
self.refresh(only_fields=['status'])
# Refresh, and raise exception if task is already completed/deleted
self.refresh(only_fields=['status'])
def stop(self):
if not self.saved:
def stop(self):
if not self.saved:
- raise Task.NotSaved("Task needs to be saved before it can be stopped")
+ raise Task.NotSaved(
+ "Task needs to be saved before it can be stopped")
# Refresh, and raise exception if task is already completed/deleted
self.refresh(only_fields=['status'])
# Refresh, and raise exception if task is already completed/deleted
self.refresh(only_fields=['status'])
def done(self):
if not self.saved:
def done(self):
if not self.saved:
- raise Task.NotSaved("Task needs to be saved before it can be completed")
+ raise Task.NotSaved(
+ "Task needs to be saved before it can be completed")
# Refresh, and raise exception if task is already completed/deleted
self.refresh(only_fields=['status'])
# Refresh, and raise exception if task is already completed/deleted
self.refresh(only_fields=['status'])
def completed(self):
return self.filter(status=COMPLETED)
def completed(self):
return self.filter(status=COMPLETED)
+ def deleted(self):
+ return self.filter(status=DELETED)
+
+ def waiting(self):
+ return self.filter(status=WAITING)
+
+ def recurring(self):
+ return self.filter(status=RECURRING)
+
def filter(self, *args, **kwargs):
"""
Returns a new TaskQuerySet with the given filters added.
def filter(self, *args, **kwargs):
"""
Returns a new TaskQuerySet with the given filters added.