diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-24 17:44:37 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-24 17:44:37 +0200 |
| commit | bef3cc7dd95745a5724d3569e45fe7be4aba02ee (patch) | |
| tree | 36ec4a6dc5b42eeec88ea0424287f317a4807320 /internal/askcli/dispatch.go | |
| parent | 5beb39a3338e83c9a5906d2e5f7acb3bf795811d (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/dispatch.go')
| -rw-r--r-- | internal/askcli/dispatch.go | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/internal/askcli/dispatch.go b/internal/askcli/dispatch.go index 312a6cf..19e9b58 100644 --- a/internal/askcli/dispatch.go +++ b/internal/askcli/dispatch.go @@ -11,7 +11,8 @@ type Runner interface { } type Dispatcher struct { - runner Runner + runner Runner + jsonOutput bool } func NewDispatcher(runner Runner) *Dispatcher { @@ -23,6 +24,19 @@ func NewDispatcher(runner Runner) *Dispatcher { } func (d Dispatcher) Dispatch(ctx context.Context, args []string, stdin io.Reader, stdout, stderr io.Writer) (int, error) { + // Extract --json flag before dispatching. + var jsonOutput bool + var filtered []string + for _, a := range args { + if a == "--json" { + jsonOutput = true + } else { + filtered = append(filtered, a) + } + } + args = filtered + d.jsonOutput = jsonOutput + if len(args) == 0 { return d.handleList(ctx, []string{"list"}, stdout, stderr) } |
