skills/personafy/SKILL.md
Build a new opinionated advisor-persona skill — a reviewer "lens" like crusty-old-engineer — modeled on a real person or archetype and proven from real evidence. Mines the subject's authentic voice and discipline, defines its one distinct load-bearing question, drafts it to the family template, proves it steers in a live session, reduces it, and publishes it to a skills bundle. Use when creating or authoring a persona/advisor skill, adding a sibling to the crusty-old-engineer family, or turning a person's real direction style into a reusable reviewer skill. Also triggers on "personafy" / "personify".
npx skillsauth add microsoft/amplifier-bundle-skills personafyInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Build a new advisor-persona skill — an opinionated reviewer "lens" that joins an
existing family of sibling personas (e.g., crusty-old-engineer). The persona is
modeled on a real person or archetype, grounded in mined evidence, and enforces ONE
distinct recurring question.
Success artifact: a complete, family-conformant SKILL.md that is (a) grounded in
verbatim evidence, (b) proven to steer an LLM in a live session, (c) reduced to the
smallest set that still steers, and (d) loading from its target bundle in a fresh session.
<subject>: (Optional) The person or archetype to model, plus pointers to evidence
(session corpora, transcripts, docs). If no corpus exists, derive the persona from a
written conceptual brief instead.<family>: (Optional) The sibling persona skills to fit alongside. Defaults to the
advisor-persona family in amplifier-bundle-skills (e.g., crusty-old-engineer).Read the existing sibling persona skills' SKILL.md in full. Extract: the shared section
template, the frontmatter/metadata shape, the tone-contract pattern (required / disallowed
/ style), and — critically — the single load-bearing question each sibling owns and how
they cross-reference each other.
Success criteria: You can state each sibling's distinct question in one line and reproduce the shared template and metadata shape.
Run one or more existing personas live against a shared, realistic scenario — plus a combined "consensus" run — to see how the written instructions translate into actual behavior and steering.
self with context_depth="none" (one isolated run per persona).Success criteria: You've seen how each sibling's instructions become behavior, not just read them — enough to know what makes the steering work.
Name the ONE distinct recurring question the new persona enforces. Build a contrast table against every sibling.
Success criteria: A one-line lens plus a contrast table showing it is genuinely distinct from each sibling. Rule: if the question collapses into a sibling's, it is not a new persona — stop.
The heart of the method. Gather the subject's authentic voice and decision-discipline from real data (use the conceptual fallback only if no corpus exists).
bash (jq/grep/sed; never cat a huge session file — a single line can
exceed your context window).model_role="research".model_role="reasoning".Conceptual fallback (no corpus): derive the same profile fields from a written brief about the archetype; mark everything as designed-not-mined.
Success criteria: A consolidated profile where every load-bearing trait is backed by a verbatim quote (or explicitly marked as designed), ranked by corroboration, with synthetic noise excluded. Rule: ground every claim in real evidence; an honest "N/A — not observed" beats a fabricated trait. Artifacts: the profile file path.
Write the skill mirroring the siblings exactly: identity (defined by negation — "not X, not Y"), When-to-Use framed as a cross-stage lens, not a stage-gate, the tone contract (required / disallowed / style), Core Behaviors each anchored in a verbatim quote from the profile, an Output Structure, one worked Example, Explicit Non-Goals, a Relationship-to-siblings section, and a Final Note. Match the family's frontmatter format.
Success criteria: A complete draft, structurally identical to the siblings, every behavior grounded in the profile. Rule: keep the verbatim quotes — they are the highest-signal tokens and the soul of the persona.
Run the draft in a fresh CLI session against a real-ish scenario and confirm it adopts the voice and hits each behavior.
amplifier run --mode single --output-format text \
"Load the skill \"<name>\" and review the following as that persona: <realistic scenario>"
Success criteria: A transcript showing the persona behaving as designed (voice + each behavior firing). Rule: proof is demonstrated behavior — "the file exists" is NOT proof.
Apply context-reduction: cut redundancy to the smallest set that still steers (drop restated procedure, compress prose), but keep the verbatim quotes and the structural skeleton. Re-prove (Step 6) if the cut was heavy.
Success criteria: A leaner SKILL.md with the same steering power, verified.
Pick a name in the family's convention. A shareable archetype name (a generic role) → a public bundle; a name that references a real person → a private/team bundle.
Success criteria: Name chosen and target bundle decided — public vs private matched to whether the name exposes a real person.
Place SKILL.md at <bundle>/skills/<name>/SKILL.md. Verify the bundle exposes skills via
the canonical directory-discovery registration — its tool-skills config points
config.skills at the whole skills/ directory (#subdirectory=skills), so a new skill
dir is auto-discovered. Do NOT rely on per-skill wrapper behaviors. Then run the git
lifecycle.
foundation:git-ops.Success criteria: PR merged into the target bundle.
Rule: a SKILL.md in skills/ is NOT exposed unless the bundle points tool-skills
at the skills/ directory — registration is directory-based, not per-file.
Run amplifier update, then load the skill in a FRESH session and confirm loaded_from is
the bundle cache — not a local ~/.amplifier/skills copy.
Success criteria: load_skill resolves the skill from the bundle cache path in a clean
session.
Rule: "merged on main" ≠ "loads for a user" — verify discoverability end-to-end, the
same gate the persona itself would demand.
development
Simplicity-obsessed design reviewer that interrogates complexity, questions every abstraction, and insists on the minimal viable design. Sounds like a senior engineer who has watched too many systems collapse under their own weight and now treats every unnecessary layer as a personal affront. Not a generalist skeptic — a simplicity zealot. A lens for any checkpoint — brainstorm, design, plan, implement, debug, or review — not just design. Use when: anything looks more complex than the problem needs — a speculative idea, an abstraction, a layer, an over-built fix — any time the worry is "do we actually need this, or can it be deleted?"
tools
Curmudgeonly engineering advisor that provides grounded skepticism, evidence-linked judgment, and constructive progress on architectural decisions, legacy refactors, tooling choices, and broad "how should I start?" questions. Sounds like a senior systems engineer who has reviewed too many designs to be impressed, but still cares about correctness. A lens for any checkpoint — brainstorm, design, plan, implement, debug, or review — not just up-front decisions. Use when: weighing consequences, hidden costs, or failure modes of any choice — an idea, an architecture, a tooling/legacy call, an implementation path, or a fix — any time the worry is "what will this cost us later?"
testing
Use when verifying that completed work actually works. Auto-surface during /verify mode, post-implementation review, or before claiming a task is done. Teaches the discipline of testing outcomes vs implementation, the unit/integration/smoke gradient, and what "done" actually means.
development
Use when starting work in any repository. Auto-surface when an agent is about to write code, create a PR, or verify work. Teaches the discovery pattern for finding and applying per-repo conventions (AGENTS.md, PR templates, CONTRIBUTING.md) before acting.