Runtime Registry
This document specifies how the Spawnfile project tracks, pins, and categorizes the runtimes it targets.
Purpose
Section titled “Purpose”The compiler emits output for specific runtimes. Those runtimes are external projects with their own release cadences. The runtime registry is the mechanism for:
- declaring which runtimes the project knows about
- pinning the version each adapter was written and tested against
- tracking which runtimes have active adapters vs which are still under research
Registry File
Section titled “Registry File”The runtime registry is a YAML file at the repository root: runtimes.yaml.
Schema
Section titled “Schema”runtimes: <name>: remote: <git clone URL> ref: <pinned git ref -- tag, SHA, or branch> default_branch: <main | master> status: <active | exploratory | deprecated>Fields
Section titled “Fields”| Field | Required | Description |
|---|---|---|
remote | yes | Git clone URL for the runtime repository |
ref | yes | Pinned git ref — should be the latest stable release tag |
default_branch | yes | The repository’s primary branch name |
status | yes | Lifecycle status of this runtime in the Spawnfile project |
Status Values
Section titled “Status Values”| Status | Meaning |
|---|---|
active | Has a working compiler adapter in src/runtime/<name>/ |
exploratory | Research exists in specs/research/RUNTIME-NOTES.md but no adapter yet |
deprecated | Was previously active, adapter is no longer maintained |
Version Pinning
Section titled “Version Pinning”Why Pin
Section titled “Why Pin”Runtime APIs, config formats, and CLI interfaces change across versions. An adapter written against openclaw v2026.2.3 may not produce valid output for v2026.3.13. Pinning makes this explicit.
What To Pin
Section titled “What To Pin”The ref field should point to the latest stable release tag. Stable means:
- no pre-release suffixes like
-alpha,-beta,-rc,-dev - exception: if a runtime only publishes pre-release tags, pin the most recent one and note it
When To Bump
Section titled “When To Bump”Bump ref when:
- a new stable release is available and the adapter has been verified against it
- the adapter is being updated to support new runtime features from a newer version
Do not bump ref speculatively. The pin represents “the adapter works at this version.”
Sync Script
Section titled “Sync Script”scripts/runtimes.sh reads runtimes.yaml and clones or checks out each runtime at its pinned ref.
./scripts/runtimes.sh # sync all runtimes./scripts/runtimes.sh openclaw # sync one runtimeThe cloned repositories live in runtimes/ at the repo root. This directory is gitignored.
These local clones are for research, blueprint generation, and adapter development. spawnfile compile should not require local runtime clones on the compiler machine; container build/install should use the registry pin plus the adapter’s install strategy.
Adapter Lifecycle
Section titled “Adapter Lifecycle”Adding A New Runtime
Section titled “Adding A New Runtime”- Add an entry to
runtimes.yamlwithstatus: exploratory - Run
./scripts/runtimes.sh <name>to clone it - Research the runtime and add findings to
specs/research/RUNTIME-NOTES.md - When ready to implement, create
src/runtime/<name>/adapter.tsand change status toactive
Promoting To Active
Section titled “Promoting To Active”A runtime moves from exploratory to active when:
- an adapter exists in
src/runtime/<name>/ - the adapter passes tests against the pinned version
- the adapter is registered in
src/runtime/registry.ts - the compiled output can be built and the runtime can boot at the pinned version
- if the runtime exposes a host-reachable service, a host-side smoke check succeeds against that service
Deprecating A Runtime
Section titled “Deprecating A Runtime”A runtime moves to deprecated when:
- the upstream project is archived or abandoned
- the adapter is no longer maintained
- the runtime’s config surface has diverged beyond reasonable adapter maintenance
Deprecated runtimes stay in the registry for reference but the compiler should warn when targeting them.
Operational discoveries about a pinned runtime version — build quirks, auth surfaces, health endpoints, container boot behavior — should be recorded in specs/research/RUNTIME-NOTES.md.
Relationship To Other Specs
Section titled “Relationship To Other Specs”- The Spawnfile Specification defines the
runtimefield in manifests — the name must match a registered runtime - The Compiler Specification defines how runtime adapters are invoked and how output is grouped by runtime
- The Container Compilation spec defines how runtime container metadata is used to generate Dockerfiles
research/RUNTIME-NOTES.mdcontains the per-runtime research that informs adapter design