Agent skill
fact-check
Verify claims in backlog items, skill documentation, or plugin content against primary sources using web lookups. Spawns parallel verification agents that MUST use WebFetch/WebSearch/gh — training data recall is explicitly rejected as evidence. Produces VERIFIED/REFUTED/INCONCLUSIVE verdicts with citations. Triggers on "fact check", "verify claims", "check against primary sources", or when backlog items are marked UNVERIFIED.
Install this agent skill to your Project
npx add-skill https://github.com/Jamie-BitFlight/claude_skills/tree/main/.claude/skills/fact-check
SKILL.md
Fact Check — Primary Source Claim Verification
Verify factual claims against primary sources using web lookups. Training data recall is NOT evidence.
When to Use
- Backlog items marked
UNVERIFIED - Plugin documentation with uncited claims about tools, APIs, CLI flags
- Skills that reference specific software behavior without citation
- After code review agents flag potential fabrication
When NOT to Use
- Structural findings (broken links, missing files, malformed YAML) — those are filesystem checks, not fact checks
- Code logic bugs — use
/find-causeinstead - Research on new tools — use
/research-curatorinstead
Evidence Rules
<evidence_rules>
Adapted from the find-cause evidence chain protocol.
Valid evidence (one of these MUST support each verdict):
- WebFetch output — content retrieved from an official documentation URL
- WebSearch result — search results linking to authoritative sources
- Command output —
npx <tool> --help,gh api, or similar CLI output - Repository source code — file content from the tool's GitHub repo via
ghor clone - MCP tool output —
mcp__Ref,mcp__exaresults with URLs
NOT valid evidence (these MUST NOT support verdicts):
- Training data recall ("I know this from my training")
- Inference from absence ("the docs don't mention it, so it doesn't exist")
- Reasoning from analogy ("tool X works this way, so tool Y does too")
- Documentation that describes intent without observed behavior
- Another AI's claim without primary source backing
</evidence_rules>
Claim Extraction
Parse the input to extract discrete, falsifiable claims:
flowchart TD
Start([Parse input]) --> Q{Input type?}
Q -->|Backlog item title| ReadBacklog[Run backlog list --format json, find matching item]
Q -->|Plugin path| ScanFiles[Scan SKILL.md and references for factual claims]
Q -->|--all-unverified| FindAll[Run backlog list --format json, filter UNVERIFIED items]
ReadBacklog --> Extract[Extract falsifiable claims]
ScanFiles --> Extract
FindAll --> Extract
Extract --> Classify[Classify each claim]
Classify --> Spawn[Spawn verification agents]
Claim Classification
For each claim, determine:
- Claim text — the specific assertion
- Primary source — where to check (official docs URL, GitHub repo, CLI help)
- Verification method — WebFetch URL, run CLI command, search GitHub issues
- Falsifiability — what would disprove this claim?
Verification Agent Spawning
Spawn @fact-checker agents in parallel waves of 5.
Each agent receives:
CLAIM: {exact claim text}
SOURCE_FILE: {file containing the claim, with line numbers}
PRIMARY_SOURCE: {URL or command to check against}
VERIFICATION_METHOD: {WebFetch | WebSearch | CLI command | gh API}
FALSIFICATION_CRITERIA: {what would disprove this}
Wave Execution
flowchart TD
Start([Claims extracted]) --> Count{How many claims?}
Count -->|1-5| Wave1[Wave 1 — all in parallel]
Count -->|6-10| Split2[Wave 1 — first 5, Wave 2 — remaining]
Count -->|11+| SplitN[Waves of 5, sequential]
Wave1 --> Collect[Collect verdicts]
Split2 --> SeqWaves[Execute waves sequentially]
SeqWaves --> Collect
SplitN --> SeqWaves
Collect --> Report[Generate report]
Verdict Format
Each agent returns a structured verdict:
CLAIM: {the claim being checked}
VERDICT: VERIFIED | REFUTED | INCONCLUSIVE
EVIDENCE:
- Source: {URL or command}
- Retrieved: {date}
- Content: {relevant excerpt from primary source}
EXPLANATION: {how the evidence supports the verdict}
CITATION: {formatted citation for backlog/docs update}
Verdict Criteria
- VERIFIED — primary source confirms the claim. Evidence excerpt matches.
- REFUTED — primary source contradicts the claim. Evidence excerpt shows the discrepancy.
- INCONCLUSIVE — primary source could not be reached, does not address the claim, or is ambiguous. State what additional step would resolve it.
Chain of Verification (CoVe) Requirement
Each agent MUST apply CoVe before finalizing:
- Initial lookup — fetch primary source, form initial verdict
- Verification questions — generate 2-3 questions that could falsify the initial verdict
- Independent check — answer each verification question using a different source or method
- Final verdict — confirm or revise based on cross-checking
This prevents the agent from confirming its own bias in a single lookup.
Report Format
After all waves complete:
# Fact Check Report
**Date**: {YYYY-MM-DD}
**Scope**: {backlog item title | plugin path | all-unverified}
**Claims checked**: {N}
## Summary
| Verdict | Count |
|---------|-------|
| VERIFIED | {N} |
| REFUTED | {N} |
| INCONCLUSIVE | {N} |
## Verdicts
### Claim 1: {claim text}
**Verdict**: {VERIFIED|REFUTED|INCONCLUSIVE}
**Source**: {primary source URL}
**Evidence**: {excerpt}
**Citation**: {formatted citation}
### Claim 2: ...
## Backlog Updates
{For each REFUTED or VERIFIED claim, the specific edit to make to the per-item file}
Post-Actions
- Update backlog — for VERIFIED/REFUTED claims, update the backlog item's Status field in the per-item file
- Lint —
uv run prek run --files .claude/backlog/ - Commit —
git add .claude/backlog/ && git commit -m "docs(backlog): fact-check {N} claims ({date})"
For INCONCLUSIVE claims, add a note to the backlog item describing what additional verification is needed.
References
- Evidence chain protocol adapted from find-cause
- Wave spawning pattern from research-curator
- Anti-hallucination checkpoint from skill-research-process
- Chain of Verification from cove-prompt-design
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
ccc
This skill should be used when code search is needed (whether explicitly requested or as part of completing a task), when indexing the codebase after changes, or when the user asks about ccc, cocoindex-code, or the codebase index. Trigger phrases include 'search the codebase', 'find code related to', 'update the index', 'ccc', 'cocoindex-code'.
agent-browser
Browser automation CLI for AI agents. Use when the user needs to interact with websites, including navigating pages, filling forms, clicking buttons, taking screenshots, extracting data, testing web apps, or automating any browser task. Triggers include requests to "open a website", "fill out a form", "click a button", "take a screenshot", "scrape data from a page", "test this web app", "login to a site", "automate browser actions", or any task requiring programmatic web interaction.
delegate
Quick delegation template for sub-agent prompts. Use when assigning work to a sub-agent, before invoking the Agent tool, or when preparing prompts for specialized agents. Provides the WHERE-WHAT-WHY framework. For comprehensive delegation guidance, activate the agent-orchestration how-to-delegate skill.
swarm-spawning
Spawn agents and teammates in Claude Code swarms. Use when choosing between subagents vs teammates, selecting agent types (Explore, Plan, general-purpose, plugin agents), configuring spawn backends (in-process, tmux, iterm2), or setting environment variables for spawned agents.
knowledge-explorer
Manage the research/ knowledge base (KB) of tool and library research entries. Use when browsing KB topics, adding new research entries, updating existing entries with dated revisions, fetching GitHub repo metadata into a draft KB entry, or migrating old-format entries to skill-spec frontmatter. Triggers on tasks like "what do we have on X", "add this to the KB", "update the KB entry for Y", "fetch github info for owner/repo", or "migrate old entries".
design-anti-patterns
Enforce anti-AI UI design rules based on the Uncodixfy methodology. Use when generating HTML, CSS, React, Vue, Svelte, or any frontend UI code. Prevents "Codex UI" — the generic AI aesthetic of soft gradients, floating panels, oversized rounded corners, glassmorphism, hero sections in dashboards, and decorative copy. Applies constraints from Linear/Raycast/Stripe/GitHub design philosophy: functional, honest, human-designed interfaces. Triggers on: UI generation, dashboard building, frontend component creation, CSS styling, landing page design, or any task producing visual interface code.
Didn't find tool you were looking for?