Files
brain/docs/registry
Дмитрий 9ad00cf96c feat(registry): фундамент-словарь capability-токенов (этап 2a, роутер-реестр)
Phase 2a эпика «роутер-реестр» (спека v2 §3, OPEN-1): расширен
docs/registry/capability-vocabulary.json 10 -> 26 токенов.

- A8-цепочка (10) сохранена.
- 9 токенов-мостов рабочих цепочек (создают рёбра графа producer<->consumer):
  feature-spec, implementation-plan, completed-change, code-review-feedback,
  raw-research, ui-design, marketing-draft, content-framework, close-entries.
- 7 токенов-данностей задачи (-> initialInputs в 2c): feature-intent,
  feature-or-bugfix, bug-or-failure, ui-task, user-understanding-need,
  marketing-content-task, close-source-data.
- Тест формы на реальном файле (validateVocabulary ok + счётчик + ключевые токены).

Атомарные produce-токены ~144 контрактов добавляются в 2b (словарь живой).
Структурная разведка подтверждена графом проекта (graphify, правило 14):
coverage-machine не подключён к живому enforce-judge-gate (работа 2c),
два реестра (контрактный community 92 / узловой community 20).

Регрессия: 4367 passed, exit 0 (5 чужих node:test исключены).

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-19 08:57:36 +03:00
..

Node Registry

Машиночитаемый реестр узлов тулчейна Лидерры — single source of truth для router-procedure.md, хуков enforcement'а (этапы 2-3 router discipline overhaul) и auto-rendered секций в нормативке.

Файлы

  • nodes.yaml — реестр 83 узлов + 16 цепочек L1-L16. Источник истины.
  • schema.json — JSON Schema, валидация nodes.yaml при загрузке.
  • README.md — этот файл.

Как читать узел

- id: "#19"                # уникальный идентификатор из Tooling Прил. Н §0
  name: "Superpowers v5.1.0"
  slug: "superpowers"      # каноническое имя для invocation (kebab-ASCII)
  category: "phase-2"      # phase-0 / phase-1 / phase-2 / phase-3 / off-phase
  subcategory: null        # либо строка (architecture-tooling, debug-runtime, ...)
  status: "active"         # active | dormant | deferred | historic
  dormancy_reason: null    # null если active, иначе текст причины
  triggers:                # как роутер выбирает узел
    - {classification: "feature", weight: 1.0}
    - {keyword: "tdd", weight: 1.0}
    - {file_pattern: "tests/**/*.php", weight: 1.0}
  boundaries:              # связи с другими узлами (ADR, paired stack, replaces)
    - {adr: "ADR-011", role: "hard-floor source"}
    - {pair: "#30", relation: "paired stack"}
  chain_membership: ["L1", "L8"]   # в каких L-цепочках участвует (sorted)
  attributes:              # свободная map для прочих метаданных
    tooling_section: "§3.3 #19"
    install: "marketplace plugin"

Status маппинг

Status Что значит
active Узел активно используется.
dormant Узел отключён/заменён без эквивалента. Артефакт реестра сохраняется (#17 pg_partman — заменён ручным cron'ом).
deferred Узел запланирован, но pending Б-1 / undeployed dependencies (#34 Sentry, #44 Figma, #67 NightOwl, #82 DataForSEO, #83 Unisender Go).
historic Узел заменён другим узлом реестра ({pair: "#N", relation: "replaced by"}). #1 PG MCP заменён #10 Boost.

Trigger типы

  • {keyword: "<lowercase trimmed>", weight} — exact-match по фразе.
  • {classification: "<class>", weight} — соответствие классу задачи (feature/planning/bugfix/refactor/...).
  • {file_pattern: "<glob>", weight} — соответствие пути файла (tests/**/*.php).

Weight — number ∈ [0, 1]. По умолчанию 1.0.

Boundaries

  • {adr: "ADR-XXX", role: "<role>"} — узел связан с ADR-решением.
  • {pair: "#N", relation: "<rel>"} — узел связан с другим узлом реестра (replaces, replaced by, paired stack).
  • {relation: "<text>"} — свободная связь (правила PSR_v1, описательная роль).

Как добавить новый узел

  1. Получить новый #N из Tooling Прил. Н §0 (канон счётчика).
  2. Открыть nodes.yaml, добавить блок в массив nodes: (в правильное место по числовой сортировке).
  3. Триггеры: что должен сказать заказчик / какой класс задач включает узел. Lowercase, trimmed, без двоеточий.
  4. Границы: какие ADR разделяют узел от соседей, есть ли paired stack.
  5. Прогнать рендер: node tools/registry-render.mjs — должно перерендерить Tooling §4.0 + routing-off-phase routing-table.
  6. Запустить тесты: cd app && npx vitest --config vitest.config.tools.mjs run ../tools/registry-load.test.mjs. Все должны быть GREEN.
  7. Закоммитить YAML + Tooling/routing-off-phase одним коммитом.

Auto-render

tools/registry-render.mjs пишет в auto-region маркеры:

  • <!-- auto:tooling-registry-summary:begin --> в docs/Tooling_v8_3.md §4.0 (краткая сводка 83 узлов).
  • <!-- auto:routing-table:begin --> в docs/routing-off-phase.md (routing-table по classifications).

Не правьте содержимое между маркерами вручную — оно перезатрётся при следующем рендере. Для изменения структуры таблицы — правьте tools/registry-render.mjs renderer functions.

Запуск:

node tools/registry-render.mjs          # переписать файлы
node tools/registry-render.mjs --check  # exit 1 если drift (для lefthook)

Lefthook gate

registry-render-check — pre-commit job 17 в lefthook.yml. Триггерится на изменения docs/registry/nodes.yaml / docs/Tooling_v8_3.md / docs/routing-off-phase.md. Warn-only первую неделю (if/then/fi block, exit 0 даже при drift). Если видишь WARN — запусти:

node tools/registry-render.mjs && git add docs/Tooling_v8_3.md docs/routing-off-phase.md

После стабилизации (когда команда привыкнет к workflow) — убрать warn-fallback и сделать blocking.

Цепочки L1-L16

16 канонических связок 2+ узлов (см. chains: секцию в nodes.yaml). Источник истины — docs/routing-off-phase.md §4 (таблица L1-L16). При изменении routing-off-phase — обновляйте chains в nodes.yaml синхронно.

Связано