Instruction generation

Type: kb/types/note.md · Status: current

How commonplace instantiates build-time generation over runtime parameterisation in the shipped system. This note describes the scaffold, template substitution, and install entry point.

The entry point

commonplace-init is the single build/install step. It creates the project directory structure, copies scaffold trees verbatim, and resolves a small set of templates with per-project values. Everything a new commonplace project needs is produced by this one command.

There are no runtime variables in the generated artifacts. AGENTS.md, skill definitions, and configuration files contain literal paths and names by the time an agent sees them.

Substitution points

init_project resolves three placeholder kinds during template processing:

Placeholder Replaced with Source
<your-project> Project directory name (or --name override) CLI argument or root.name
{{project_name}} Same same
/PATH/TO/COMMONPLACE/ Absolute path to the project root, with trailing slash root resolved to absolute path

Substitution is a flat string replace in _write_template. Templates that don't need substitution (scaffold trees) are copied byte-for-byte instead.

Generated artifacts

commonplace-init produces four kinds of output:

Directories (from DEFAULT_DIRS) — empty directory shells the practitioner fills in:

  • kb/types/ — shared global types
  • kb/notes/, kb/notes/types/ — user's notes collection
  • kb/reference/, kb/reference/types/ — user's reference collection
  • kb/instructions/ — user's instructions collection
  • kb/sources/, kb/sources/types/ — user's source captures
  • kb/tasks/backlog/, kb/tasks/active/, kb/tasks/completed/ — user's task lifecycle
  • kb/work/, kb/reports/, kb/reports/connect/, kb/reports/types/ — user's workshops and reports

Scaffold trees — copied from packaged scaffold assets:

  • kb/commonplace/notes/ — shipped methodology library (from our kb/notes/)
  • kb/commonplace/reference/ — shipped-system documentation and ADRs
  • kb/commonplace/instructions/ — shipped procedures and cp-skill-* skills
  • kb/commonplace/agent-memory-systems/ — shipped reviews of external systems
  • kb/types/ — shared global types (text, note, instruction, definition, index)
  • kb/reports/types/, kb/sources/types/ — collection-local type definitions for user-space collections

Scaffold files — individual files copied into the user's collections:

  • kb/notes/COLLECTION.md — minimal theoretical/descriptive/prescriptive template
  • kb/reference/COLLECTION.md — minimal template
  • kb/instructions/COLLECTION.md — minimal template

Each template invites the practitioner to pick a register, state a quality goal, and declare outbound link rules, with pointers to the shipped kb/commonplace/<collection>/COLLECTION.md as a worked example.

Resolved templates — read, substituted, written:

  • AGENTS.md.templateAGENTS.md.template in the target root (practitioner then copies or renames to AGENTS.md)
  • .envrc.template.envrc

Both flow through the same _write_template helper with the same replacements dictionary.

Skill promotion

In addition to copying the instructions tree under kb/commonplace/instructions/, init_project promotes a selected subset of skills (write, validate, connect, convert, ingest, snapshot-web, revise-iterative, revise-autoreason) into runtime discovery directories for multiple harnesses:

  • .claude/skills/cp-skill-<skill>/
  • .agents/skills/cp-skill-<skill>/

Each promotion is a symlink pointing at kb/commonplace/instructions/cp-skill-<skill>/. This keeps skill discovery working in each runtime while the canonical skill content stays in one place inside the shipped library — edits to the library update both harnesses' views simultaneously.

Re-running init

init_project is idempotent-ish. Existing files are classified into three groups by _record_existing:

  • Identical to scaffold — silently preserved
  • Different from scaffold — preserved without overwriting, reported as "preserved existing files differing from current scaffold output" so the operator can decide whether to diff and update manually
  • Missing — created fresh

The rule is "never clobber a practitioner edit." Updating an installed project to a newer commonplace release is a manual diff-and-merge step, not a re-run.

What's not generated

A short list of things that are still authored by hand rather than generated:

  • Static-site navigation configuration, if a project publishes the KB as a site
  • Per-project customisation of the ## KB Goals section in a generated AGENTS.md — the template carries placeholder prose; the practitioner fills in real values

These could all move to generated form later, but the current build-time step covers the cases where runtime parameterisation would have cost the most interpretation overhead: paths in promoted skills and the project name stamped into the control-plane template.


Relevant Notes: