Sigma · Prompts

Documentation Review Prompt

Paste into Claude Code, run from the repo root.


You are a senior technical writer and developer-experience engineer. You are reviewing a repository's documentation for clarity, accuracy, structure, and agent-readability. Assume the audience is developers from junior to senior, and that AI coding agents (Claude Code, GitHub Copilot, Cursor) will also consume these docs.

Your prime directive: respect the existing documentation and author voice. Work with what is there. Do not replace idiosyncratic-but-working docs with generic templates. Do not sanitize tone.

SCOPE

Review all human-facing documentation and agent-configuration files:

  • README.md at root and any per-package READMEs
  • Everything under docs/ if present
  • CONTRIBUTING.md, CODE_OF_CONDUCT.md, SECURITY.md, LICENSE, CHANGELOG.md
  • CLAUDE.md, AGENTS.md, .github/copilot-instructions.md, .cursor/rules/*.mdc (or legacy .cursorrules)
  • .github/PULL_REQUEST_TEMPLATE.md, issue templates
  • Architecture Decision Records (ADRs) typically under docs/adr/ or docs/decisions/
  • Inline documentation in entry-point files (main package README-equivalents) — not general code comments

Cross-check documentation against the actual code where feasible: do package.json scripts match what the README says? Do referenced files exist? Do code examples match current APIs?

PHASE 1 — RECONNAISSANCE

Do this first. Report briefly before any analysis.

  1. Inventory. List every documentation file found with one-line purpose and approximate freshness (git log last-modified if you can determine it, otherwise note).
  2. Voice sample. Read at least three representative documentation files and characterize the author voice in 2–3 sentences: formality (formal / conversational / casual), person (first / second / third), use of humor, emoji conventions, typical sentence length, any recurring stylistic signatures. Quote two short example sentences. This voice profile governs every edit you propose.
  3. Structural map. Describe the current docs/ layout if present. Identify whether it already follows a recognizable framework (Diátaxis (formerly the Divio system), monorepo-per-package, flat) or is ad-hoc.
  4. Agent files. Note which of CLAUDE.md, AGENTS.md, .github/copilot-instructions.md exist. Read each and note whether they point to docs or duplicate them.
  5. Stack detection. Languages, build tools, package managers. This determines what "getting started" must cover.
  6. Gaps. List foundational files that are absent (e.g., no CONTRIBUTING.md, no LICENSE, no docs/ folder at all).

PHASE 2 — REVIEW RUBRIC

For each finding, record: file path, location (section heading or line range), severity (Critical / High / Medium / Low / Nit), and one of:

  • SAFE — corrections to existing content, or net-new scaffolding files where absent, that do not restructure existing docs
  • JUDGMENT — restructuring, rewriting, new conceptual content, or framework adoption
  • CRITICAL — security, licensing, accuracy, or dangerous-guidance finding

Clarity & Approachability

  • Start-here path. Can a new developer go from "I just cloned this" to "it's running locally" without getting stuck? Flag missing or broken onboarding.
  • Audience signposting. Are sections labeled for their audience (e.g., "If you're contributing a new game," "If you're deploying to production")?
  • Jargon introduced before it's defined. Especially domain-specific terms.
  • Implicit context. Docs that assume knowledge of a predecessor system, a private conversation, or tribal knowledge.
  • Tone-audience fit. Overly casual for security docs; overly formal for contributor guides. But defer to established voice unless it actively harms comprehension.

Accuracy

  • Code vs docs drift. Commands, flags, file paths, env var names, config keys that don't match the current code.
  • Broken internal links. Relative links to moved/renamed files.
  • Broken external links. Best-effort — note as a check to run, don't block on them.
  • Stale version references. "Requires Node 16" when package.json says >=20.
  • Contradictions between docs. README says one thing, docs/setup.md says another.

Structure & Navigation

  • README shape. Does it answer in the first screen: what is this, who is it for, how do I run it, where do I go next? Not a checklist — a smell test.
  • docs/ index. Is there a docs/README.md or docs/index.md that orients readers? Or does docs/ dump 20 files into a flat folder with no nav?
  • Heading hierarchy. Semantic ## / ### nesting, not bolded text pretending to be headings. This matters for agents parsing structure.
  • Diátaxis fitness (judgment only). If structure is ad-hoc and the repo would benefit, suggest a Diátaxis layout (tutorials / how-to / reference / explanation) in Section B. If existing structure is coherent but different, leave it alone.
  • Cross-linking. Related pages that should reference each other but don't.

Formatting & Conventions

  • Code fences. Language tags present (```bash not ```)? Agents and syntax highlighters need them.
  • Consistent terminology. "The client" vs "the frontend" vs "the web app" used interchangeably for the same thing.
  • Consistent casing. GitHub not Github, npm not NPM or Npm, project name spelled/cased consistently throughout.
  • List vs prose balance. Walls of bullet points where prose would read better; dense prose where a list would scan better.
  • Callouts. Notes, warnings, and tips formatted consistently if the repo uses them.

Agent-Readability

  • Explicit file paths. "See src/adapters/storage.ts" beats "see the storage adapter." Agents resolve paths; humans benefit too.
  • Runnable examples. Complete enough to copy-paste, with working directory noted when it matters.
  • TL;DR at top of long docs. Agents and skimmers both benefit from a lead summary.
  • Avoid implicit ordering. "As mentioned above" / "see earlier" — be specific about what and where.

Agent Instruction Files

  • Presence. At minimum one of CLAUDE.md / AGENTS.md should exist for agent-heavy workflows. .github/copilot-instructions.md if Copilot is in use.
  • Role clarity. These files should cover: project overview (one paragraph), repo layout with key directories, common commands (build, test, run, lint), conventions the agent should follow, files/areas to leave alone, where to find more context.
  • Non-duplication. They should reference README.md and docs/ rather than restating them. Restated content goes stale.
  • Concision. These files consume context tokens on every agent invocation. Tight is better than comprehensive.
  • Absence. If missing, scaffolding them from existing repo content is a Section A action.
  • LICENSE present and declared in README.
  • SECURITY.md present with a disclosure channel if the project is public or handles user data.
  • CONTRIBUTING.md present if external contributions are expected, with at minimum: local dev setup, how to propose changes, testing expectations.
  • CODEOWNERS alignment with team reality if present.
  • CHANGELOG.md — if present, is it current? If absent and the project is versioned, flag.

Critical Findings (Section C territory)

  • Credentials or secrets in examples, even if "example" or "redacted" — API keys, tokens, real connection strings.
  • Internal hostnames, IPs, or staging URLs in public docs.
  • Real customer/user names or data in examples.
  • Dangerous commands without guardrails (rm -rf, destructive migrations, --force pushes).
  • Inaccurate security guidance — "just disable SSL for local dev" without context, example code that demonstrates an anti-pattern being taught as the pattern.
  • License conflicts — e.g., GPL code vendored into an MIT project without notice.
  • References to private infrastructure that shouldn't be in a public repo.

PHASE 3 — REPORT

Section A — Safe Corrections & Scaffolding

Numbered list. Two sub-buckets:

A1. Corrections to existing docs

For each: file, location, before/after snippet, one-line rationale. Typos, broken links, wrong commands, code-fence language tags, consistent casing of project/tool names, obvious factual errors checked against code, LICENSE reference in README — if missing.

A2. Scaffolding (net-new files only where absent)

Propose file contents for:

  • CLAUDE.md — if absent. Concise. Points to README.md and docs/. Covers layout, commands, conventions, leave-alone areas.
  • AGENTS.md — scaffold only if both CLAUDE.md and AGENTS.md are absent; scaffold both when the team uses multiple agent tools.
  • .github/copilot-instructions.md — if absent and Copilot is used (check for Copilot-related CI or team indicators).
  • Cursor rules (.cursor/rules/*.mdc or legacy .cursorrules) — reviewed where present, but not scaffolded; leave their authoring to teams already on Cursor.
  • docs/README.md index — if docs/ exists but has no index.
  • docs/ skeleton with placeholder stubs — only if no docs/ folder exists at all.
  • create CONTRIBUTING.md / SECURITY.md if absent.

For each scaffolding file: full proposed contents, with a note on what was pulled from existing repo content vs what's placeholder.

These are the ONLY changes you may offer to apply automatically.

Section B — Structural & Content Improvements

Judgment calls. Group by theme (e.g., "Restructure docs/ to Diátaxis," "Unify terminology around the rendering pipeline," "Rewrite the deploy guide for accuracy"). For each: current state, proposed change, effort estimate, what the author should weigh in on.

At the end, produce a ready-to-paste follow-up prompt to implement a chosen subset.

Section C — Critical Findings

Ordered by severity. For each: file + location, description, concrete risk, recommended fix.

At the end, produce a ready-to-paste follow-up prompt to address these findings.

Section D — Summary

  • Top 3 quick wins
  • Biggest structural opportunity
  • Single most important critical finding, if any
  • Voice-profile summary (one paragraph) — so it's visible which voice you'll preserve in edits

PHASE 4 — IMPLEMENTATION

After presenting the report, ASK whether to proceed with Section A. If approved, apply all A1 corrections and A2 scaffolding as a single coherent set of edits, then output:

  • A suggested commit message (conventional-commits style, e.g. docs: fix broken links, normalize project casing, scaffold agent instructions)
  • A suggested PR description

Do nothing from Section B or C without an explicit new request.

CONSTRAINTS

  • Do not modify any existing file before I approve Section A.
  • Preserve the author voice sampled in Phase 1. When editing, match sentence rhythm, formality level, and stylistic signatures. When in doubt, change less.
  • Do not introduce AI-boilerplate: avoid "robust," "seamless," "powerful," "leverages," "utilize," bolded phrase-soup, excessive emoji, or "This section covers..." preambles — unless the existing docs already use them.
  • Do not restructure existing docs/ layouts as a Section A action. Restructuring is Section B.
  • Do not fabricate facts about the project. If something is unclear, flag it as a question for the author rather than inventing an answer.
  • Agent instruction files must reference existing docs, not duplicate them.
  • Do not add content whose accuracy you cannot verify against the code or existing docs.
  • If a doc has an idiosyncratic voice that is clearly deliberate, preserve it even if it's unconventional.