summaryrefslogtreecommitdiff
path: root/internal/task/task.go
diff options
context:
space:
mode:
authorPaul Bütow <1224732+snonux@users.noreply.github.com>2025-06-22 16:39:56 +0300
committerPaul Bütow <1224732+snonux@users.noreply.github.com>2025-06-22 16:39:56 +0300
commitdc1a6e83669dd22be4542833970d3251741ba1f3 (patch)
treee2585f906485e89f6d4417a5d1d3d04f9c442ce4 /internal/task/task.go
parente42bb79ed74cb975db0c4b8128b9014f0f6acf33 (diff)
Fix add task hotkey
Diffstat (limited to 'internal/task/task.go')
-rw-r--r--internal/task/task.go23
1 files changed, 21 insertions, 2 deletions
diff --git a/internal/task/task.go b/internal/task/task.go
index 603002d..b20eef0 100644
--- a/internal/task/task.go
+++ b/internal/task/task.go
@@ -12,6 +12,8 @@ import (
"strconv"
"strings"
"time"
+
+ "github.com/google/shlex"
)
// Task represents a taskwarrior task as returned by `task export`.
@@ -54,7 +56,7 @@ func SetDebugLog(path string) error {
// Add creates a new task with the given description and tags.
func Add(description string, tags []string) error {
- args := []string{"add"}
+ var args []string
for _, t := range tags {
if len(t) > 0 && t[0] != '+' {
t = "+" + t
@@ -62,11 +64,28 @@ func Add(description string, tags []string) error {
args = append(args, t)
}
args = append(args, description)
+ return AddArgs(args)
+}
- cmd := exec.Command("task", args...)
+// AddArgs runs "task add" with the provided arguments. Each element in args
+// is passed as a separate command-line argument, allowing the caller to
+// specify additional modifiers like due dates or tags.
+func AddArgs(args []string) error {
+ cmd := exec.Command("task", append([]string{"add"}, args...)...)
return cmd.Run()
}
+// AddLine splits the given line into shell words and runs "task add" with the
+// resulting arguments. This allows users to pass raw Taskwarrior parameters
+// such as "due:today" directly.
+func AddLine(line string) error {
+ fields, err := shlex.Split(line)
+ if err != nil {
+ return err
+ }
+ return AddArgs(fields)
+}
+
// Export retrieves all tasks using `task export rc.json.array=off` and parses
// the JSON output into a slice of Task structs.
// Export retrieves tasks using `task <filter> export rc.json.array=off` and parses