skills/pi-agent/references/json.md
Source: https://pi.dev/docs/latest/json
Use JSON mode for one-shot prompts that output all session events as JSON lines to stdout.
pi --mode json "Your prompt"
AgentSessionEvent includes base agent events plus queue, compaction, and retry events:
agent_start, agent_endturn_start, turn_endmessage_start, message_update, message_endtool_execution_start, tool_execution_update, tool_execution_endqueue_updatecompaction_start, compaction_endauto_retry_start, auto_retry_endqueue_update emits full pending steering and follow-up queues. Compaction events cover manual and automatic compaction.
First line is the session header:
{"type":"session","version":3,"id":"uuid","timestamp":"...","cwd":"/path"}
Subsequent lines are events:
{"type":"agent_start"}
{"type":"turn_start"}
{"type":"message_update","message":{},"assistantMessageEvent":{"type":"text_delta","delta":"Hello"}}
{"type":"agent_end","messages":[]}
pi --mode json "List files" 2>/dev/null | jq -c 'select(.type == "message_end")'
For bidirectional control, use RPC instead of JSON mode.