4.2 KiB
Cross-Harness Architecture
ECC is the reusable workflow layer. Harnesses are execution surfaces.
The goal is to keep the durable parts of agentic work in one repo:
- skills
- rules and instructions
- hooks where the harness supports them
- MCP configuration
- install manifests
- session and orchestration patterns
Claude Code, Codex, OpenCode, Cursor, Gemini, and future harnesses should adapt those assets at the edge instead of requiring a new workflow model for every tool.
Portability Model
| Surface | Shared Source | Harness Adapter | Current Status |
|---|---|---|---|
| Skills | skills/*/SKILL.md |
Claude plugin, Codex plugin, .agents/skills, Cursor skill copies, OpenCode plugin/config |
Supported with harness-specific packaging |
| Rules and instructions | rules/, AGENTS.md, translated docs |
Claude rules install, Codex AGENTS.md, Cursor rules, OpenCode instructions |
Supported, but not identical across harnesses |
| Hooks | hooks/hooks.json, scripts/hooks/ |
Claude native hooks, OpenCode plugin events, Cursor hook adapter | Hook-backed in Claude/OpenCode/Cursor; instruction-backed in Codex |
| MCPs | .mcp.json, mcp-configs/ |
Native MCP config import per harness | Supported where the harness exposes MCP |
| Commands | commands/, CLI scripts |
Claude slash commands, compatibility shims, CLI entrypoints | Supported, but command semantics vary |
| Sessions | ecc2/, session adapters, orchestration scripts |
TUI/daemon, tmux/worktree orchestration, harness-specific runners | Alpha |
What Travels Unchanged
SKILL.md is the most portable unit.
A good ECC skill should:
- use YAML frontmatter with
name,description, andorigin - describe when to use the skill
- state required tools or connectors without embedding secrets
- keep examples repo-relative or generic
- avoid harness-only command assumptions unless the section is clearly labeled
The same source skill can be installed into multiple harnesses because it is mostly instructions, constraints, and workflow shape.
What Gets Adapted
Each harness has different loading and enforcement behavior:
- Claude Code loads plugin assets and has native hook execution.
- Codex reads
AGENTS.md, plugin metadata, skills, and MCP config, but hook parity is instruction-driven. - OpenCode has a plugin/event system that can reuse ECC hook logic through an adapter layer.
- Cursor uses its own rule and hook layout, so ECC maintains translated surfaces under
.cursor/. - Gemini support is install/instruction oriented and should be treated as a compatibility surface, not as full hook parity.
Adapters should stay thin. The shared behavior belongs in skills/, rules/, hooks/, scripts/, and mcp-configs/.
Hermes Boundary
Hermes is not the public ECC runtime.
Hermes is an operator shell that can consume ECC assets:
- import selected ECC skills into a Hermes skills directory
- use ECC MCP conventions for tool access
- route chat, CLI, cron, and handoff workflows through reusable ECC patterns
- distill repeated local operator work back into sanitized ECC skills
The public repo should ship reusable patterns, not local Hermes state.
Do ship:
- sanitized setup docs
- repo-relative demo prompts
- general operator skills
- examples that do not depend on private credentials
Do not ship:
- OAuth tokens or API keys
- raw
~/.hermesexports - personal workspace memory
- private datasets
- local-only automation packs that have not been reviewed
Today vs Later
Supported today:
- shared skill source in
skills/ - Claude Code plugin packaging
- Codex plugin metadata and MCP reference config
- OpenCode package/plugin surface
- Cursor-adapted rules, hooks, and skills
ecc2/as an alpha Rust control plane
Still maturing:
- exact hook parity across all harnesses
- automated skill sync into Hermes
- release packaging for
ecc2/ - cross-harness session resume semantics
- deeper memory and operator planning layers
Rule For New Work
When adding a workflow, put the durable behavior in ECC first.
Use harness-specific files only for:
- loading the shared asset
- adapting event shapes
- mapping command names
- handling platform limits
If a workflow only works in one harness, document that boundary directly.