Extract code into individual functions
This commit is contained in:
parent
0769d65610
commit
dca5ebb9fb
1 changed files with 74 additions and 23 deletions
97
topen
97
topen
|
|
@ -5,6 +5,7 @@
|
||||||
# Edits an existing task note file,
|
# Edits an existing task note file,
|
||||||
# or creates a new one.
|
# or creates a new one.
|
||||||
|
|
||||||
|
import argparse
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
@ -13,38 +14,88 @@ from tasklib import Task, TaskWarrior
|
||||||
|
|
||||||
TASK_DATA_DIR = "~/.local/share/task"
|
TASK_DATA_DIR = "~/.local/share/task"
|
||||||
|
|
||||||
TASKNOTES_DIR = "~/.local/share/task/notes"
|
TOPEN_DIR = "~/.local/share/task/notes"
|
||||||
TASKNOTES_EXT = "md"
|
TOPEN_EXT = "md"
|
||||||
TASKNOTES_ANNOT = "Note"
|
TOPEN_ANNOT = "Note"
|
||||||
|
|
||||||
tw = TaskWarrior(data_location=TASK_DATA_DIR)
|
|
||||||
|
|
||||||
args = sys.argv
|
def parse_cli() -> argparse.Namespace:
|
||||||
|
parser = argparse.ArgumentParser(description="Taskwarrior note editing made easy.")
|
||||||
|
_ = parser.add_argument(
|
||||||
|
"id", help="The id/uuid of the taskwarrior task for which we edit notes"
|
||||||
|
)
|
||||||
|
_ = parser.add_argument(
|
||||||
|
"-d",
|
||||||
|
"--notes-dir",
|
||||||
|
default=TOPEN_DIR,
|
||||||
|
help="Location of topen notes",
|
||||||
|
)
|
||||||
|
_ = parser.add_argument(
|
||||||
|
"-x", "--extension", default=TOPEN_EXT, help="Extension of note files"
|
||||||
|
)
|
||||||
|
_ = parser.add_argument(
|
||||||
|
"-t",
|
||||||
|
"--annotation",
|
||||||
|
default=TOPEN_ANNOT,
|
||||||
|
help="Annotation content to set within taskwarrior",
|
||||||
|
)
|
||||||
|
_ = parser.add_argument(
|
||||||
|
"--task-data", default=TASK_DATA_DIR, help="Location of taskwarrior data"
|
||||||
|
)
|
||||||
|
|
||||||
if not len(args) == 2:
|
return parser.parse_args()
|
||||||
_ = sys.stderr.write("Please provide task ID as argument.\n")
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
given_id = args[1]
|
|
||||||
|
|
||||||
try:
|
def main():
|
||||||
t = tw.tasks.get(id=given_id)
|
args = parse_cli()
|
||||||
except Task.DoesNotExist:
|
|
||||||
t = tw.tasks.get(uuid=given_id)
|
|
||||||
|
|
||||||
_ = sys.stderr.write(f"Editing note for: {t['description']} ({t['uuid']})\n")
|
if not args.id:
|
||||||
|
_ = sys.stderr.write("Please provide task ID as argument.\n")
|
||||||
|
|
||||||
notes_file = Path(TASKNOTES_DIR).joinpath(f"{t['uuid']}.{TASKNOTES_EXT}")
|
task = get_task(id=args.id, data_location=args.task_data)
|
||||||
|
uuid = task["uuid"]
|
||||||
|
if not uuid:
|
||||||
|
_ = sys.stderr.write(f"Could not find task for id: {args.id}.")
|
||||||
|
sys.exit(1)
|
||||||
|
fname = get_notes_file(uuid, notes_dir=args.notes_dir, notes_ext=args.extension)
|
||||||
|
|
||||||
proc = subprocess.Popen(f"nvim {notes_file}", shell=True)
|
# TODO: Add editor choice
|
||||||
_ = proc.wait()
|
open_editor(fname)
|
||||||
|
|
||||||
def add_annotation_if_missing(task: Task) -> None:
|
add_annotation_if_missing(task, annotation_content=args.annotation)
|
||||||
for annot in t["annotations"]:
|
|
||||||
if annot["description"] == "Note":
|
|
||||||
|
def get_task(id: str, data_location: str = TASK_DATA_DIR) -> Task:
|
||||||
|
tw = TaskWarrior(data_location)
|
||||||
|
try:
|
||||||
|
t = tw.tasks.get(id=id)
|
||||||
|
except Task.DoesNotExist:
|
||||||
|
t = tw.tasks.get(uuid=id)
|
||||||
|
|
||||||
|
return t
|
||||||
|
|
||||||
|
|
||||||
|
def get_notes_file(
|
||||||
|
uuid: str, notes_dir: str = TOPEN_DIR, notes_ext: str = TOPEN_EXT
|
||||||
|
) -> Path:
|
||||||
|
return Path(notes_dir).joinpath(f"{uuid}.{notes_ext}")
|
||||||
|
|
||||||
|
|
||||||
|
def open_editor(file: Path, editor: str = "nvim") -> None:
|
||||||
|
_ = sys.stderr.write(f"Editing note {file}\n")
|
||||||
|
proc = subprocess.Popen(f"{editor} {file}", shell=True)
|
||||||
|
_ = proc.wait()
|
||||||
|
|
||||||
|
|
||||||
|
def add_annotation_if_missing(
|
||||||
|
task: Task, annotation_content: str = TOPEN_ANNOT
|
||||||
|
) -> None:
|
||||||
|
for annot in task["annotations"] or []:
|
||||||
|
if annot["description"] == annotation_content:
|
||||||
return
|
return
|
||||||
t.add_annotation(TASKNOTES_ANNOT)
|
task.add_annotation(annotation_content)
|
||||||
_ = sys.stderr.write(f"Added annotation.\n")
|
_ = sys.stderr.write("Added annotation.\n")
|
||||||
|
|
||||||
|
|
||||||
add_annotation_if_missing(t)
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue