with one click
learn
// [Utilities] Use when you need to teach Claude lessons that persist across sessions.
// [Utilities] Use when you need to teach Claude lessons that persist across sessions.
[HINT] Download the complete skill directory including SKILL.md and all related files
| name | learn |
| version | 4.0.0 |
| description | [Utilities] Use when you need to teach Claude lessons that persist across sessions. |
| disable-model-invocation | false |
Goal: Teach Claude lessons that persist across sessions by saving to the most relevant reference doc.
Workflow:
Learn Review + /why-review)/prompt-enhance on modified file(s) to optimize AI attention anchoringKey Rules:
docs/project-reference/lessons.mdBe skeptical. Apply critical thinking, sequential thinking. Every claim needs traced proof, confidence percentages (Idea should be more than 80%).
/learn always use the validation framework fluent API instead of throwing ValidationException
/learn never call external APIs in command handlers - use Entity Event Handlers
/learn prefer async/await over .then() chains
/learn list
/learn remove 3
/learn clear
Each docs/project-reference/ file is auto-initialized by session-init-docs.cjs hook and populated by /scan-* skills. Understanding their roles is critical for correct routing.
| File | Role & Content | Injected By | Injection Trigger | Scan Skill |
|---|---|---|---|---|
project-structure-reference.md | Architecture, directory tree, tech stack, module registry, service map | subagent-init-*.cjs (18 hooks) | Agent spawn | /scan-project-structure |
backend-patterns-reference.md | Backend/hook patterns: CJS modules, CQRS, repositories, validation, message bus, background jobs | code-patterns-injector.cjs, backend-context.cjs | Edit/Write backend files | /scan-backend-patterns |
seed-test-data-reference.md | Seed/dev-data patterns: environment gate, idempotency loop, DI scope safety, command-dispatch | Referenced in config + seed workflows | Seeder/DataSeeder file edits | /scan-seed-test-data |
frontend-patterns-reference.md | Frontend patterns: components, state mgmt, API services, styling conventions, directives | code-patterns-injector.cjs, frontend-context.cjs | Edit/Write frontend files | /scan-frontend-patterns |
integration-test-reference.md | Test architecture: base classes, fixtures, helpers, service-specific setup, test runners | Referenced in config | Test file edits | /scan-integration-tests |
feature-docs-reference.md | Feature doc templates, app-to-service mapping, doc structure conventions | On-demand (skill reads) | Skill activation | /scan-feature-docs |
code-review-rules.md | Review rules, conventions, anti-patterns, decision trees, checklists | code-review-rules-injector.cjs | Review skill activation | /scan-code-review-rules |
lessons.md | General lessons — fallback catch-all. Injected on EVERY prompt (budget-controlled) | prompt-injections.cjs | Every UserPromptSubmit + Edit/Write | Managed by /learn |
scss-styling-guide.md | SCSS/CSS: BEM methodology, mixins, variables, theming, responsive patterns | design-system-context.cjs | Styling file edits | /scan-scss-styling |
design-system/README.md | Design system: tokens overview, component inventory, app-to-doc mapping | design-system-context.cjs | Design file edits | /scan-design-system |
e2e-test-reference.md | E2E test patterns: framework, page objects, config, best practices | code-patterns-injector.cjs | E2E file edits | /scan-e2e-tests |
domain-entities-reference.md | Domain entities, data models, DTOs, aggregate boundaries, ER diagrams, cross-service sync | backend-context.cjs, frontend-context.cjs | Backend/frontend file edits | /scan-domain-entities |
docs-index-reference.md | Documentation tree, file counts, doc relationships, keyword-to-doc lookup | On-demand (manual) | Manual reference | /scan-docs-index |
Key insight: Files injected automatically by hooks have higher visibility — lessons placed enforced during edits. Files injected on-demand are only seen when skills explicitly read them. Prefer auto-injected files for high-recurrence lessons.
| Gate | Question | Pass | Fail → Action |
|---|---|---|---|
| Recurrence | "Would this mistake recur in a future session WITHOUT this reminder?" | Yes → continue | No → skip /learn; mistake is situational |
| Auto-fix | "Could /code-review, /simplify, /security, or /lint catch this automatically?" | No → continue | Yes → skip /learn; update the review skill instead |
Both gates must pass. A lesson review skills already catch adds noise without value. A one-off situational mistake won't be prevented by a persisted rule.
Route to the most relevant file based on lesson content:
| If lesson is about... | Route to | Section hint |
|---|---|---|
| Code review rules, anti-patterns, review checklists, YAGNI/KISS/DRY, naming conventions, review process | docs/project-reference/code-review-rules.md | Add to most relevant section (anti-patterns, rules, checklists) |
| Backend/hook patterns: CJS modules, CQRS, repositories, entities, validation, message bus, background jobs, migrations, EF Core, MongoDB | docs/project-reference/backend-patterns-reference.md | Add to relevant section or Anti-Patterns section |
| Frontend Angular/TS patterns: components, stores, forms, API services, BEM, RxJS, directives, pipes | docs/project-reference/frontend-patterns-reference.md | Add to relevant section or Anti-Patterns section |
| Integration/unit tests: test base classes, fixtures, test helpers, test patterns, assertions, test runners | docs/project-reference/integration-test-reference.md | Add to relevant section |
| E2E tests: Playwright, Cypress, Selenium, page objects, E2E config, browser automation, visual regression | docs/project-reference/e2e-test-reference.md | Add to relevant section |
| Domain entities, data models, DTOs, aggregates, entity relationships, cross-service data sync, ER diagrams | docs/project-reference/domain-entities-reference.md | Add to Entity Catalog or Relationships section |
| Project structure, directory organization, module boundaries, tech stack choices, service architecture | docs/project-reference/project-structure-reference.md | Add to relevant architecture section |
| SCSS/CSS styling, BEM methodology, mixins, variables, theming, responsive design, CSS conventions | docs/project-reference/scss-styling-guide.md | Add to relevant styling section |
| Design system, design tokens, component library, UI kit conventions, Figma-to-code patterns | docs/project-reference/design-system/README.md | Add to relevant design section |
| Feature documentation, doc templates, doc structure conventions, app-to-service doc mapping | docs/project-reference/feature-docs-reference.md | Add to relevant conventions section |
| Documentation indexing, doc organization, doc-to-code relationships, doc lookup patterns | docs/project-reference/docs-index-reference.md | Add to relevant section |
| General lessons, workflow tips, tooling, AI behavior, project conventions, anything not matching above | docs/project-reference/lessons.md | Append as dated list entry |
Before saving any lesson, critically evaluate whether a doc update alone is sufficient or a deeper prevention mechanism is needed:
| Prevention Layer | When to use | Example |
|---|---|---|
| Doc update only | One-off awareness, rare edge case, team convention | "Always use fluent validation API" → docs/project-reference/backend-patterns-reference.md |
Prompt rule (development-rules.md) | Rule that ALL agents must follow on every task (injected on UserPromptSubmit) | "Grep after bulk edits" → .claude/docs/development-rules.md |
System Lesson (prompt-injections.cjs) | Universal AI mistake, high recurrence, silent failure, any project | "Re-read files after context compaction" → .claude/hooks/lib/prompt-injections.cjs |
Hook (.claude/hooks/) | Automated enforcement, must never be forgotten | "Dedup markers must match" → lib/dedup-constants.cjs + consistency test |
Test (.claude/hooks/tests/) | Regression prevention, verifiable invariant | "All hooks import from shared module" → test in test-all-hooks.cjs |
Skill update (.claude/skills/) | Workflow step that should always include this check | "Review changes must check doc staleness" → skill SKILL.md update |
Decision flow:
AskUserQuestion:
development-rules.md so all agents see itprompt-injections.cjs System Lessons (see criteria below)/plan instead of just saving.After generalizing a lesson, evaluate whether it qualifies as a System Lesson in .claude/hooks/lib/prompt-injections.cjs. System Lessons are injected into EVERY prompt — they are the highest-visibility prevention layer.
Qualification criteria (ALL must be true):
System Lessons — Universal AI mistake prevention rules injected into EVERY prompt. Stored in
injectAiMistakePrevention()→ "Common AI Mistake Prevention" array. Each must be universal, high-recurrence, and silent-failure. READ.claude/hooks/lib/prompt-injections.cjsto check for duplicates before adding.
If qualified: Recommend "Doc + System Lesson" option. On user approval, append the lesson as a new bullet to the System Lessons array in prompt-injections.cjs following the existing format: `- **Bold title.** Explanation sentence.`
If NOT qualified: Explain why (e.g., "Too project-specific", "Already covered by existing System Lesson about X", "Low recurrence — only happens in rare edge cases"). Proceed with doc-only or prompt-rule option.
Every lesson MUST be root-cause level and generic across any codebase. Apply this 3-step extraction before saving:
Step 1 — Name the FAILURE MODE, not the symptom:
The failure mode is the reasoning or assumption that broke — not what the output looked like.
| Symptom (BAD — reject this) | Failure mode (GOOD — save this) |
|---|---|
| "Used wrong enum value" | "Generated code using an assumed API without verifying it exists in source" |
| "Wrong namespace/import" | "Assumed project setup from convention without reading project-specific config files first" |
| "Happy-path test failed in CI" | "Wrote assertions without tracing what runtime infrastructure the code path requires" |
| "Set properties that don't exist" | "Assumed all types in a hierarchy share the same interface without reading the base class" |
| "Always read file X before Y" | "Assumed execution context without reading the owning layer's contract — fixed at symptom site instead of cause" |
Step 2 — Verify generality:
Does this failure mode apply to ≥3 different contexts or codebases? If only one file or one specific case → go up one abstraction level. A good lesson prevents an entire class of mistakes.
Step 3 — Write as a universal rule:
Anti-pattern examples:
lib/dedup-constants.cjs for marker strings" → project-specific path.claude/docs/hooks/README.md after deleting hooks" → project-specific fileRun these 2 tasks at the end of every /learn operation:
Task 1 — Learn Review (value + generality + recurrence):
docs/project-reference/lessons.md (injected on every prompt), apply stricter bar: high impact + high recurrence only.Task 2 — Run /why-review (adversarial challenge):
/why-review to challenge whether this lesson deserves persistent memory./code-review, /simplify, /security, /lint, hook/test) are insufficient./learn.docs/{file}. Confirm? [Y/n]"For docs/project-reference/lessons.md (general lessons):
- [YYYY-MM-DD] <lesson text>
For pattern/rules files (code-review-rules, backend-patterns, frontend-patterns, integration-test):
docs/project-reference/lessons.md)docs/project-reference/lessons.md is injected into EVERY prompt and EVERY file edit. Token budget must be controlled.
Hard limit: 10000 characters (~3333 tokens). Check BEFORE saving any new lesson.
Workflow when adding to docs/project-reference/lessons.md:
wc -c docs/project-reference/lessons.md)Budget Trim process:
AskUserQuestion: "Budget exceeded. Recommend removing/condensing these LOW/MEDIUM items: [list]. Approve?"Condensing rules:
"Patterns like X break Y syntax" → just state the ruleDoes NOT apply to: Other routing targets (backend-patterns-reference.md, code-review-rules.md, etc.) — those files have their own size and are injected contextually, not on every prompt.
/learn <text> — Route and append lesson to the best-fit file (check budget if target is lessons.md)/learn list — Read and display lessons from ALL 12 target files (show file grouping + char count for lessons.md)/learn remove <N> — Remove lesson from docs/project-reference/lessons.md by line number/learn clear — Clear all lessons from docs/project-reference/lessons.md only (confirm first)/learn trim — Manually trigger Budget Trim on docs/project-reference/lessons.mdWhen Claude detects correction phrases in conversation (e.g., "always use X", "remember this", "never do Y", "from now on"), this skill auto-activates. When auto-inferred (not explicit /learn), confirm with the user before saving: "Save this as a lesson? [Y/n]"
Lessons are injected by lessons-injector.cjs hook on:
docs/project-reference/lessons.md content (with dedup)docs/project-reference/lessons.md content (always)code-patterns-injector.cjs, code-review-rules-injector.cjs, etc.)After saving a lesson to any target file, run /prompt-enhance on the modified file(s) to optimize AI attention anchoring and token quality.
When to run:
What it does:
How to invoke:
/prompt-enhance docs/project-reference/<modified-file>.md
Skip conditions (do NOT run prompt-enhance if):
lessons.md AND the file is under 1500 chars (too small to benefit)[IMPORTANT] Use
TaskCreateto break ALL work into small tasks BEFORE starting — including tasks for each file read. This prevents context loss from long files. For simple tasks, AI MUST ATTENTION ask user whether to skip.Mandatory end tasks are ALWAYS (in order):
- "Run Learn Review (lesson value + generality + recurrence gate)."
- "Run
/why-reviewto challenge whether the lesson is worth persistent memory."- "Run
/prompt-enhance <modified-file>to optimize lesson content for AI attention anchoring."Do NOT mark the skill complete until all 3 tasks run.
AI Mistake Prevention — Failure modes to avoid on every task:
Check downstream references before deleting. Deleting components causes documentation and code staleness cascades. Map all referencing files before removal. Verify AI-generated content against actual code. AI hallucinates APIs, class names, and method signatures. Always grep to confirm existence before documenting or referencing. Trace full dependency chain after edits. Changing a definition misses downstream variables and consumers derived from it. Always trace the full chain. Trace ALL code paths when verifying correctness. Confirming code exists is not confirming it executes. Always trace early exits, error branches, and conditional skips — not just happy path. When debugging, ask "whose responsibility?" before fixing. Trace whether bug is in caller (wrong data) or callee (wrong handling). Fix at responsible layer — never patch symptom site. Assume existing values are intentional — ask WHY before changing. Before changing any constant, limit, flag, or pattern: read comments, check git blame, examine surrounding code. Verify ALL affected outputs, not just the first. Changes touching multiple stacks require verifying EVERY output. One green check is not all green checks. Holistic-first debugging — resist nearest-attention trap. When investigating any failure, list EVERY precondition first (config, env vars, DB names, endpoints, DI registrations, data preconditions), then verify each against evidence before forming any code-layer hypothesis. Surgical changes — apply the diff test. Bug fix: every changed line must trace directly to the bug. Don't restyle or improve adjacent code. Enhancement task: implement improvements AND announce them explicitly. Surface ambiguity before coding — don't pick silently. If request has multiple interpretations, present each with effort estimate and ask. Never assume all-records, file-based, or more complex path.
Critical Thinking Mindset — Apply critical thinking, sequential thinking. Every claim needs traced proof, confidence >80% to act. Anti-hallucination: Never present guess as fact — cite sources for every claim, admit uncertainty freely, self-check output for errors, cross-reference independently, stay skeptical of own confidence — certainty without evidence root of all hallucination.
MUST ATTENTION apply critical thinking — every claim needs traced proof, confidence >80% to act. Anti-hallucination: never present guess as fact.
MUST ATTENTION apply AI mistake prevention — holistic-first debugging, fix at responsible layer, surface ambiguity before coding, re-read files after compaction.
IMPORTANT MUST ATTENTION run Triage Gate FIRST — if recurrence is low OR review skills can catch it, skip /learn entirely
IMPORTANT MUST ATTENTION check Reference Doc Catalog to find the best target file — NOT always lessons.md
IMPORTANT MUST ATTENTION mandatory end tasks are ALWAYS: Learn Review → /why-review → /prompt-enhance <modified-file> (in order)
IMPORTANT MUST ATTENTION break work into small todo tasks using TaskCreate BEFORE starting
IMPORTANT MUST ATTENTION prefer auto-injected files for high-recurrence lessons (higher visibility)
[TASK-PLANNING] Before acting, analyze task scope and systematically break it into small todo tasks and sub-tasks using TaskCreate.