Scaffold Exercises Create exercise directory structures that pass pnpm ai-hero-cli internal lint , then commit with git commit . Directory naming Sections : XX-section-name/ inside exercises/ (e.g., 01-retrieval-skill-building ) Exercises : XX.YY-exercise-name/ inside a section (e.g., 01.03-retrieval-with-bm25 ) Section number = XX , exercise number = XX.YY Names are dash-case (lowercase, hyphens) Exercise variants Each exercise needs at least one of these subfolders: problem/ - student workspace with TODOs solution/ - reference implementation explainer/ - conceptual material, no TODOs When stubbing, default to explainer/ unless the plan specifies otherwise. Required files Each subfolder ( problem/ , solution/ , explainer/ ) needs a readme.md that: Is not empty (must have real content, even a single title line works) Has no broken links When stubbing, create a minimal readme with a title and a description:
Exercise Title Description here If the subfolder has code, it also needs a main.ts (>1 line). But for stubs, a readme-only exercise is fine. Workflow Parse the plan - extract section names, exercise names, and variant types Create directories - mkdir -p for each path Create stub readmes - one readme.md per variant folder with a title Run lint - pnpm ai-hero-cli internal lint to validate Fix any errors - iterate until lint passes Lint rules summary The linter ( pnpm ai-hero-cli internal lint ) checks: Each exercise has subfolders ( problem/ , solution/ , explainer/ ) At least one of problem/ , explainer/ , or explainer.1/ exists readme.md exists and is non-empty in the primary subfolder No .gitkeep files No speaker-notes.md files No broken links in readmes No pnpm run exercise commands in readmes main.ts required per subfolder unless it's readme-only Moving/renaming exercises When renumbering or moving exercises: Use git mv (not mv ) to rename directories - preserves git history Update the numeric prefix to maintain order Re-run lint after moves Example: git mv exercises/01-retrieval/01.03-embeddings exercises/01-retrieval/01.04-embeddings Example: stubbing from a plan Given a plan like: Section 05: Memory Skill Building - 05.01 Introduction to Memory - 05.02 Short-term Memory (explainer + problem + solution) - 05.03 Long-term Memory Create: mkdir -p exercises/05-memory-skill-building/05.01-introduction-to-memory/explainer mkdir -p exercises/05-memory-skill-building/05.02-short-term-memory/ { explainer,problem,solution } mkdir -p exercises/05-memory-skill-building/05.03-long-term-memory/explainer Then create readme stubs: exercises/05-memory-skill-building/05.01-introduction-to-memory/explainer/readme.md -> "# Introduction to Memory" exercises/05-memory-skill-building/05.02-short-term-memory/explainer/readme.md -> "# Short-term Memory" exercises/05-memory-skill-building/05.02-short-term-memory/problem/readme.md -> "# Short-term Memory" exercises/05-memory-skill-building/05.02-short-term-memory/solution/readme.md -> "# Short-term Memory" exercises/05-memory-skill-building/05.03-long-term-memory/explainer/readme.md -> "# Long-term Memory"