claude-code-headless
Original:🇺🇸 English
Translated
Run Claude Code programmatically without interactive UI. Triggers on: headless, CLI automation, --print, output-format, stream-json, CI/CD, scripting.
5installs
Source0xdarkmatter/claude-mods
Added on
NPX Install
npx skill4agent add 0xdarkmatter/claude-mods claude-code-headlessTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →Claude Code Headless Mode
Run Claude Code from scripts without interactive UI.
Quick Start
bash
# Basic headless execution
claude -p "Explain this code" --allowedTools "Read,Grep"
# JSON output for parsing
claude -p "List files" --output-format json
# Continue conversation
claude -p "Start analysis" --output-format json > result.json
session=$(jq -r '.session_id' result.json)
claude --resume "$session" "Now fix the issues"Essential CLI Options
| Flag | Description |
|---|---|
| Non-interactive (headless) mode |
| text, json, stream-json |
| Resume by session ID |
| Continue most recent session |
| Comma-separated allowed tools |
| Comma-separated denied tools |
| Path to MCP server config JSON |
| Enable verbose logging |
| Add to system prompt |
Permission Modes
| Mode | Flag | Effect |
|---|---|---|
| Default | (none) | Prompt for permissions |
| Accept edits | | Auto-accept file changes |
| Bypass | | Skip all prompts |
Output Formats
Text (default)
bash
claude -p "Hello"
# Outputs: Human-readable responseJSON
bash
claude -p "Hello" --output-format jsonjson
{
"type": "result",
"subtype": "success",
"result": "Hello! How can I help?",
"session_id": "abc123",
"total_cost_usd": 0.001,
"duration_ms": 1234,
"num_turns": 1
}Stream-JSON
bash
claude -p "Hello" --output-format stream-json
# Real-time JSONL output for each messageCommon Patterns
Script with tool restrictions
bash
claude -p "Analyze the codebase" \
--allowedTools "Read,Grep,Glob" \
--disallowedTools "Write,Edit,Bash"CI/CD integration
bash
claude -p "Review this PR diff" \
--permission-mode acceptEdits \
--output-format json \
--append-system-prompt "Focus on security issues"Multi-turn automation
bash
session=$(claude -p "Start task" --output-format json | jq -r '.session_id')
claude --resume "$session" "Continue with step 2"
claude --resume "$session" "Finalize and report"Error Handling
bash
result=$(claude -p "Task" --output-format json)
if [[ $(echo "$result" | jq -r '.is_error') == "true" ]]; then
echo "Error: $(echo "$result" | jq -r '.result')" >&2
exit 1
fiOfficial Documentation
- https://code.claude.com/docs/en/headless - Headless mode reference
- https://code.claude.com/docs/en/settings - Settings and permissions
Additional Resources
- - Complete CLI flag reference
./references/cli-options.md - - Output format schemas
./references/output-formats.md - - CI/CD and scripting examples
./references/integration-patterns.md
See Also: for automation events, for troubleshooting
claude-code-hooksclaude-code-debug