summaryrefslogtreecommitdiff
path: root/internal/askcli/command_info_add.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-03-24 17:44:37 +0200
committerPaul Buetow <paul@buetow.org>2026-03-24 17:44:37 +0200
commitbef3cc7dd95745a5724d3569e45fe7be4aba02ee (patch)
tree36ec4a6dc5b42eeec88ea0424287f317a4807320 /internal/askcli/command_info_add.go
parent5beb39a3338e83c9a5906d2e5f7acb3bf795811d (diff)
ask: add --json flag for machine-readable outputv0.25.12
List, ready, all, info, and urgency commands now output JSON arrays when --json is passed. This fixes pi agent-plan-mode extension which expects JSON from ask but was getting human-readable tables. Amp-Thread-ID: https://ampcode.com/threads/T-019d207c-b8e2-748d-af52-dd8f84fb2b32 Co-authored-by: Amp <amp@ampcode.com>
Diffstat (limited to 'internal/askcli/command_info_add.go')
-rw-r--r--internal/askcli/command_info_add.go14
1 files changed, 13 insertions, 1 deletions
diff --git a/internal/askcli/command_info_add.go b/internal/askcli/command_info_add.go
index 2680163..025b104 100644
--- a/internal/askcli/command_info_add.go
+++ b/internal/askcli/command_info_add.go
@@ -3,6 +3,8 @@ package askcli
import (
"bytes"
"context"
+ "encoding/json"
+ "fmt"
"io"
"strings"
)
@@ -27,7 +29,17 @@ func (d Dispatcher) handleInfo(ctx context.Context, args []string, stdout, stder
io.WriteString(stderr, "error: task not found\n")
return 1, nil
}
- io.WriteString(stdout, FormatTaskInfo(tasks[0]))
+ if d.jsonOutput {
+ data, err := json.Marshal(tasks)
+ if err != nil {
+ fmt.Fprintf(stderr, "error: failed to marshal JSON: %v\n", err)
+ return 1, nil
+ }
+ stdout.Write(data)
+ io.WriteString(stdout, "\n")
+ } else {
+ io.WriteString(stdout, FormatTaskInfo(tasks[0]))
+ }
return 0, nil
}