Orchestrate a team of AI coding agents from a declarative tutti.toml config. Launch agents in isolated git worktrees, run verification workflows, track token usage, and manage context handoffs — all through a single CLI.
Use when the user asks you to:
tt binary installed and on PATH (install from https://github.com/nutthouse/tutti)tmux installedpython3 availabletutti.toml config file in the workspace rootAlways run preflight checks before starting a workflow:
python3 tutti_openclaw.py doctor_check
All actions go through the wrapper script. Every action returns a consistent JSON envelope:
{
"ok": true,
"action": "action_name",
"command": ["tt", "..."],
"exit_code": 0,
"data": {},
"stdout": "",
"stderr": ""
}
| Action | Command | Purpose |
|---|---|---|
| -------- | --------- | --------- |
doctor_check | python3 tutti_openclaw.py doctor_check | Preflight: verify tools, config, and environment |
launch_team | python3 tutti_openclaw.py launch_team | Launch all agents defined in tutti.toml |
launch_agent | python3 tutti_openclaw.py launch_agent | Launch a single agent |
send_prompt | python3 tutti_openclaw.py send_prompt | Send a prompt to an agent with optional auto-start, wait-for-idle, and output capture |
team_status | python3 tutti_openclaw.py team_status | Read agent states from .tutti/state/ |
agent_output | python3 tutti_openclaw.py agent_output | Peek at an agent's terminal output |
stop_agent | python3 tutti_openclaw.py stop_agent | Stop a single agent |
stop_team | python3 tutti_openclaw.py stop_team | Stop all agents |
| Action | Command | Purpose |
|---|---|---|
| -------- | --------- | --------- |
list_workflows | python3 tutti_openclaw.py list_workflows | Discover available workflows |
plan_workflow | python3 tutti_openclaw.py plan_workflow | Dry-run a workflow |
run_workflow | python3 tutti_openclaw.py run_workflow | Execute a workflow |
verify_team | python3 tutti_openclaw.py verify_team [--workflow | Run verification workflow |
read_verify_status | python3 tutti_openclaw.py read_verify_status | Read last verification result |
| Action | Command | Purpose |
|---|---|---|
| -------- | --------- | --------- |
land_agent | python3 tutti_openclaw.py land_agent | Land an agent's branch back to current branch, or open a PR |
| Action | Command | Purpose |
|---|---|---|
| -------- | --------- | --------- |
generate_handoff | python3 tutti_openclaw.py generate_handoff | Capture agent context to a packet |
apply_handoff | python3 tutti_openclaw.py apply_handoff | Inject a handoff packet into an agent |
list_handoffs | python3 tutti_openclaw.py list_handoffs [--agent ] [--limit 20] | List available handoff packets |
| Action | Command | Purpose |
|---|---|---|
| -------- | --------- | --------- |
permissions_check | python3 tutti_openclaw.py permissions_check | Check if a command is allowed by policy |
Workflows in tutti.toml support these step types:
| Type | Purpose | Key fields |
|---|---|---|
| ------ | --------- | ------------ |
prompt | Send text to an agent session | agent, text, inject_files, wait_for_idle, wait_timeout_secs |
command | Execute a shell command | run, cwd, timeout_secs, fail_mode |
ensure_running | Start an agent if not already running | agent, fail_mode |
workflow | Execute another workflow as a nested step | workflow, agent, strict, fail_mode |
land | Land an agent's branch | agent, pr, force, fail_mode |
review | Send an agent's diff to a reviewer | agent, reviewer, fail_mode |
Prompt steps support inject_files — an array of workspace-relative file paths that are copied into the agent's worktree before the prompt is sent. This enables stateful context passing between agents (e.g., injecting a snapshot JSON produced by another agent).
Nested workflow steps enable composition: observe → dispatch → fix → verify → land as a chain of workflow invocations.
Follow this sequence for orchestrating a workspace:
doctor_check. Stop and report if non-zero.launch_team or launch_agent .team_status and agent_output to observe progress.send_prompt "do something" --auto-up --wait --output to dispatch work and capture results.list_workflows to discover, then run_workflow .verify_team --strict for gate-style quality checks.land_agent to cherry-pick work, or land_agent --pr to open a PR.generate_handoff when context is high, apply_handoff to resume.stop_team or stop_agent when done.action, command, and stderr from the JSON envelope. Do not retry blindly.read_verify_status.stderr contains auth errors, stop and escalate to the user. Do not retry auth failures.--auto-up on send_prompt to automatically start agents on demand rather than failing.If tt is not on PATH or you need a specific version:
python3 tutti_openclaw.py --tt-bin /path/to/tt doctor_check
# or via environment variable
TUTTI_BIN=/path/to/tt python3 tutti_openclaw.py doctor_check
doctor_check before any launch or workflow operation.team_status (reads state files directly) over agent_output for status checks.--strict flag on verify_team and run_workflow when results gate further actions.--auto-up on send_prompt when the target agent may not be running.--output on send_prompt to capture the agent's response for programmatic verification.--json output from tt commands when you need structured data (the wrapper handles this automatically).stdout text output — always use the data field from the JSON envelope.共 1 个版本