This skill governs how code is documented at every level — from individual file headers to
global architecture docs. Apply it consistently across all projects. When in doubt: document
the why, not the what. The code already says what it does.
/docs/ in both frontend and backend. Note what'spresent, missing, or stale.
Apply to every file that is ≥ 20 lines OR is imported by other modules.
The very first line of every source file must be a comment containing the file's full path
from the project root. Use the comment syntax appropriate to the language.
// src/services/auth/tokenService.js
# src/services/auth/token_service.py
Immediately after the path comment, add a header block. Use the language's block comment
syntax. This block is mandatory and must be kept accurate.
/**
* File: src/services/auth/tokenService.js
*
* Overview:
* Issues, validates, and refreshes JWT tokens for authenticated sessions.
* Exists to centralise all token logic so Auth routes stay thin.
*
* Exports:
* - issueToken(userId, role) → signed JWT string
* - verifyToken(token) → decoded payload or throws
* - refreshToken(oldToken) → new signed JWT string
*
* Imported By:
* - src/routes/auth.js
* - src/middleware/requireAuth.js
*
* Imports:
* - jsonwebtoken — signing/verification
* - config/env — JWT_SECRET, TOKEN_TTL
*
* Notes:
* - Tokens expire in 15 min; refresh window is 7 days.
* - verifyToken throws on expiry — callers must handle.
*/
Rules:
Imported By.
Top of every non-trivial function (any function with logic beyond a single expression):
/**
* Signs a new JWT for the given user. Embeds userId and role in payload.
* Throws if JWT_SECRET is not set in env.
*/
function issueToken(userId, role) { ... }
Rules:
Allowed (rare exceptions only):
const TIMEOUT = 5000 // 5 seconds
Prohibited — remove on sight:
| Pattern | Example | Why banned |
|---|---|---|
| --- | --- | --- |
| Restating the code | // enable proxy above proxy: true | Zero information |
| Removed/old code notes | // removed legacy handler | Use git for history |
| Change log comments | // changed to use v2 API | Not a changelog |
| Section dividers | // ---- helpers ---- | Use modules instead |
| Obvious steps | // loop through users above a users.forEach | Noise |
If you encounter these, delete them. They are clutter that erodes trust in real comments.
See references/subsystem-doc.md for the full template and field-by-field instructions.
One .md file per subsystem, located at:
/backend/docs/.md /frontend/docs/.md Subsystem identification heuristics:
auth, billing, search, notifications, api-layer, data-layer, file-upload, websockets, admin, onboarding
Discovery checklist — identify a subsystem when you find:
If a subsystem doc already exists:
Location: /docs/architecture.md (or /backend/docs/architecture.md depending on repo layout)
See references/architecture-doc.md for the full template.
Required sections:
.mdtesting work across the system (not per-subsystem)
Required if a backend exists. Location: /backend/docs/api.md
For large backends: one file per subsystem, e.g. /backend/docs/api-auth.md,
/backend/docs/api-billing.md, then an index in /backend/docs/api.md.
See references/api-reference.md for the full endpoint template.
Every endpoint must document:
After writing or updating docs, audit them:
## Documentation Audit
### Missing
- List any subsystem without a doc
### Outdated
- List any doc that references removed files, functions, or endpoints
### Incorrect
- List any wrong dependency, wrong export name, wrong flow description
### Recommendations
- Specific fixes with file locations
Do not skip this pass. Stale documentation is worse than none — it actively misleads.
These apply any time you touch code:
"Imported By" lists if practical.
api.md..md..md from the template in references/subsystem-doc.md.
references.
Never leave documentation in a state that describes code that doesn't exist.
| Concern | Location | |
|---|---|---|
| --- | --- | |
| File path + module summary | Top of every source file | |
| Function purpose | Top of every non-trivial function | |
| Subsystem deep-dive | `/[frontend\ | backend]/docs/ |
| System-wide architecture | /docs/architecture.md | |
| API contracts | /backend/docs/api.md (or per-subsystem) |
references/subsystem-doc.md — Full subsystem doc template + instructionsreferences/architecture-doc.md — Full architecture.md templatereferences/api-reference.md — Full API endpoint documentation template共 1 个版本