Drive any agent CLI from an agent-neutral source shape (AGENTS.md + .agents/skills), translating per harness at launch.
Project description
agedum
Latin agedum — "go on! / get going!"
Drive any agent CLI from an agent-neutral source shape, translating per harness at launch. You keep one set of sources; agedum renders them for whichever agent CLI you run.
- Instructions live in a root
AGENTS.md(plain markdown). - Skills live in
.agents/skills/<name>/asSKILL.md(+ optional task files, scripts, and a per-harnessSKILL.<harness>.mdoverlay).
At launch, agedum compiles that shape to the harness's native layout in a throwaway
dir, then runs your command inside a private mount namespace (bubblewrap) where
the compiled files appear at their expected paths — visible only to that process,
never written into your real tree or $HOME. For Claude: AGENTS.md → CLAUDE.md
and .agents/skills/<name>/ → .claude/skills/<name>/ (the base SKILL.md merged
with an optional SKILL.claude.md overlay).
Status: Claude harness, project + global scope, implemented. Each scope lands at its own Claude location — project →
./CLAUDE.md+./.claude/skills/, global (~/.config/agents/AGENTS.md+~/.agents/skills/) →~/.claude/CLAUDE.md
~/.claude/skills/(honours$CLAUDE_CONFIG_DIR). They're never merged; Claude reads both. Only those two~/.claudepaths are overlaid for the child — your~/.claude.jsonauth and other settings are untouched.kimi (
--kimi) is also supported. kimi reads the projectAGENTS.mdnatively, so agedum leaves it in place; it has no user-scopeAGENTS.md, so the globalAGENTS.mdis injected via a transient--agent-fileYAML (no--agent-fileis added when there's no global scope). Skills are binds: global →~/.kimi/skills/, project →./.kimi/skills/(both auto-read by kimi).opencode (
--opencode) is supported too — pure path-discovery, like Claude. The projectAGENTS.mdis read natively (./AGENTS.md); the globalAGENTS.mdbinds to~/.config/opencode/AGENTS.md; skills bind to./.opencode/skills/(project) and~/.config/opencode/skills/(global), both searched before.agents/skills/so the overlaid copy wins. No extra flags. Linux-only; requiresbwrapon PATH.
Usage
# Run a command with virtual files injected from the project + global source:
agedum --claude -- claude --model sonnet -p "review this"
agedum --claude -- claude # interactive
agedum --kimi -- kimi -p "explain this code"
agedum --opencode -- opencode run "explain this code"
agedum --version
Everything after -- is the command, run verbatim; the context flag before --
(--claude) chooses the format. The two are decoupled, so one context can front any
command. Injected paths must be gitignored — agedum refuses to overlay a git-tracked
file (the namespace shares your real .git).
Documentation
Full docs at agedum.vcoeur.com:
- Source shape — the structure of
AGENTS.mdand.agents/skills/ - Scopes — project vs global (user) scope, and where each lands
- Harnesses — exactly what agedum does for each
--<harness>command - CLI reference and Internals — the mount-namespace launch and its safety rules
Install
pipx install agedum # standalone CLI (once published)
Develop
make dev-install # uv sync --all-groups
make test # pytest
make lint # ruff check + format --check
make run -- --version
make docs # build the docs site (strict); docs-serve for live preview
Python ≥ 3.12, managed with uv. The version is
derived from the git tag (vX.Y.Z) at build time via hatch-vcs — never committed.
Release
Tag the commit vX.Y.Z and push the tag; the release workflow builds and
publishes to PyPI via OIDC trusted publishing.
License
MIT — see LICENSE.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file agedum-0.5.0.tar.gz.
File metadata
- Download URL: agedum-0.5.0.tar.gz
- Upload date:
- Size: 155.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d80bf7e7dc5ccc88458f591486750b97ddb3f7f470199c2a2a82af666e0e6279
|
|
| MD5 |
e81d76e6719fb7260752e41074876ce2
|
|
| BLAKE2b-256 |
95e2e12ef678fad676a3ce680cb0580d022f22f31227fb22ebafa17248b33bc2
|
Provenance
The following attestation bundles were made for agedum-0.5.0.tar.gz:
Publisher:
release.yml on vcoeur/agedum
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agedum-0.5.0.tar.gz -
Subject digest:
d80bf7e7dc5ccc88458f591486750b97ddb3f7f470199c2a2a82af666e0e6279 - Sigstore transparency entry: 1638978394
- Sigstore integration time:
-
Permalink:
vcoeur/agedum@b0af3a5f5c7c65cf15348850d21f9c7c75de0f19 -
Branch / Tag:
refs/tags/v0.5.0 - Owner: https://github.com/vcoeur
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@b0af3a5f5c7c65cf15348850d21f9c7c75de0f19 -
Trigger Event:
push
-
Statement type:
File details
Details for the file agedum-0.5.0-py3-none-any.whl.
File metadata
- Download URL: agedum-0.5.0-py3-none-any.whl
- Upload date:
- Size: 13.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
adaf192c56eedb54f68ad5fadc06d6149265c0d6d892992cab8f1e4181c436d3
|
|
| MD5 |
a616cd1e8976ae7b138a84d00e6bc858
|
|
| BLAKE2b-256 |
dd3bdd71e961b8ffe1b74a6191442d9775aef5e777f8df4a0326ab339fa725fc
|
Provenance
The following attestation bundles were made for agedum-0.5.0-py3-none-any.whl:
Publisher:
release.yml on vcoeur/agedum
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agedum-0.5.0-py3-none-any.whl -
Subject digest:
adaf192c56eedb54f68ad5fadc06d6149265c0d6d892992cab8f1e4181c436d3 - Sigstore transparency entry: 1638978559
- Sigstore integration time:
-
Permalink:
vcoeur/agedum@b0af3a5f5c7c65cf15348850d21f9c7c75de0f19 -
Branch / Tag:
refs/tags/v0.5.0 - Owner: https://github.com/vcoeur
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@b0af3a5f5c7c65cf15348850d21f9c7c75de0f19 -
Trigger Event:
push
-
Statement type: