Skip to main content

guildmaster — an agent and CLI that manages skills for the AgentCulture mesh.

Project description

guildmaster

An agent and CLI that manages skills for the AgentCulture mesh.

guildmaster is a sibling to steward (resident-agent alignment), culture (the IRC-based agent mesh), and daria (the awareness agent) in the Organic Development framework. Its mission is skill and skillversion management plus an overview surface for the mesh: per the settled division of labor (issue #1), guildmaster becomes the skills supplier/manager while steward retreats to agent-alignment. It onboards as a consumer first — vendoring the canonical skills like every other sibling — before taking over the upstream ledger, broadcast, and version tracking.

The repo and the Culture agent are named guildmaster; the CLI ships as guild-cli on PyPI and installs the guild binary.

Install

# From PyPI (Trusted Publishing):
uv tool install guild-cli

# From source (dev):
uv sync
uv run guild --version

Commands

All verbs are read-only, offline, and deterministic — safe to call in agent loops. Add --json to any of them for structured output.

Verb What it does
guild whoami Report this agent's identity — suffix + backend (from culture.yaml) + version. The smallest identity probe.
guild learn Survey the repo: the CLI verbs, the vendored skills under .claude/skills/, and a pointer to CLAUDE.md.
guild explain <topic> Explain one topic in depth — print a vendored skill's SKILL.md, or a verb's summary.
uv run guild whoami
uv run guild learn
uv run guild explain cicd

Supplier verbs — teach & onboard

As the mesh's skills supplier, guildmaster propagates skills to sibling agents through two agent-first write verbs. Both default to dry-run (render the issues and the ledger/verification diffs); --apply files them.

Verb What it does
guild teach --skill <name> … --to <agent> … Teach a chosen set of skills to a chosen set of mesh agents.
guild onboard --agent <owner/repo> Welcome a brand-new sibling with the full canonical kit, an identity-setup section, ledger registration, and a verification record.

Agent-major, not skill-major. A run files one GitHub issue per target agent, bundling a per-skill section for every skill that agent receives — not one issue per skill. New-vs-resync framing is auto-detected per (skill, agent) from the docs/skill-sources.md ledger. Skills must be chosen explicitly (--skill, repeatable, or --all) — there is no implicit default.

These supersede a separate announce-skill-update verb. teach is the single render-and-post engine; onboard is "teach the whole canonical kit" plus ledger registration, the identity section, and a verification record. There is no standalone broadcast verb (cf. issue #10, which asked for one — guildmaster fulfills the broadcast role via these two verbs instead).

Before → after. Today guildmaster has no broadcast verb of its own — steward runs the live broadcaster, and teaching a set of skills or standing up a new sibling is manual (hand-rendered briefs, hand-edited ledger, no verification). After: one command propagates a skill set, or onboards a sibling end-to-end. Going live is gated on the staged steward→guildmaster cutover — see docs/cutover.md.

Inventory verbs — overview & show

guildmaster owns the mesh's inventory surfaces (the read-only "what kit + config does an agent have?" view) per issue #12. Both are read-only — no --apply, no mutation, no drift verdict (judgment stays with steward overview / steward doctor).

Verb What it does
guild overview [--scope all|self <agent>|mesh] The supplier view: the canonical skill set + versions/origins, the docs/skill-sources.md ledger, and drift signals (uncovered skills, per-agent kit gaps). Feeds teach / onboard. --scope mesh instead surveys every agent's vendored skills live off the filesystem and flags what's missing/stale per agent.
guild show <path-or-suffix> One agent's full config in one view — its detected prompt file (CLAUDE.md / AGENTS.md / GEMINI.md), its parallel culture.yaml, and its .claude/skills index.
uv run guild overview                       # whole ledger + canonical set
uv run guild overview --scope self daria    # one agent's kit + gaps
uv run guild overview --scope mesh          # live survey: every agent's skills + missing/stale
uv run guild show ../culture                 # config by path
uv run guild show daria                      # config by registered suffix
uv run guild show ../culture --json          # structured config object

guild show resolves a registered suffix via the Culture server manifest (culture_server_yaml in .claude/skills.local.yaml); pass an explicit directory path to skip the lookup. Pre-cutover the ledger is still a consumer-side view with no downstream column, so overview's drift signals activate only after the steward→guildmaster cutover — the verb says so plainly.

Develop

uv sync
uv run pytest -n auto -v
uv run black --check guild tests && uv run isort --check-only guild tests
uv run flake8 guild tests && uv run bandit -c pyproject.toml -r guild

Every PR bumps the version (CI's version-check enforces it):

python3 .claude/skills/version-bump/scripts/bump.py patch

See CLAUDE.md for the full project shape, conventions, and the build/test/publish toolchain.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

guild_cli-0.4.2.tar.gz (149.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

guild_cli-0.4.2-py3-none-any.whl (41.2 kB view details)

Uploaded Python 3

File details

Details for the file guild_cli-0.4.2.tar.gz.

File metadata

  • Download URL: guild_cli-0.4.2.tar.gz
  • Upload date:
  • Size: 149.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for guild_cli-0.4.2.tar.gz
Algorithm Hash digest
SHA256 27c712af1a082a99942f556040f3dcbcec692a060b081d170c855b7ade0d3aa0
MD5 6d02fc4e31197f06eb5241e23ee07dd0
BLAKE2b-256 1c78a13a2a5d889c876cb437190234d4e47768669400eeb7fe67b38a8023c7e0

See more details on using hashes here.

File details

Details for the file guild_cli-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: guild_cli-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 41.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for guild_cli-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cc7f134ea6bf4a716d77f36fe1a23b5cfd71b03d0dfc35054b6a0f2a68fd2e83
MD5 f1eae7f2fa4d98d91eda0d35fc7a09fa
BLAKE2b-256 035e039ab42081be6fd26909636dfc1734b7b93aef0c990c4bc87d895d909db6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page