Starweaver
Starweaver is a Rust agent SDK for building local-first AI agents, CLIs, and service runtimes. It gives you a typed agent loop, provider-neutral model protocol, function tools, structured output, durable session primitives, first-party environment tools, and a CLI product surface in one workspace.
Why Starweaver
- Rust-native agent construction with
AgentBuilder,AgentApp, andAgentSession. - Provider-neutral model messages, settings, profiles, streaming parts, and request audit hooks.
- Typed function tools from Serde and
schemars, plus toolsets, metadata, retries, approval, and deferred records. - Structured output through JSON Schema, typed parsing, output functions, and validation retry.
- Runtime extension hooks for prompt preparation, request shaping, tool policy, output validation, usage, and trace recording.
- Durable execution foundations: context export/restore, checkpoints, session records, replay streams, and SQLite storage adapters.
- First-party SDK bundles for filesystem, shell, skills, task tracking, host search/scrape/media adapters, MCP, and subagents.
- A CLI launcher with profile-based local runs, install/update flow, display messages, local storage, and release artifacts.
Install
Install the latest public release:
|
The installer downloads the matching starweaver-cli archive, verifies checksums.txt when
available, and installs starweaver, starweaver-cli, sw, and starweaver-rpc. It installs into
$HOME/.local/bin for normal users and /usr/local/bin for root. Override the location when
needed:
| STARWEAVER_INSTALL_DIR="/bin"
Install a pinned release or prerelease:
| STARWEAVER_VERSION=vX.Y.Z
The default latest channel uses GitHub's latest stable release first and falls back to the
newest public prerelease when no stable release exists yet.
Update an installed CLI from GitHub release artifacts:
The update command checks the current CLI package version before invoking the installer. When the
selected release is already installed it exits with status=up-to-date; pass --force to reinstall
the same version.
Run from a checkout:
SDK Quickstart
use Arc;
use ;
# async
Add typed tools:
use Arc;
use JsonSchema;
use ;
use ;
# async
Documentation
Published docs: https://starweaver.wh1isper.top
Start here:
Architecture and product decisions live in spec/. User-facing guides live in docs/.
Workspace
Starweaver is organized as focused crates:
starweaver-agent: public SDK facade, app/session helpers, bundles, subagents, profiles, and filters.starweaver-runtime: deterministic agent loop, graph state, tools, output, retries, capabilities, streams, traces, and checkpoints.starweaver-model: provider-neutral model protocol, settings, profiles, transports, wrappers, OAuth-backed adapters, and replay tests.starweaver-tools: function tools, toolsets, metadata, lifecycle, MCP foundations, approval, and deferred execution.starweaver-context:AgentContext, typed dependencies, state, event/message buses, notes, usage, and resumable state.starweaver-environment: local and virtual filesystem/shell providers, policies, resources, and environment snapshots.starweaver-session,starweaver-stream,starweaver-storage: durable session, replay, display stream, and SQLite storage contracts.starweaver-cli: local CLI product surface, launcher dispatch, profiles, TUI, storage, install, and update workflows.starweaver-rpc-core: shared JSON-RPC host protocol helpers and stream/replay projections.starweaver-rpc: standalone JSON-RPC host process for Desktop and local host integrations.
Validation
Full local gate:
Release
Prepare a release:
The workflow pushes release/vX.Y.Z for review. After that release commit reaches main, publish vX.Y.Z as a GitHub Release; the published Release event builds CLI archives, uploads checksums, and publishes crates through the Release environment.
Acknowledgements
Thank you to the projects that helped shape Starweaver's thinking, especially Pydantic AI and Yet Another Agents / ya-mono.
License
BSD-3-Clause