API reference: Reference overview maps every package to its exhaustive API page, each with links to source and tests.
bunx smithers-orchestrator starters.
Implement → review loop
Iterate until a reviewer signs off, with a hard cap.<Loop> until, read the most recent iteration with ctx.latest. ctx.outputMaybe(.., { nodeId }) without an explicit iteration resolves the current render iteration (which equals the loop iteration only for a single, non-nested loop, and is 0 when several loops coexist), so an outputMaybe-based until can silently never advance.
Parallel multi-agent review
Two models catch different bugs. Cost = the slower model’s latency.continueOnFail keeps one model’s timeout from blocking the other.
Approval gate with branching
Decision data drives the next branch.onDeny: "fail" aborts, "continue" proceeds without the gated branch, "skip" skips the gated tasks.
Retry policy & timeouts
Optional, non-blocking step
Conditional branch on output
ctx.outputMaybe for control flow.
Dynamic ticket discovery
Discover work, run each ticket, re-render to catch the next batch. Scales to large projects.t.id, not array index) so resume matches.
Coherent task with tools
One context boundary per logical operation, not per step. Splitting too finely loses cross-step reasoning.Per-agent least-privilege tools
Side-effect tools with idempotency
External mutations must mark themselves and use the runtime idempotency key.Caching for iterative authoring
Schemas in their own file
MDX prompt with auto-injected schema
props.schema is the JSON-schema description of the Task’s outputSchema, auto-injected. Keeps the prompt and the validator in sync.
In .mdx prompt files, prose that looks like JSX or HTML is parsed as JSX. Wrap examples such as <Parallel maxConcurrency={N}> in inline backticks or a fenced code block so the prompt module still compiles and exports its default prompt component.
Custom hooks over ctx
VCS revert & per-attempt snapshots
Smithers records the current JJ change ID in_smithers_attempts.jj_pointer per attempt. Revert any attempt with a recorded JJ pointer to its exact workspace state:
Time travel: fork, replay, diff
--run to start immediately); replay also makes a child run but immediately resumes it. --restore-vcs checks out the original revision so re-execution sees the same source.
Scoring tasks
ratio.
Eval suites for regressions
status, output (exact match), and outputContains (partial match). Reports land in .smithers/evals/<suite>.json; the command exits non-zero on failures.
Continue-as-new for very long runs
A run with too much accumulated state hands off to a fresh run with carried state.Hot reload while authoring
Fork agent session context
Every agent task produces a reusable session snapshot.fork starts a new task from a copy of another task’s final context, without mutating the source.
fork adds the source as a dependency (the forked task waits for it), copies its conversation into a fresh session, then submits the new prompt. Both branches above start from the same investigation and never affect each other. Chain it for follow-ups (plan → implement → verify); inside a <Loop> it forks the latest completed snapshot for that id. See <Task> fork.
Read next
- How It Works: the model these recipes plug into.
- Components: full prop surface.
- CLI: every command.