Help us improve
Share bugs, ideas, or general feedback.
From mattpocock-skills
Turns the workspace into a stateful teaching environment with a mission, glossary, learning records, and progression tracking.
npx claudepluginhub joshuarweaver/cascade-content-creation-misc-1 --plugin mattpocock-skills-11How this skill is triggered — by the user, by Claude, or both
Slash command
/mattpocock-skills:teach What would you like to learn about?What would you like to learn about?The summary Claude sees in its skill listing — used to decide when to auto-load this skill
The user has asked you to teach them something. This is a stateful request - they intend to learn the topic over multiple sessions.
Teaches a new skill or concept across multiple sessions. Creates a structured learning workspace with mission, glossary, resources, and learning records files. Guides knowledge acquisition and skill exercises using interactive HTML explainers and feedback loops.
Teaches concepts adaptively: assesses learner level, scaffolds from known to unknown using Zone of Proximal Development, employs Socratic questioning, adapts to feedback. For 'how does X work?' queries revealing gaps or failed prior explanations.
Delivers structured multi-session tutoring for technical topics with Socratic diagnostics, knowledge graphs for prerequisites, agendas, teaching, quizzes, and progress tracking.
Share bugs, ideas, or general feedback.
The user has asked you to teach them something. This is a stateful request - they intend to learn the topic over multiple sessions.
Treat the current directory as a teaching workspace. The state of their learning is captured in this directory in several files:
MISSION.md: A document capturing the reason the user is interested in the topic. This should be used to ground all teaching. Use the format in MISSION-FORMAT.md.GLOSSARY.md: A glossary of terminology related to the topic. All workspace files should adhere to this terminology. Use the format in GLOSSARY-FORMAT.md.RESOURCES.md: A list of resources which can be explored to ground your teaching in contextual knowledge, or to acquire knowledge and wisdom. Use the format in RESOURCES-FORMAT.md../learning-records/*.md: A directory of learning records, which capture what the user has learned. These are loosely equivalent to architectural decision records in software development - they capture non-obvious lessons and key insights that may need to be revised later, or drive future sessions. These should be used to calculate the zone of proximal development. They are titled 0001-<dash-case-name>.md, where the number increments each time. Use the format in LEARNING-RECORD-FORMAT.md.To learn at a deep level, the user needs three things:
Before the RESOURCES.md is well-populated, your focus should be to find high-quality resources which will help the user acquire knowledge. Never trust your parametric knowledge.
Some topics may require more skills than knowledge. Learning more about theoretical physics might be more knowledge-based. For yoga, more skills-based.
Every teaching session should be tied into the mission - the reason that the user is interested in learning about the topic.
If the user is unclear about the mission, or the MISSION.md is not populated, your first job should be to question the user on why they want to learn this.
Failing to understand the mission will mean knowledge acquisition is not grounded in real-world goals. Exercises will feel too abstract. You will have no way of judging what the user should do next.
The user should always feel as if they are being challenged 'just enough'. The scope of the topic being taught should feel extremely tight, should be directly tied into their mission.
The user may specify an exact thing they want to learn. If they don't, figure out their zone of proximal development by:
learning-recordsA user may tell you that they already know about that topic. If so, record it in their learning-records.
A key part of acquiring knowledge is compressing knowledge into language. Once a term is known and understood, it can be used and combined in new ways to make more complex terms easier to understand.
Building the glossary should be done once you feel confident that the user understands the term. Glossaries should use a strict format, and use as concise a definition as possible.
Knowledge and skills usually need to be taught as a 1-2 punch. You teach the knowledge first, then get the user to practice the skills via exercises.
Knowledge should first be gathered from trusted resources, then taught to the user via HTML explainers. These explainers should be beautiful, adhere to the glossary, and be saved to the local file system where they can be reviewed later.
Explainers should be littered with citations - links to external resources to back up any claim made.
Explainers should be as interactive as possible, with "try this" callouts to let the user try the knowledge.
You should make opening the HTML explainer as easy as possible for the user, ideally with a CLI command they can run.
Once the user has read the knowledge, allow them to ask questions about it. Answer their questions directly, and amend the explainer if needed (or produce another one).
At this point, you can amend the glossary if it appears clear they understand a term.
Skills should be taught through interactive exercises. There are several tools at your disposal:
Each exercise should be based on a feedback loop, where the user receives feedback on their performance. This feedback loop should be as tight as possible, giving feedback immediately.
Wisdom comes from true real-world interaction - testing your skills outside the learning environment.
When the user asks a question that appears to require wisdom, your default posture should be to attempt to answer - but to ultimately delegate to a community.
A community is a place (online or offline) where the user can test their skills in the real world. This might be a forum, a subreddit, a real-world class (budget permitting) or a local interest group.
You should attempt to find high-reputation communities the user can join. If the user expresses a preference that they don't want to join a community, respect it.