diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-22 21:22:04 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-22 21:22:04 +0200 |
| commit | 641e5f723215960713ad183d6d99619b64d69467 (patch) | |
| tree | bb1dfd79fd9789f2e9a2625123f69e3f784d4984 /internal/askcli/command_list.go | |
| parent | 00ff404454c3fc04e13e39992d6dd1200bad9191 (diff) | |
ask: add ready command to list READY tasks (not blocked)
handleReady passes +READY filter to show actionable tasks only.
help text updated. tests updated.
Diffstat (limited to 'internal/askcli/command_list.go')
| -rw-r--r-- | internal/askcli/command_list.go | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/internal/askcli/command_list.go b/internal/askcli/command_list.go index e6571e5..1ba9352 100644 --- a/internal/askcli/command_list.go +++ b/internal/askcli/command_list.go @@ -66,6 +66,35 @@ func (d Dispatcher) handleAll(ctx context.Context, args []string, stdout, stderr return 0, nil } +func (d Dispatcher) handleReady(ctx context.Context, args []string, stdout, stderr io.Writer) (int, error) { + filterArgs := []string{"export", "+READY"} + for _, arg := range args[1:] { + if strings.HasPrefix(arg, "limit:") || strings.HasPrefix(arg, "sort:") || + strings.HasPrefix(arg, "+") || arg == "started" { + filterArgs = append(filterArgs, arg) + } + } + var outBuf bytes.Buffer + code, err := d.runner.Run(ctx, filterArgs, nil, &outBuf, stderr) + if code != 0 { + return code, err + } + tasks, err := ParseTaskExport(&outBuf) + if err != nil { + return 1, nil + } + sort.Slice(tasks, func(i, j int) bool { + pi := priorityOrder(tasks[i].Priority) + pj := priorityOrder(tasks[j].Priority) + if pi != pj { + return pi < pj + } + return tasks[i].Urgency > tasks[j].Urgency + }) + io.WriteString(stdout, FormatTaskList(tasks)) + return 0, nil +} + func priorityOrder(p string) int { switch p { case "H": |
