adr-writer

Generates Architecture Decision Records (ADRs) capturing context, decision rationale, alternatives considered, and projected consequences. Produces numbered, status-tracked documents following the standard ADR format with proper metadata lifecycle. Triggers on: "write an ADR", "document this decision", "architecture decision record", "why did we choose", "capture this decision", "record the decision", "ADR for", "document the architecture", "decision record", "design decision", "technical decision". Use this skill when an architectural or technical decision needs to be documented.

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 "adr-writer" with this command: npx skills add mathews-tom/praxis-skills/mathews-tom-praxis-skills-adr-writer

ADR Writer

Captures architecture decisions in a lightweight, structured format that preserves context, rationale, alternatives, and consequences. Produces numbered ADR documents with proper status lifecycle — preventing the "why did we do it this way?" problem when revisiting decisions months later.

Reference Files

FileContentsLoad When
references/adr-template.mdStandard ADR template with field explanations and examplesAlways
references/status-lifecycle.mdStatus transitions, supersession rules, deprecation processADR references existing decisions
references/context-capture.mdTechniques for eliciting and documenting decision contextComplex or multi-stakeholder decision
references/alternatives-analysis.mdFramework for evaluating and documenting rejected alternativesMultiple options being considered

Prerequisites

  • A decisions directory (typically docs/adr/ or docs/decisions/)
  • Understanding of the decision being made (may require clarifying questions)

Workflow

Phase 1: Identify the Decision

  1. What choice was made? — Extract the core architectural decision. If the user describes a problem, help them articulate the decision that resolves it.
  2. Is this decision-worthy? — ADRs are for decisions that:
    • Affect system structure (component boundaries, data flow, API design)
    • Are hard to reverse (technology choice, database schema, protocol)
    • Have non-obvious tradeoffs (multiple viable alternatives)
    • Will be questioned later (the "why" will be forgotten)
  3. What triggered this decision? — New requirement, performance issue, scaling concern, security audit finding, tech debt, team growth.

Phase 2: Capture Context

Document the forces that shaped this decision:

  1. Requirements — What functional or non-functional requirements drive this?
  2. Constraints — What limits the solution space? (budget, timeline, team expertise, existing infrastructure, regulatory requirements)
  3. Current state — What exists today? What is the pain point?
  4. Stakeholders — Who is affected by this decision? Who needs to agree?

Phase 3: Enumerate Alternatives

For each alternative considered:

  1. Name it clearly — "PostgreSQL" not "Option A"
  2. List concrete pros — Specific, measurable benefits
  3. List concrete cons — Specific, measurable drawbacks
  4. State the rejection reason — Why this alternative was not chosen. Be specific: "Does not support our required throughput of 10K ops/sec" not "Too slow."

Phase 4: Document the Decision

State the chosen option and why it was selected given the context and constraints. The decision should follow logically from the context + alternatives analysis.

Phase 5: Project Consequences

Document what this decision makes easier and harder:

  1. Positive consequences — What improves?
  2. Negative consequences — What tradeoffs are accepted? What tech debt is incurred?
  3. Neutral consequences — Side effects that are neither good nor bad.

Phase 6: Assign Metadata

  1. Number — Sequential: ADR-001, ADR-002, etc. Check existing ADRs for the next number.
  2. Status — Initial status is usually "Proposed" or "Accepted"
  3. Date — Date the ADR was written
  4. Author — Who authored this ADR
  5. Supersedes/Superseded-by — Link to related ADRs if this replaces an earlier decision

Output Format

# ADR-{NNN}: {Descriptive Title}

**Status:** {Proposed | Accepted | Deprecated | Superseded by ADR-XXX}
**Date:** {YYYY-MM-DD}
**Author:** {name}
**Supersedes:** {ADR-XXX (if applicable)}

## Context

{What situation requires a decision? What constraints exist? What forces are at play?
Write in present tense — describe the situation as it exists at decision time.}

## Decision

{State the decision clearly and concisely. "We will use X for Y because Z."
One to three sentences. The reader should understand the decision without reading
the rest of the document.}

## Alternatives Considered

### {Alternative 1 Name}
- **Pros:** {specific benefits}
- **Cons:** {specific drawbacks}
- **Rejected because:** {concrete, specific reason tied to context}

### {Alternative 2 Name}
- **Pros:** {specific benefits}
- **Cons:** {specific drawbacks}
- **Rejected because:** {concrete, specific reason tied to context}

## Consequences

### Positive
- {Concrete benefit 1}
- {Concrete benefit 2}

### Negative
- {Concrete tradeoff 1 — acknowledged and accepted}
- {Technical debt incurred — with plan to address if applicable}

### Neutral
- {Side effect that is neither positive nor negative}

## References

- {Link to related issue, discussion, document, or prior ADR}

Calibration Rules

  1. Context is king. The Context section is the most important part. A decision without context is just an assertion. Future readers need to understand WHY, not just WHAT.
  2. Specific rejection reasons. "Not suitable" is not a rejection reason. "Does not support transactions across partitions, which we need for order processing" is.
  3. Honest consequences. Every decision has downsides. If the Negative section is empty, the analysis is incomplete. Push the user to articulate tradeoffs.
  4. Present tense for context. Write the Context section in present tense — it captures the world as it was when the decision was made.
  5. One decision per ADR. If multiple decisions are interrelated, write separate ADRs and cross-reference them. Do not bundle unrelated decisions.
  6. Immutable after acceptance. Accepted ADRs are not edited. If a decision changes, write a new ADR that supersedes the old one. This preserves the historical record.

Error Handling

ProblemResolution
User cannot articulate alternativesHelp them brainstorm by asking: "What else could you have done? What did you consider and reject?"
Decision is trivial (no real alternatives)Suggest it doesn't need an ADR. ADRs are for non-obvious decisions with tradeoffs.
Decision already made, no context rememberedReconstruct context from code, PRs, commit history. Note reconstructed context as "best available."
Existing ADR numbering scheme unknownCheck docs/adr/ or docs/decisions/. If no directory exists, suggest creating one and starting at 001.
Decision scope is too broadSplit into multiple focused ADRs. One for the database choice, one for the caching strategy, etc.

When NOT to Write an ADR

Push back if:

  • The decision is easily reversible (library version, code formatting rules) — use a comment or config instead
  • The decision is a standard practice with no alternatives (use HTTPS, validate input) — not decision-worthy
  • The user wants to document implementation details — ADRs are for WHY decisions, not HOW implementations
  • The decision has already been superseded — write the new ADR, not the old one

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.

General

manuscript-review

No summary provided by upstream source.

Repository SourceNeeds Review
General

html-presentation

No summary provided by upstream source.

Repository SourceNeeds Review
General

concept-to-image

No summary provided by upstream source.

Repository SourceNeeds Review
General

md-to-pdf

No summary provided by upstream source.

Repository SourceNeeds Review