pstack/skills/interrogate/SKILL.md
Use for "interrogate", "adversarial review", "multi-model review", "challenge this", "stress test this code", "find blind spots", or "tear this apart". Four LLM reviewers challenge changes from independent angles.
npx skillsauth add cursor/plugins interrogateInstall 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.
Spawn four reviewers on four different models to adversarially review code changes. Each model gets the same prompt and rubric. The adversarial signal comes from model diversity, not assigned personas. Models differ in blind spots, priors, and reasoning patterns. Agreement across models is high-confidence signal; lone-model findings are worth reading but lower confidence.
The deliverable is a synthesized verdict. Do NOT auto-apply changes.
Identify what to review from context:
git diff main...HEAD (or the appropriate base branch) for the full changesetPackage the diff (or file contents) plus any surrounding context files the reviewers need to understand the code.
Before spawning reviewers, state the intent explicitly. What is this code trying to accomplish? Derive this from:
Write one clear paragraph. Reviewers challenge whether the work achieves the intent well, not whether the intent itself is correct. If you're unsure about the intent, ask the user before proceeding.
Launch all four in a single message using the Task tool, each with a different model.
| Subagent | Model |
|----------|-------|
| Reviewer A | claude-opus-4-8-thinking-xhigh |
| Reviewer B | gpt-5.3-codex-high-fast |
| Reviewer C | gpt-5.5-high-fast |
| Reviewer D | composer-2.5-fast |
For each reviewer:
subagent_type: generalPurposemodel: the model from the tablereadonly: trueIf a model slug in the table is rejected as unresolvable when you try to spawn the subagent, check the valid slugs in the Task tool's error message, pick the closest equivalent (prefer the highest-reasoning tier of the same family), spawn with the valid slug, and open a separate PR to update this table. Do not block the review on the slug issue.
Read references/reviewer-prompt.md and fill in the template with:
references/rubric.mdreferences/code-quality-review.mdThe same filled template goes to all four reviewers, so every model applies the code-quality lens.
Each reviewer produces structured findings as described in the prompt template.
As results come back, build a unified picture:
You are the lead reviewer, a pragmatic senior engineer, not a neutral aggregator.
Read references/lead-judgment.md for the full framework. Reviewers only see a slice of the codebase. You have the full context (the goal, the constraints, the timeline, which tradeoffs were already considered). Use that context aggressively.
Categorize every finding into one of four buckets:
For each finding, include:
Present the verdict in this structure:
[The stated intent paragraph from Step 2]
[Findings that should be addressed. For each: description, which models raised it, why it matters.]
[Findings worth thinking about. For each: description, which models raised it, tradeoff involved.]
[Valid but low-priority. Brief list.]
[Rejected findings with brief rationale. This shows the user what was filtered out and why, so they can override your judgment if they disagree.]
[Where did models agree, where did they diverge, and what does the pattern of agreement/disagreement tell us?]
development
Apply when you catch yourself writing the same instruction a second time, or notice a recurring correction. Encode the rule as a lint, metadata flag, runtime check, or script instead of more text.
tools
Apply to any non-trivial work, not just bulk work: edits, migrations, analyses, checks. Build the tool that does it or proves it (codemod, script, generator, or a skill your subagents follow) instead of working by hand. The tool is the artifact a reviewer can rerun.
tools
Use for 'why does X work this way', 'why we picked Y', design rationale, regressions, postmortems, or data-backed thresholds. Discovers available MCPs and queries each evidence category (source control, issue tracker, long-form docs, real-time chat, infrastructure observability, error tracking, product analytics warehouse) in parallel, then returns a cited read on decisions and tradeoffs. Use how for runtime behavior.
data-ai
Cut AI tells from any writing. Must always apply.