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.
4 Taskpirate is a pluggable system for TaskWarrior python hooks.
11 def hook_example(task):
12 task['description'] += "changed by a hook"
14 The above is fully working example, no more boilerplate needed.
16 * much faster execution time
21 You'll need tasklib as a dependency:
23 pip install --user git+git://github.com/tbabej/tasklib@develop
25 Then you need to drop ```on-add-pirate``` and ```on-modify-pirate``` into ~/.task/hooks/.
27 After that, you can just clone any taskpirate-enabled hook as a subfolder into ~/.task/hooks/:
29 git clone https://github.com/tbabej/task.default-date-time ~/.task/hooks/default-date-time/
31 How to write a taskpirate hook
32 ------------------------------
34 In your hook's repository, any file matching ```pirate_add*.py``` will be searched for hooks in on-add event. In the same sense, any file matching ```pirate_mod*.py``` will be searched for hooks in on-modify event.
36 Now, the pirate_add_example.py might look as follows:
38 def hook_example(task):
39 task['description'] += "changed by a hook"
41 Any function in pirate_add_example that is called ```hook_*``` will be considered as a hook in on-add event. It will be passed the ```Task``` object corresponding to the current state of the task being added (as modified by the previous hooks).
46 TaskWarrior hooks are intended to be simple, but they involve writing some boilerplate code (parsing/formatting json). To allow users to write dead simple code, they can leverage tasklib.
48 Using tasklib simplifies things a lot, however, it's not a super-lightweight - usage of tasklib can slow down the hook by as much as 30-50ms (usual python hook can probably run in under 40ms), since it imports multiple libraries.
50 This becomes a problem when user has multiple tasklib-based hooks, since the import time adds up.
52 Also, note that taskpirate with arbitrary number of hooks will be most likely faster than 2-3 regular python hooks.
57 You can look into my ```task.default-date-time``` or ```task.shift-recurrence``` hooks.