list
List all architecture decisions and specs with their status. Use when the user asks "what decisions have we made", "list ADRs", "show specs", or wants an overview.
Governing Artifacts
Usage
/sdd:list [filter: adr|spec|all] [--module <name>]
Required Tools
ReadGlobGrep
Overview
List all ADRs and specs in the project with their status, date, and title.
Process
<!-- Governing: ADR-0016 (Workspace Mode), SPEC-0014 REQ "Artifact Path Resolution" -->
-
Resolve artifact paths: Follow the Artifact Path Resolution pattern from
references/shared-patterns.mdto determine the ADR and spec directories. If$ARGUMENTScontains--module <name>, resolve paths relative to that module; otherwise, in a workspace, aggregate across all modules. The resolved ADR directory is\{adr-dir\}and spec directory is\{spec-dir\}.<!-- Governing: ADR-0016 (Workspace Mode), SPEC-0014 REQ "Cross-Module Aggregation" -->
Cross-module aggregation: When in aggregate mode (no
--module, workspace detected), list artifacts from all modules. Add aModulecolumn to the output tables with module names in square brackets (e.g.,[api]). Sort by module name first, then by artifact number. When--moduleis provided, scope to that single module — no module column needed. When in single-module mode (no workspace), operate normally. -
Parse filter: Check
$ARGUMENTSfor a filter keyword:adr-- only show ADRsspec-- only show specsallor empty -- show both (default)
-
Scan for ADRs (unless filter is
spec):- Glob for
\{adr-dir\}/ADR-*.mdfiles (in aggregate mode, glob per-module and prefix results with module name) - For each file, extract
statusanddateper the Status Field Extraction algorithm in Step 3a (/sdd:primedefines this canonically;/sdd:listreuses it for the same legacy-format reasons) - Extract the title from the first
#heading - Sort by ADR number
- Glob for
-
Scan for specs (unless filter is
adr):- Glob for
\{spec-dir\}/*/spec.mdfiles (in aggregate mode, glob per-module and prefix results with module name) - For each file, extract
statusanddateper the Status Field Extraction algorithm referenced above - Extract the title from the first
#heading (e.g.,<a href="/specs/init-and-priming/spec#spec-0001" className="rfc-ref">SPEC-0001</a>: Web Dashboard) - Sort by SPEC number
- Glob for
3a. Status Field Extraction: same algorithm as /sdd:prime Step 3a. Briefly: try YAML frontmatter status: first; if absent, scan the first 30 lines for a - **Status:** \{value\} bullet (case-insensitive on "Status"); strip any parenthetical refinement notes (split on (, trim); if neither form yields a value, render as — when some artifacts have status, or drop the Status column entirely when zero do.
-
Present results as a formatted table:
Single-module or
--modulemode:## Architecture Decisions
| ID | Title | Status | Date |
|----|-------|--------|------|
| ADR-0001 | Choose frontend framework | accepted | 2025-01-15 |
| ADR-0002 | Choose PostgreSQL | proposed | 2025-02-01 |
## Specifications
| ID | Title | Status | Date |
|----|-------|--------|------|
| SPEC-0001 | Web Dashboard | approved | 2025-01-20 |Workspace aggregate mode:
## Architecture Decisions ({N} across {K} modules)
| Module | ID | Title | Status | Date |
|--------|----|-------|--------|------|
| [api] | ADR-0001 | Choose REST over GraphQL | accepted | 2025-01-15 |
| [api] | ADR-0002 | Choose PostgreSQL | proposed | 2025-02-01 |
| [worker] | ADR-0001 | Choose Redis for queues | accepted | 2025-01-20 |
## Specifications ({M} across {K} modules)
| Module | ID | Title | Status | Date |
|--------|----|-------|--------|------|
| [api] | SPEC-0001 | Web Dashboard | approved | 2025-01-20 |
| [worker] | SPEC-0001 | Job Processing | draft | 2025-02-01 | -
Handle empty results: If no ADRs or specs exist, tell the user:
- "No ADRs found. Create one with
/sdd:adr [description]." - "No specs found. Create one with
/sdd:spec [capability]."
- "No ADRs found. Create one with
Rules
- MUST use the Status Field Extraction algorithm in Step 3a to support both YAML-frontmatter and inline-bullet formats — leaving Status blank for legacy repos that use
- **Status:** \{value\}is misleading and was reported as a real-world bug - MUST drop the Status column entirely when zero artifacts in the rendered corpus have a parseable status; render
—for missing entries when the column is partially populated. Workspace aggregate mode: the rendered corpus is the union across all modules — drop the column only when ZERO artifacts across ALL modules have status. If even one module has status, keep the column - MUST strip parenthetical refinement notes from extracted status values (preserved in source files; not rendered in tables)
Example Invocations
list all ADRs in this repo
/sdd:list
show me every accepted spec
what ADRs are still in proposed state?
give me a table of all ADRs with their status and date