Files
gemini-cli/docs/cli/headless.md

51 lines
1.5 KiB
Markdown
Raw Permalink Normal View History

# Headless mode reference
2025-09-17 04:01:15 +09:00
Headless mode provides a programmatic interface to Gemini CLI, returning
structured text or JSON output without an interactive terminal UI.
2025-09-17 04:01:15 +09:00
## Technical reference
2025-09-17 04:01:15 +09:00
Headless mode is triggered when the CLI is run in a non-TTY environment or when
providing a query with the `-p` (or `--prompt`) flag.
2025-09-17 04:01:15 +09:00
### Output formats
2025-09-17 04:01:15 +09:00
You can specify the output format using the `--output-format` flag.
2025-09-17 04:01:15 +09:00
#### JSON output
2025-09-17 04:01:15 +09:00
Returns a single JSON object containing the response and usage statistics.
2025-09-17 04:01:15 +09:00
- **Schema:**
- `response`: (string) The model's final answer.
- `stats`: (object) Token usage and API latency metrics.
- `error`: (object, optional) Error details if the request failed.
2025-09-17 04:01:15 +09:00
#### Streaming JSON output
2025-09-17 04:01:15 +09:00
Returns a stream of newline-delimited JSON (JSONL) events.
2025-09-17 04:01:15 +09:00
- **Event types:**
- `init`: Session metadata (session ID, model).
- `message`: User and assistant message chunks.
- `tool_use`: Tool call requests with arguments.
- `tool_result`: Output from executed tools.
- `error`: Non-fatal warnings and system errors.
- `result`: Final outcome with aggregated statistics.
2025-09-17 04:01:15 +09:00
## Exit codes
2025-09-17 04:01:15 +09:00
The CLI returns standard exit codes to indicate the result of the headless
execution:
2025-09-17 04:01:15 +09:00
- `0`: Success.
- `1`: General error or API failure.
- `42`: Input error (invalid prompt or arguments).
- `53`: Turn limit exceeded.
2025-09-17 04:01:15 +09:00
## Next steps
2025-09-17 04:01:15 +09:00
- Follow the [Automation tutorial](./tutorials/automation.md) for practical
scripting examples.
- See the [CLI reference](./cli-reference.md) for all available flags.