RFC (Request for Comments) specification writing with objective technical analysis. Use when creating technical specifications, design documents, or architecture proposals that require structured evaluation of options and trade-offs.
RFC Specification Writing Skill
This skill automatically activates when writing technical specifications, design documents, or architecture proposals that require structured evaluation and stakeholder review.
When This Skill Activates
- Creating a new technical RFC or design document
- Proposing architectural changes or new systems
- Evaluating technical options objectively
- Documenting technical decisions with rationale
- Writing system design specifications
Core Principles
Objective Technical Analysis
RFCs must maintain strict neutrality when evaluating options:
-
Evidence-Based Evaluation
- Support claims with data, benchmarks, or documented experience
- Avoid subjective language ("better", "best", "obvious choice")
- Present measurable criteria for comparison
-
Balanced Trade-off Analysis
- Every option has advantages AND disadvantages
- Document both explicitly for each alternative
- Avoid dismissing options without clear justification
-
Separation of Facts and Opinions
- Clearly label assumptions vs verified facts
- Cite sources for technical claims
- Distinguish between team preferences and technical constraints
-
Stakeholder Neutrality
- Present options without advocating for a predetermined choice
- Let evaluation criteria drive the recommendation
- Document dissenting opinions fairly
RFC Document Structure
Required Sections
-
Header Metadata
--- rfc_id: RFC-XXXX title: [Descriptive Title] status: DRAFT | REVIEW | APPROVED | IN_PROGRESS | COMPLETED | SUPERSEDED author: [Name] reviewers: [List of reviewers with status] created: YYYY-MM-DD last_updated: YYYY-MM-DD decision_date: YYYY-MM-DD (when approved) --- -
Overview (1-2 paragraphs)
- What this RFC proposes
- Why it matters now
- Expected outcome
-
Background & Context
- Current state of the system
- Historical context if relevant
- Glossary of terms
- Links to related RFCs or documentation
-
Problem Statement
- Specific problem being addressed
- Evidence of the problem (metrics, incidents, user feedback)
- Impact of not solving (cost, risk, opportunity loss)
-
Goals & Non-Goals
- Explicit scope boundaries
- What success looks like
- What this RFC deliberately does NOT address
-
Evaluation Criteria
- Measurable criteria for comparing options
- Weight or priority of each criterion
- Minimum thresholds where applicable
-
Options Analysis
For each option (minimum 2):### Option N: [Name] **Description**: [What this option entails] **Advantages**: - [Pro 1] - [Pro 2] **Disadvantages**: - [Con 1] - [Con 2] **Evaluation Against Criteria**: | Criterion | Score/Rating | Notes | |-----------|--------------|-------| | ... | ... | ... | **Effort Estimate**: [Complexity and resources required] **Risk Assessment**: [Potential risks and mitigations] -
Recommendation
- Recommended option with justification
- How it scores against criteria
- Acknowledged trade-offs being accepted
-
Technical Design (for approved RFCs)
- Architecture diagrams
- API specifications
- Data models
- Security considerations
-
Implementation Plan
- Phases and milestones
- Dependencies
- Rollback strategy
-
Open Questions
- Unresolved technical questions
- Areas needing further investigation
- Pending stakeholder input
-
Decision Record
- Final decision made
- Date and approvers
- Key discussion points
- Conditions or constraints on approval
RFC Lifecycle
DRAFT → REVIEW → APPROVED → IN_PROGRESS → COMPLETED
↓
SUPERSEDED (if replaced by newer RFC)
Status Definitions
| Status | Description |
|---|---|
| DRAFT | Initial writing, not ready for review |
| REVIEW | Open for stakeholder feedback |
| APPROVED | Decision made, ready for implementation |
| IN_PROGRESS | Implementation underway |
| COMPLETED | Implementation finished |
| SUPERSEDED | Replaced by newer RFC (link to new RFC) |
Evaluation Criteria Framework
Use these standard criteria categories (adapt as needed):
Technical Criteria
- Performance: Latency, throughput, resource usage
- Scalability: Horizontal/vertical scaling, bottlenecks
- Reliability: Fault tolerance, recovery, availability
- Security: Attack surface, data protection, compliance
- Maintainability: Code complexity, debugging, updates
Operational Criteria
- Operability: Monitoring, alerting, incident response
- Deployment: CI/CD integration, rollback capability
- Documentation: Learning curve, knowledge transfer
Business Criteria
- Time to Implement: Development effort, dependencies
- Cost: Infrastructure, licensing, maintenance
- Risk: Technical risk, organizational risk
Neutral Language Guidelines
Avoid
- "Obviously the best choice"
- "Everyone agrees that..."
- "This is clearly superior"
- "The only sensible option"
- Dismissing alternatives as "not worth considering"
Use Instead
- "Based on criteria X, Option A scores higher because..."
- "Option B requires consideration of trade-off Y"
- "The data suggests that..."
- "Stakeholder input indicates a preference for..."
- "Given constraints A and B, Option C is recommended"
Quality Checklist
Before marking RFC as REVIEW:
- [ ] All required sections are complete
- [ ] At least 2 alternatives are analyzed
- [ ] Evaluation criteria are explicit and measurable
- [ ] Trade-offs are documented for each option
- [ ] Language is objective and evidence-based
- [ ] Technical diagrams are included where helpful
- [ ] Open questions are clearly listed
- [ ] Implementation plan is realistic
Integration with CTO Architect Workflow
When the CTO Architect agent creates technical specifications:
- Use this skill for any significant technical decision
- Follow the template in
references/rfc-template.md - Ensure neutral evaluation of all options
- Link to related PRDs when applicable
- Request review from appropriate technical stakeholders
File Naming Convention
- RFC documents:
RFC-XXXX-<short-description>.md - Example:
RFC-0042-api-gateway-selection.md
Directory Structure
rfcs/
├── draft/ # Work in progress
├── review/ # Under stakeholder review
├── approved/ # Approved, awaiting or in implementation
├── completed/ # Implementation finished
└── archive/ # Superseded or abandoned
└── YYYY/
References
- Template:
./references/rfc-template.md - Evaluation Matrix:
./references/evaluation-matrix.md
You Might Also Like
Related Skills

update-docs
This skill should be used when the user asks to "update documentation for my changes", "check docs for this PR", "what docs need updating", "sync docs with code", "scaffold docs for this feature", "document this feature", "review docs completeness", "add docs for this change", "what documentation is affected", "docs impact", or mentions "docs/", "docs/01-app", "docs/02-pages", "MDX", "documentation update", "API reference", ".mdx files". Provides guided workflow for updating Next.js documentation based on code changes.
vercel
docstring
Write docstrings for PyTorch functions and methods following PyTorch conventions. Use when writing or updating docstrings in PyTorch code.
pytorch
docs-writer
Always use this skill when the task involves writing, reviewing, or editing files in the `/docs` directory or any `.md` files in the repository.
google-gemini
write-concept
Write or review JavaScript concept documentation pages for the 33 JavaScript Concepts project, following strict structure and quality guidelines
leonardomso
resource-curator
Find, evaluate, and maintain high-quality external resources for JavaScript concept documentation, including auditing for broken and outdated links
leonardomso
doc-coauthoring
Guide users through a structured workflow for co-authoring documentation. Use when user wants to write documentation, proposals, technical specs, decision docs, or similar structured content. This workflow helps users efficiently transfer context, refine content through iteration, and verify the doc works for readers. Trigger when user mentions writing docs, creating proposals, drafting specs, or similar documentation tasks.
anthropics