comment-quality
Comment Quality Skill
Review code comments for temporal references, development-activity language, and relative comparisons. Produces structured reports with actionable rewrites that explain WHAT the code does and WHY, only WHAT the code does and WHY. Supports .go, .py, .js, .ts, .md, and .txt files.
Instructions
Phase 1: SCAN
Goal: Identify all comments containing temporal, activity, or relative language.
Step 1: Determine scope
Read the repository CLAUDE.md first to pick up any project-specific comment conventions.
Scan only what was requested. If user specifies files, scan those files. If user specifies a directory, scan that directory. Honor the explicit scope -- even if you suspect other files have issues, honor the explicit scope and suggest expansion separately at the end.
If user explicitly requests auto-fix, enable it. Otherwise present findings for review. For large codebases, group findings by directory when reporting.
Step 2: Search for temporal patterns
Flag every instance of the following categories. No temporal word is "harmless" -- all temporal language ages poorly and must be rewritten regardless of how innocuous it seems:
- Temporal words: "new", "old", "previous", "current", "now", "recently", "latest", "modern"
- Development activity: "added", "removed", "deleted", "updated", "changed", "modified", "fixed", "improved", "enhanced", "refactored", "optimized"
- State transitions: "replaced", "migrated", "upgraded", "deprecated", "became", "turned into", "evolved"
- Date references: "as of", "since", "from", "after", "before"
- Relative comparisons: "better than", "faster than", "instead of", "unlike the previous"
Step 3: Filter false positives
Exclude from findings -- these are not developer comments and must remain untouched:
- Copyright and license headers (legal requirements, not code comments)
@generatedmarkers (tooling markers)@deprecatedannotations (keep the tag, flag only temporal explanation text after it)- Variable names or string literals that happen to contain temporal words
- TODO/FIXME items that describe future work without temporal references
When a finding appears, inspect nearby comments in the same function or block -- temporal language tends to cluster.
Gate: All files in scope scanned. Findings list populated with file path, line number, and matched text. Every finding listed, not just the first few. Proceed only when gate passes.
Phase 2: ANALYZE
Goal: Understand context for each finding to produce meaningful rewrites.
Step 1: Read surrounding code
For each finding, read the function, block, or section the comment describes. Understand what the code actually does. A rewrite without code context produces vague replacements that strip temporal words without adding substance.
Step 2: Classify the comment
| Finding | Type | Severity |
|---------|------|----------|
| "now uses JWT" | Temporal + Activity | High |
| "improved perf" | Activity | Medium |
| "Copyright 2024" | Legal (skip) | N/A |
Step 3: Determine replacement content
For each comment, identify:
- What does the code do right now?
- Why does it do it this way?
- What value does the comment add for a future reader?
Gate: Every finding classified with context understood. Proceed only when gate passes.
Phase 3: REWRITE
Goal: Generate specific, valuable replacement comments.
Step 1: Draft rewrites
For each finding, produce a structured entry with file path, line number, current text, suggested replacement, and reasoning:
**File: `path/to/file.ext`**
Line X - [Comment type]:
Current: // Authentication now uses JWT tokens
Suggested: // Authenticates requests using signed JWT tokens
Reason: "now uses" is temporal - describe current behavior only
Step 2: Validate rewrite quality
Each rewrite MUST pass these checks:
- Would this comment make sense in 10 years?
- Does it explain WHAT or WHY, not WHEN?
- Is it more specific than what it replaces (not just temporal word removed)?
- Does it add value for a future maintainer?
If a rewrite just removes the temporal word without adding substance, it fails validation. Simply deleting a word produces a useless comment -- // Updated error handling becoming // Error handling adds nothing. Rewrite with specific, descriptive content: // Handles database connection errors with exponential backoff retry.
Gate: All rewrites pass quality checks. No vague or empty replacements. Proceed only when gate passes.
Phase 4: REPORT
Goal: Deliver structured, actionable report.
Step 1: Generate report
Report facts concisely with file paths and line numbers. Every finding must include the current text, suggested replacement, and reasoning -- a diagnostic-only count without rewrites creates work without providing solutions.
## Comment Quality Review
### Summary
- Files scanned: N
- Issues found: M
- Most common pattern: [temporal word]
### Findings
[All findings with file, line, current text, suggested text, reason]
### Recommendations
1. Apply suggested changes
2. Consider adding linter rules for temporal language prevention
Step 2: Apply fixes (if auto-fix enabled)
If user requested auto-fix, apply all rewrites using Edit tool. Verify each edit succeeded. Wait for explicit user permission before auto-fixing without explicit user authorization.
Step 3: Cleanup
Remove any scan results, intermediate reports, or helper files created during execution.
Gate: Report delivered. All findings accounted for. Task complete.
Error Handling
Error: "No Temporal Language Found"
Cause: Files are clean or scope was too narrow Solution:
- Verify common files were scanned (README, main source files)
- Report clean results -- this is a valid positive outcome
- Suggest expanding scope if user suspects issues exist elsewhere
Error: "Too Many Results to Display"
Cause: Large codebase with widespread temporal language Solution:
- Prioritize by file importance (README first, then core modules)
- Group findings by pattern type
- Process files by directory with grouped reports
Error: "Comment Meaning Unclear Without History"
Cause: Comment only makes sense with development context that no longer exists Solution:
- Read surrounding code to infer current purpose
- If purpose is clear from code, suggest removing the comment entirely
- If purpose is unclear, ask user for clarification before rewriting
References
Reference Loading Table
Load on demand — only pull what the current task requires.
| Task Signal | Load |
|---|---|
Go files (.go) in scope |
references/go-comment-patterns.md |
Error handling code (try/catch, if err !=, raise) |
references/error-handling-patterns.md |
| Performance code (cache, pool, batch, concurrency, goroutine) | references/performance-patterns.md |
| General rewrite examples needed | references/examples.md |
| Full anti-pattern reference | references/preferred-patterns.md |
| Language-specific (Go, Python, JS/TS) or documentation (README, API) comments | references/preferred-patterns-language-specific.md |
Reference Files
${CLAUDE_SKILL_DIR}/references/preferred-patterns.md: Core temporal anti-pattern catalog (language-agnostic)${CLAUDE_SKILL_DIR}/references/preferred-patterns-language-specific.md: Language-specific and documentation-targeted anti-patterns${CLAUDE_SKILL_DIR}/references/examples.md: Before/after examples of comment rewrites${CLAUDE_SKILL_DIR}/references/go-comment-patterns.md: Go-specific temporal patterns with grep/rg detection commands${CLAUDE_SKILL_DIR}/references/error-handling-patterns.md: Temporal patterns in error handling code with detection commands${CLAUDE_SKILL_DIR}/references/performance-patterns.md: Temporal patterns in performance-related comments with detection commands
More from notque/claude-code-toolkit
generate-claudemd
Generate project-specific CLAUDE.md from repo analysis.
12fish-shell-config
Fish shell configuration and PATH management.
12pptx-generator
PPTX presentation generation with visual QA: slides, pitch decks.
12codebase-overview
Systematic codebase exploration and architecture mapping.
10image-to-video
FFmpeg-based video creation from image and audio.
9data-analysis
Decision-first data analysis with statistical rigor gates.
9