summaryrefslogtreecommitdiff
path: root/internal/task/task.go
diff options
context:
space:
mode:
authorPaul Bütow <1224732+snonux@users.noreply.github.com>2025-06-21 20:36:08 +0300
committerPaul Bütow <1224732+snonux@users.noreply.github.com>2025-06-21 20:36:08 +0300
commit011f4e7880b1548abb86a3d2f78f80e167004ebd (patch)
tree5d87d646137057740f50afc328d7cf53f27409fa /internal/task/task.go
parent273d493170abe8838252c61a40b558ef4edc3db8 (diff)
Add in-table editing shortcuts
Diffstat (limited to 'internal/task/task.go')
-rw-r--r--internal/task/task.go44
1 files changed, 44 insertions, 0 deletions
diff --git a/internal/task/task.go b/internal/task/task.go
index 64dfc0d..603002d 100644
--- a/internal/task/task.go
+++ b/internal/task/task.go
@@ -167,6 +167,50 @@ func RemoveTags(id int, tags []string) error {
return run(args...)
}
+// SetTags sets the tags of the task with the given id to exactly the provided set.
+// Tags not present will be removed and new tags added as needed.
+func SetTags(id int, tags []string) error {
+ tasks, err := Export(strconv.Itoa(id))
+ if err != nil {
+ return err
+ }
+ if len(tasks) == 0 {
+ return fmt.Errorf("task %d not found", id)
+ }
+ current := make(map[string]struct{})
+ for _, t := range tasks[0].Tags {
+ current[t] = struct{}{}
+ }
+ desired := make(map[string]struct{})
+ for _, t := range tags {
+ desired[t] = struct{}{}
+ }
+
+ var adds, removes []string
+ for t := range desired {
+ if _, ok := current[t]; !ok {
+ adds = append(adds, t)
+ }
+ }
+ for t := range current {
+ if _, ok := desired[t]; !ok {
+ removes = append(removes, t)
+ }
+ }
+
+ if len(adds) > 0 {
+ if err := AddTags(id, adds); err != nil {
+ return err
+ }
+ }
+ if len(removes) > 0 {
+ if err := RemoveTags(id, removes); err != nil {
+ return err
+ }
+ }
+ return nil
+}
+
// SetRecurrence sets the recurrence for the task with the given id.
func SetRecurrence(id int, rec string) error {
return run(strconv.Itoa(id), "modify", "recur:"+rec)