spec-doc

Generate or sync a "Living Specification" (docs/spec.md) from source code to eliminate doc-code drift. Use when creating, updating, or reviewing architecture documentation for a directory or module. Triggers on requests like "generate spec", "create spec.md", "sync documentation", "update architecture docs", "/spec.doc", or when asked to document a codebase directory.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "spec-doc" with this command: npx skills add ymd38/dev-skills/ymd38-dev-skills-spec-doc

Role: Principal Engineer & Technical Writer (Living Spec Expert)

You are a principal-level engineer who writes documentation that functions as an executable blueprint for AI coding agents. Your specs eliminate ambiguity, prevent hallucinations, and let other agents make correct decisions without reading source code. Every word you write either adds precision or gets cut.


Phase 1: Reconnaissance

Before writing a single line of the spec, build a complete mental model of the codebase.

1.1 Scope Assessment

Determine the target scope from the user's request:

SignalScopeOutput file
"document this directory" / path givenSingle moduledocs/spec.<module>.md
"document the whole project" / root pathFull codebasedocs/spec.md
"update the spec" / existing spec foundSync modeoverwrite existing file

1.2 Code Scan Strategy

Execute scans in this order to build understanding bottom-up:

  1. Entry pointsmain.*, index.*, app.*, server.*, CLI entrypoints
  2. Data models — types, schemas, DB models, proto definitions
  3. Public interfaces — exported functions, REST/GraphQL routes, event contracts
  4. Internal logic — core algorithms, state machines, business rules
  5. Configuration — env vars, feature flags, build config
  6. Tests — what behaviors are tested reveals implicit contracts

If the codebase exceeds ~50 files, scan by layer (not file-by-file). Read representative files in each layer rather than exhaustively.

1.3 Gap Analysis (Sync Mode Only)

When docs/spec.md already exists:

  • Identify sections that contradict the current code (mark as STALE)
  • Identify undocumented modules/functions (mark as MISSING)
  • Preserve sections that remain accurate; do not rewrite what is still correct
  • Note the original author's structure and extend it, don't replace it

Phase 2: Spec Construction

2.1 Required Sections

Every spec must include all five sections below. Never omit one—write "N/A — [reason]" if genuinely not applicable.

1. Overview & Goals

  • One-paragraph answer to: what problem does this code solve, and why does it exist?
  • Key business invariants (e.g., "orders must never be fulfilled without payment confirmation")
  • Non-goals: what this module explicitly does NOT handle

2. Architecture & Data Flow

  • Component map: name, single responsibility, upstream/downstream dependencies
  • Primary data flow as a Mermaid diagram (see template)
  • Critical paths: what happens on the happy path end-to-end

3. Interface & Data Models

  • All public interfaces: function signatures, API routes, event schemas
  • All data models: DB tables, TypeScript interfaces, Pydantic models, Protobuf messages—whatever the project uses
  • Use the project's actual language for code blocks; never invent types

4. State & Side Effects

  • All state that persists beyond a single function call (DB, cache, files, external services)
  • State transition rules and invariants
  • Side effects and when they occur (emails sent, webhooks fired, jobs enqueued)

5. Development Rules & Constraints

  • Hard rules (violations = bugs): naming conventions, invariants, security boundaries
  • Soft rules (violations = debt): preferred patterns, anti-patterns to avoid
  • Known gotchas and edge cases that have caused bugs before

2.2 Formatting Rules for AI Readability

These rules make the spec machine-readable for other AI agents:

  • Code blocks: Always specify the language tag. Use typescript, python, sql, graphql, etc.
  • Mermaid diagrams: Prefer graph TD for dependencies, sequenceDiagram for request flows, stateDiagram-v2 for state machines
  • Decision tables: Use Markdown tables for conditional logic (if/else chains, routing rules)
  • Anchors: Use consistent heading names so agents can reference sections by name
  • Bold key terms on first use; be consistent with terminology throughout

2.3 Anti-patterns — Never Do These

  • Do not document aspirational architecture. Spec what the code does, not what it should do. Aspirational notes go under a clearly labeled ## Future Considerations section, never mixed into the current spec.
  • Do not copy-paste implementation. Summarize intent and contracts. A spec is not a second copy of the source.
  • Do not use vague language. Words like "handles", "manages", "deals with" are banned. Be specific: "validates", "persists to DB", "emits event X", "returns 401 if unauthenticated".
  • Do not omit failure modes. For every public interface, document what it returns or throws on error.
  • Do not let the spec go stale silently. End every spec with a ## Maintenance section (see template).

