S

scaffold-exercises

by @mattpocockv
4.4(20)

lint準拠の演習ディレクトリ構造を自動作成し、チェックを実行してコードを提出することで、コース演習環境のセットアッププロセスを簡素化します。

learning-resourcestutorial-generationskill-developmentautomationGitHub
インストール方法
npx skills add mattpocock/skills --skill scaffold-exercises
compare_arrows

Before / After 効果比較

1
使用前

ネストされたディレクトリ構造を手動で作成し、設定ファイルを記述し、フォーマットの問題を修正するために繰り返しlintを実行します。1回の演習環境セットアップに20分かかります。

使用後

規範に準拠したディレクトリ構造と設定ファイルを自動生成し、ワンクリックでlintチェックをパスして提出し、3分で演習環境セットアップを完了します。

SKILL.md

scaffold-exercises

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"

Weekly Installs210Repositorymattpocock/skillsGitHub Stars4.6KFirst Seen7 days agoSecurity AuditsGen Agent Trust HubPassSocketPassSnykPassInstalled oncodex201gemini-cli198cursor198github-copilot197kimi-cli197amp197

ユーザーレビュー (0)

レビューを書く

効果
使いやすさ
ドキュメント
互換性

レビューなし

統計データ

インストール数3.4K
評価4.4 / 5.0
バージョン
更新日2026年5月19日
比較事例1 件

ユーザー評価

4.4(20)
5
25%
4
50%
3
25%
2
0%
1
0%

この Skill を評価

0.0

対応プラットフォーム

🔧Claude Code

タイムライン

作成2026年3月20日
最終更新2026年5月19日