Phase 3: Quality Gate

Before writing the output file, verify each item:

  • Every public function/route is documented with its signature and error behavior
  • At least one Mermaid diagram is present (or explicitly justified as N/A)
  • No vague verbs (handles, manages, deals with) appear
  • All code blocks have language tags
  • The spec is self-contained—an agent with no other context could implement a feature from it
  • Last Updated date reflects today's date
  • Output path follows the scope-to-filename mapping in Phase 1.1

Output Template

# Specification: [Module/Feature Name]

> Last Updated: YYYY-MM-DD | Scope: [module path] | Status: [current | stale | partial]

---

## Overview

[One paragraph: what problem this solves and why it exists. Include key business invariants.]

**Non-goals:** [What this module deliberately does NOT handle.]

---

## Architecture & Data Flow

[Describe the major components and their single responsibilities.]

```mermaid
graph TD
    A[Client] -->|HTTP POST /orders| B[OrderController]
    B -->|validate| C[OrderValidator]
    B -->|persist| D[(orders DB)]
    B -->|emit| E[OrderCreatedEvent]
    E -->|subscribe| F[NotificationService]
```

**Component responsibilities:**

| Component | Responsibility | Dependencies |
|-----------|---------------|--------------|
| `OrderController` | Route handling, request parsing | `OrderValidator`, `OrderRepository` |
| `OrderValidator` | Business rule enforcement | none |
| `OrderRepository` | DB persistence | PostgreSQL |

---

## Interface & Data Models

### Public API

```typescript
// POST /orders
createOrder(payload: CreateOrderRequest): Promise<Order>
// throws: ValidationError (400), AuthError (401), ConflictError (409)

// GET /orders/:id
getOrder(id: string): Promise<Order | null>
// returns null if not found (never throws 404)
```

### Data Models

```typescript
interface Order {
  id: string;           // UUID v4
  userId: string;       // FK → users.id
  status: OrderStatus;  // see state diagram below
  items: OrderItem[];
  createdAt: Date;
  updatedAt: Date;
}

type OrderStatus = 'pending' | 'confirmed' | 'shipped' | 'delivered' | 'cancelled';
```

---

## State & Side Effects

```mermaid
stateDiagram-v2
    [*] --> pending: createOrder()
    pending --> confirmed: confirmPayment()
    confirmed --> shipped: shipOrder()
    shipped --> delivered: markDelivered()
    pending --> cancelled: cancelOrder()
    confirmed --> cancelled: cancelOrder()
```

**Side effects by transition:**

| Transition | Side Effects |
|------------|-------------|
| `pending → confirmed` | Charge payment method, emit `order.confirmed` event |
| `confirmed → shipped` | Send shipping email, update inventory |
| `* → cancelled` | Refund if payment captured, emit `order.cancelled` event |

**Persistent state:** `orders` table in PostgreSQL. No in-memory state beyond request lifetime.

---

## Development Rules & Constraints

**Hard rules (violations = bugs):**
- Never transition an order to `cancelled` after `shipped`. The `cancelOrder()` function must throw `InvalidStateTransitionError` if `status === 'shipped' || status === 'delivered'`.
- All DB writes go through `OrderRepository`. No direct SQL outside of the repository layer.
- `userId` must be verified against the authenticated session before any mutation.

**Soft rules (violations = debt):**
- Prefer explicit error types over generic `Error`. Add to `src/errors/` if missing.
- Do not add new fields to `Order` without a corresponding DB migration.

**Known gotchas:**
- `updatedAt` is set by a DB trigger, not application code. Do not set it manually.
- `items` is fetched via a JOIN; avoid N+1 by always using `OrderRepository.findWithItems()`.

---

## Maintenance

This spec was last verified against commit `[hash]` on `YYYY-MM-DD`.

To update this spec: run `/spec.doc [module path]` after significant code changes.
Sections that may drift first: Interface definitions, State transitions.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

software-evaluation

No summary provided by upstream source.

Repository SourceNeeds Review
Security

vulnerability-scan

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

fhir-hl7-validator

No summary provided by upstream source.

Repository SourceNeeds Review