@gian-tiaga/eda 0.7.0 → 0.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -3,7 +3,7 @@
3
3
  > Поточная разработка с AI-агентами — на русском языке.
4
4
  > Набор готовых скилов для **Claude Code** и **Codex CLI**, которые ведут тебя через весь цикл: от исследования до коммита.
5
5
 
6
- `eda` — это пятнадцать скилов, каждый отвечает за свой кусок работы. Вместо того чтобы каждый раз объяснять модели, как делать ревью или как исполнять план, ты говоришь одно слово — и она следует чёткой инструкции на русском, со всеми правилами, проверками и артефактами в нужных папках.
6
+ `eda` — это шестнадцать скилов, каждый отвечает за свой кусок работы. Вместо того чтобы каждый раз объяснять модели, как делать ревью или как исполнять план, ты говоришь одно слово — и она следует чёткой инструкции на русском, со всеми правилами, проверками и артефактами в нужных папках.
7
7
 
8
8
  ---
9
9
 
@@ -35,13 +35,14 @@ eda update-all ~/Code
35
35
 
36
36
  | Скил | Что делает | Куда складывает |
37
37
  |---|---|---|
38
+ | `eda-start` | Помогает стартовать новый проект: собирает требования, вместе с пользователем выбирает стек, архитектуру, инструменты качества кода, AI-скилы, агентные инструкции, MCP-серверы и правила проекта. Не пишет код и не ставит зависимости; сохраняет согласованные стартовые решения и по подтверждению создаёт черновики правил/архитектуры/AGENTS | `docs/project-starts/`, опционально `docs/rules.md`, `docs/arch.md`, `AGENTS.md` |
38
39
  | `eda-roadmap` | Создаёт roadmap-файл: список будущих задач с короткими, понятными и недвусмысленными описаниями без деталей реализации, файлов, библиотек, API и пошагового плана | `docs/roadmaps/` |
39
40
  | `eda-explore` | Исследует тему до конкретного результата: описание проблемы, релевантная архитектура, закрытые развилки, риски внутри решений и короткий выбранный вариант решения без плана. В дефолтном режиме ведёт исследование как диалог: факты собирает сам, а значимые развилки выносит тебе с рекомендацией. Если нужны пакеты или ПО — проверяет актуальные стабильные версии через context7 или web search | `docs/researches/` |
40
41
  | `eda-plan` | Пишет план реализации через стандартный Plan Mode хост-агента. `docs/rules.md` и `docs/arch.md` использует как обязательную рамку, а не справочный контекст: план должен строго следовать правилам и архитектуре. В плане явно фиксирует контракты БД/API, если задача их затрагивает. Затем три параллельных субагента/модели (слабая, средняя, мощная) проверяют план на реалистичность, пропущенные шаги и нарушения правил — главный планировщик сам решает, что применить | `docs/plans/` |
41
42
  | `eda-execute` | Выполняет план. Спрашивает, где работать (текущая ветка, новая ветка, отдельный worktree). Перед правками читает план, `docs/rules.md` и `docs/arch.md`; правила и архитектура обязательны к исполнению. Если шаг плана им противоречит, останавливается и спрашивает. Тесты пишет внутри каждого шага. В конце — полный прогон тестов и линтеров | `docs/executions/` |
42
43
  | `eda-fix` | Делает обычные фиксы по короткому контексту, баг-репорту или файлу плана. Перед правками читает правила и архитектуру, добавляет нужные тесты, прогоняет проверки и сохраняет историю правок | `docs/fixes/` |
43
- | `eda-review` | Делает код-ревью с оценкой 0–100 и сверкой с планом работ, но в файл пишет только проблемы: ошибки, недоделки, неточности, нарушения правил/архитектуры, риски и недостающие тесты. Не перечисляет выполненную работу. В обычном режиме после черновика передаёт файл в `eda-review-check`; с флагом `draft` сохраняет только первичное ревью без субагентов | `docs/reviews/` |
44
- | `eda-review-check` | Проверяет готовое ревью из `docs/reviews/` специализированными субагентами: выполнение плана, архитектуру, правила и при включённой настройке качество кода. В строгом режиме добавляет кросс-ревью между Claude и Codex. Сам применяет подтверждённые замечания к файлу ревью, но не правит код | `docs/reviews/` |
44
+ | `eda-review` | Делает код-ревью с оценкой 0–100 и сверкой с планом работ, но в файл пишет только проблемы: ошибки, недоделки, неточности, нарушения правил/архитектуры, риски и недостающие тесты. Если запущен без аргументов, ревьюит незакоммиченный `git diff HEAD` без проверки плана. Не перечисляет выполненную работу. В обычном режиме после черновика передаёт файл в `eda-review-check`; с флагом `draft` сохраняет только первичное ревью без субагентов | `docs/reviews/` |
45
+ | `eda-review-check` | Проверяет готовое ревью из `docs/reviews/` специализированными субагентами: архитектуру, правила, выполнение плана при указанном plan-файле и при включённой настройке качество кода. В строгом режиме добавляет кросс-ревью между Claude и Codex. Сам применяет подтверждённые замечания к файлу ревью, но не правит код | `docs/reviews/` |
45
46
  | `eda-fix-by-review` | Применяет замечания из ревью. Обязательные — сразу. Спорные — спрашивает. В конце ссылается на отчёт прямо в файле ревью | `docs/review-fixes/` |
46
47
  | `eda-polish` | Оркестрирует доводку изменений: запускает `eda-review draft`, затем `eda-review-check`, затем `eda-fix-by-review apply-optional` и повторяет цикл до оценки 95/100 или лимита 5 итераций. Каждый шаг идёт в изолированном субагенте или отдельном CLI-процессе. Не коммитит | `docs/reviews/`, `docs/review-fixes/` |
47
48
  | `eda-send-review` | Отправляет ревью на GitHub PR через `gh` — как комментарий, review, approve или request-changes. Сам определяет PR по текущей ветке | (комментарий в PR) |
@@ -122,6 +123,18 @@ review:
122
123
 
123
124
  ## 🔄 Воркфлоу
124
125
 
126
+ ```text
127
+ start ─────────────> docs ───────────────┬───────────────┐
128
+ │ │ │
129
+ v v v
130
+ roadmap ────────> explore ─────> plan ───> execute ───┬──> review ───> review-check ───> fix-by-review ───┬──> send-review
131
+ │ │ │
132
+ └────────────> plan v └──> commit
133
+ fix ─────────────> review
134
+ ```
135
+
136
+ Если проект уже существует, можно начинать без `eda-start`:
137
+
125
138
  ```text
126
139
  docs ───────────────┬───────────────┐
127
140
  │ │
@@ -136,7 +149,7 @@ polish = review draft ─> review-check ─> fix-by-review apply-optional ─>
136
149
  automate может запускаться от review, fix-by-review или fix.
137
150
  ```
138
151
 
139
- Использовать всю цепочку не обязательно — каждый скил самодостаточен. Можно начать с `eda-roadmap`, `eda-explore`, или сразу с `eda-execute` на готовом плане, или просто `eda-commit`, когда правки уже сделаны. Для параллельной работы есть `eda-worktree`, а для возврата ветки из worktree в текущую ветку — `eda-merge-worktree`.
152
+ Использовать всю цепочку не обязательно — каждый скил самодостаточен. Новый проект можно начать с `eda-start`; существующий — с `eda-roadmap`, `eda-explore`, или сразу с `eda-execute` на готовом плане, или просто `eda-commit`, когда правки уже сделаны. Для параллельной работы есть `eda-worktree`, а для возврата ветки из worktree в текущую ветку — `eda-merge-worktree`.
140
153
 
141
154
  ---
142
155
 
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@gian-tiaga/eda",
3
- "version": "0.7.0",
4
- "description": "Набор скилов eda-* для Claude Code и Codex CLI: roadmap, explore, plan, execute, fix, review, review-check, fix-by-review, polish, send-review, commit, worktree, merge-worktree, docs, automate",
3
+ "version": "0.8.0",
4
+ "description": "Набор скилов eda-* для Claude Code и Codex CLI: start, roadmap, explore, plan, execute, fix, review, review-check, fix-by-review, polish, send-review, commit, worktree, merge-worktree, docs, automate",
5
5
  "type": "module",
6
6
  "bin": {
7
7
  "eda": "bin/cli.js"
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  name: eda-review-check
3
- description: 'Проверяет готовое ревью из `docs/reviews/...` специализированными субагентами и, в strict-режиме, соседним CLI. Не делает первичное ревью и не правит код. Читает ревью, target/plan из front matter, `docs/rules.md`, `docs/arch.md`, `docs/settings.yaml` и связанный research при наличии. Запускает plan-check, architecture-check, rules-check и опциональный quality-check, затем сам применяет подтверждённые замечания к файлу ревью: добавляет, убирает или переформулирует пункты, обновляет score/status/meta_reviewers и раздел изменений после мета-ревью.'
3
+ description: 'Проверяет готовое ревью из `docs/reviews/...` специализированными субагентами и, в strict-режиме, соседним CLI. Не делает первичное ревью и не правит код. Читает ревью, target/plan из front matter, `docs/rules.md`, `docs/arch.md`, `docs/settings.yaml` и связанный research при наличии. Запускает architecture-check, rules-check, plan-check только при указанном plan-файле и опциональный quality-check, затем сам применяет подтверждённые замечания к файлу ревью: добавляет, убирает или переформулирует пункты, обновляет score/status/meta_reviewers и раздел изменений после мета-ревью.'
4
4
  ---
5
5
 
6
6
  # Скил: Проверка ревью (eda-review-check)
@@ -30,7 +30,7 @@ description: 'Проверяет готовое ревью из `docs/reviews/..
30
30
 
31
31
  1. **Не делаешь первичное ревью.** Входом всегда является готовый файл `docs/reviews/...`.
32
32
  2. **Не правишь код.** Можно менять только выбранный файл ревью и вспомогательный файл `${REVIEW_FILE%.md}_cli_meta.md` в strict-режиме.
33
- 3. **Мета-ревью специализированными агентами обязательно.** Базовые роли: `plan-check`, `architecture-check`, `rules-check`. Если включена проверка качества кода — добавь `quality-check` в тот же batch.
33
+ 3. **Мета-ревью специализированными агентами обязательно.** Базовые роли: `architecture-check`, `rules-check`. `plan-check` запускай только если в front matter ревью `plan` указывает на конкретный файл. Если включена проверка качества кода — добавь `quality-check` в тот же batch.
34
34
  4. **Главный редактор ревью — ты.** Субагенты дают предложения; решение добавить, убрать или переформулировать пункт принимаешь сам.
35
35
  5. **Ревью остаётся ревью только по проблемам.** Не добавляй выполненные пункты, похвалу, нейтральный отчёт о diff или общие рассуждения.
36
36
  6. **Каждое принятое изменение фиксируй в `## Изменения после мета-ревью`.** Отклонённые предложения тоже запиши коротко с причиной.
@@ -55,16 +55,16 @@ description: 'Проверяет готовое ревью из `docs/reviews/..
55
55
  - если входа нет — `AskUserQuestion` со списком последних файлов из `docs/reviews/`;
56
56
  - если `docs/reviews/` отсутствует или пуста — остановись со статусом `blocked: нужно ревью`.
57
57
 
58
- Прочитай `$REVIEW_FILE` целиком. Из front matter и текста извлеки `$TARGET`, `$PLAN_FILE`, текущие `mode`, `score`, `status`, `meta_reviewers`. Если target указывает на diff-команду, получи актуальный diff. Если target указывает на файл, папку или PR — прочитай достаточно кода, чтобы проверить замечания. Прочитай `docs/rules.md`, `docs/arch.md`, `docs/settings.yaml`, если они есть. Если ревью ссылается на `docs/researches/...`, прочитай связанный research.
58
+ Прочитай `$REVIEW_FILE` целиком. Из front matter и текста извлеки `$TARGET`, `$PLAN_FILE`, текущие `mode`, `score`, `status`, `meta_reviewers`. Если `plan: none` или план явно помечен как пропущенный, установи `$PLAN_FILE=none`. Если target указывает на diff-команду, получи актуальный diff. Если target указывает на файл, папку или PR — прочитай достаточно кода, чтобы проверить замечания. Прочитай `docs/rules.md`, `docs/arch.md`, `docs/settings.yaml`, если они есть. Если ревью ссылается на `docs/researches/...`, прочитай связанный research.
59
59
 
60
- Если `$PLAN_FILE` отсутствует, не угадывай план. `plan-check` всё равно запускается, но получает явную инструкцию вернуть только `? план не проверен: нужен путь к файлу`.
60
+ Если `$PLAN_FILE=none` или отсутствует, не угадывай план и не запускай `plan-check`. В разделе изменений после мета-ревью коротко зафиксируй: «plan-check не запускался: план не указан в ревью».
61
61
 
62
62
  ### 2. Запустить специализированных субагентов
63
63
 
64
- Запусти **в одном сообщении и одним batch** агентов с разными ролями. В интерактивном Codex это означает субагентов, а не отдельные процессы `codex exec`. Не запускай сначала часть агентов, не жди их ответы и не запускай остальных позже: все проверки должны стартовать до чтения любого результата.
64
+ Запусти **в одном сообщении и одним batch** агентов с выбранными ролями. В интерактивном Codex это означает субагентов, а не отдельные процессы `codex exec`. Не запускай сначала часть агентов, не жди их ответы и не запускай остальных позже: все выбранные проверки должны стартовать до чтения любого результата.
65
65
 
66
66
  Роли агентов:
67
- - `plan-check`: проверяет, что реализация действительно выполнила `$PLAN_FILE`, включая частичные пункты, пропущенные требования, лишние отклонения и недостающие проверки.
67
+ - `plan-check`: запускай только если `$PLAN_FILE` указывает на существующий файл. Проверяет, что реализация действительно выполнила `$PLAN_FILE`, включая частичные пункты, пропущенные требования, лишние отклонения и недостающие проверки.
68
68
  - `architecture-check`: проверяет следование `docs/arch.md`, границы модулей, контракты, зависимости и соответствие существующим архитектурным решениям.
69
69
  - `rules-check`: проверяет следование `docs/rules.md`, локальным запретам, обязательным командам, требованиям к тестам, миграциям, документации и процессу.
70
70
  - `quality-check`: запускай только если `review.include_code_quality: true` или пользователь явно попросил качество кода. Проверяет качество реализации: читаемость, сложность, дублирование, имена, размер и ответственность функций/классов, сцепление модулей, поддерживаемость и соответствие локальному стилю. Quality-замечания помечай типом `quality`; по умолчанию рекомендация `на усмотрение автора`, кроме случаев, где сложность, дублирование или неясная структура реально создают риск багов, тестовых пробелов или дорогого сопровождения.
@@ -73,9 +73,9 @@ description: 'Проверяет готовое ревью из `docs/reviews/..
73
73
  - Claude Code: запускай все роли через `Agent` tool на `model: "sonnet"`.
74
74
  - Codex interactive: если доступен инструмент субагентов (`spawn_agent` или аналог), запускай все роли через него на `gpt-5.3-codex`; не используй отдельные `codex exec` для обычного мета-ревью, когда субагенты доступны.
75
75
  - Codex exec / неинтерактивный fallback: если инструмента субагентов нет, запускай роли через параллельные `codex exec --model gpt-5.3-codex` одной Bash-командой с `&` и общим `wait`.
76
- - Если нужный идентификатор недоступен, возьми ближайшую code-capable модель того же уровня. Не используй быструю слабую модель для этих проверок: они должны читать diff, план, правила, архитектуру и релевантный код.
76
+ - Если нужный идентификатор недоступен, возьми ближайшую code-capable модель того же уровня. Не используй быструю слабую модель для этих проверок: они должны читать diff, план при наличии, правила, архитектуру и релевантный код.
77
77
 
78
- Каждому агенту дай путь к `$REVIEW_FILE`, `$TARGET`, `$PLAN_FILE`, `docs/rules.md`, `docs/arch.md`, `docs/settings.yaml`, связанный research при наличии. Каждый агент должен читать не только ревью, но и фактический diff/код, достаточный для проверки своей роли.
78
+ Каждому агенту дай путь к `$REVIEW_FILE`, `$TARGET`, `docs/rules.md`, `docs/arch.md`, `docs/settings.yaml`, связанный research при наличии. `plan-check` дополнительно получает `$PLAN_FILE`, если он есть. Каждый агент должен читать не только ревью, но и фактический diff/код, достаточный для проверки своей роли.
79
79
 
80
80
  Формат ответа агентов:
81
81
  - `+` какую проблему добавить в ревью;
@@ -83,7 +83,7 @@ description: 'Проверяет готовое ревью из `docs/reviews/..
83
83
  - `~` что переформулировать;
84
84
  - `?` что невозможно проверить и почему.
85
85
 
86
- Для `plan-check` добавь явную инструкцию: «Если `$PLAN_FILE` не передан или файл не найден, верни только `? план не проверен: нужен путь к файлу`; не пытайся угадывать план.»
86
+ Если `$PLAN_FILE` не передан, равен `none` или файл не найден, `plan-check` не запускай.
87
87
 
88
88
  ### 3. Применить результаты обычного мета-ревью
89
89
 
@@ -99,7 +99,7 @@ description: 'Проверяет готовое ревью из `docs/reviews/..
99
99
  - **Отклонено:** <короткий список с причиной>
100
100
  ```
101
101
 
102
- Поменяй `status: draft` → `meta-reviewed`, если статус был draft. В `meta_reviewers` добавь `plan-check`, `architecture-check`, `rules-check`, а если запускался — `quality-check`, и фактические модели, например `gpt-5.3-codex` или `sonnet`. Если оценка после корректировок изменилась — обнови `score`.
102
+ Поменяй `status: draft` → `meta-reviewed`, если статус был draft. В `meta_reviewers` добавь только фактически запущенные роли: `architecture-check`, `rules-check`, `plan-check` при наличии `$PLAN_FILE`, а если запускался — `quality-check`, и фактические модели, например `gpt-5.3-codex` или `sonnet`. Если оценка после корректировок изменилась — обнови `score`.
103
103
 
104
104
  ### 4. Кросс-CLI: отдать соседнему агенту — только в `strict`
105
105
 
@@ -117,6 +117,8 @@ codex exec "Прочитай $REVIEW_FILE, $TARGET, $PLAN_FILE, docs/rules.md, d
117
117
  claude -p "Прочитай $REVIEW_FILE, $TARGET, $PLAN_FILE, docs/rules.md, docs/arch.md, связанный research при наличии. Затем глубоко проверь ревью по плану, правилам, архитектуре и релевантному коду: открой файлы, модули, API и тесты, которые следуют из diff и замечаний, и оцени фактическую корректность. Мета-ревью на русском: какие проблемы добавить, убрать, переформулировать; какие баги, риски для смежного кода и недостающие тесты пропущены. Не предлагай перечислять выполненную работу. Формат: '+', '−', '~', '?'." > "${REVIEW_FILE%.md}_cli_meta.md"
118
118
  ```
119
119
 
120
+ Если `$PLAN_FILE=none`, в промпте соседнему CLI явно напиши: «План не указан; не проверяй выполнение плана и не угадывай файл плана, проверь только правила, архитектуру и код».
121
+
120
122
  Соседней CLI нет — `AskUserQuestion`: завершить как есть или прервать.
121
123
 
122
124
  Прочитай ответ, **сам реши**, что применять. Допиши в `## Изменения после мета-ревью`:
@@ -139,7 +141,7 @@ claude -p "Прочитай $REVIEW_FILE, $TARGET, $PLAN_FILE, docs/rules.md, do
139
141
  - Делать первичное ревью. Это `eda-review`.
140
142
  - Править код. Это `eda-fix-by-review`.
141
143
  - Пропускать мета-ревью специализированными агентами.
142
- - Запускать мета-ревьюеров частями: сначала 1–2 агента, потом остальных. Все обязательные проверки стартуют сразу.
144
+ - Запускать мета-ревьюеров частями: сначала 1–2 агента, потом остальных. Все выбранные обязательные проверки стартуют сразу.
143
145
  - Пропускать кросс-CLI молча в `strict` (если соседней CLI нет — спроси через `AskUserQuestion`).
144
146
  - Вставлять чужие предложения механически — каждое решение принимай ты.
145
147
  - Задавать вопросы без блокировки и продолжать работу до ответа.
@@ -1,11 +1,11 @@
1
1
  ---
2
2
  name: eda-review
3
- description: 'Ревью изменений (незакоммиченный diff, ветка, PR, папка/файл) с обязательной сверкой с планом работ из `docs/plans/`. Если план не указан и его нельзя однозначно определить, спрашивает путь к плану до ревью. Перед ревью читает `docs/rules.md` и `docs/arch.md`. Формирует ревью только по проблемам, сохраняет в `docs/reviews/` и в обычном режиме передаёт файл в `eda-review-check` для мета-проверки субагентами. Флаг `draft` сохраняет только черновое ревью без субагентов. Кросс-CLI включается флагом `strict` или настройкой `defaults.strict: true`. Не правит код — это `eda-fix-by-review`.'
3
+ description: 'Ревью изменений (незакоммиченный diff, ветка, PR, папка/файл) с оценкой и сверкой с планом работ из `docs/plans/`, когда план указан или однозначно найден. Если запущен без аргументов, ревьюит незакоммиченный `git diff HEAD` без проверки плана. Перед ревью читает `docs/rules.md` и `docs/arch.md`. Формирует ревью только по проблемам, сохраняет в `docs/reviews/` и в обычном режиме передаёт файл в `eda-review-check` для мета-проверки субагентами. Флаг `draft` сохраняет только черновое ревью без субагентов. Кросс-CLI включается флагом `strict` или настройкой `defaults.strict: true`. Не правит код — это `eda-fix-by-review`.'
4
4
  ---
5
5
 
6
6
  # Скил: Ревьюер (eda-review)
7
7
 
8
- Делаешь ревью изменений: сверяешь diff с планом работ, правилами и архитектурой, пишешь только найденные проблемы, ставишь оценку, сохраняешь файл. Каждый пункт начинаешь с короткого человеческого объяснения риска, без технической перегрузки; файлы, строки, детали кода и способ исправления даёшь ниже в блоке «Технические детали». Не перечисляешь, что выполнено хорошо или без замечаний. Затем в обычном режиме запускаешь `eda-review-check`, который проверяет ревью параллельными специализированными агентами; в `strict` он добавляет соседний CLI. В `draft` останавливаешься сразу после сохранения черновика.
8
+ Делаешь ревью изменений: сверяешь diff с планом работ, правилами и архитектурой, пишешь только найденные проблемы, ставишь оценку, сохраняешь файл. Если скилл вызван без аргументов, ревьюишь незакоммиченный `git diff HEAD` и не проверяешь план. Каждый пункт начинаешь с короткого человеческого объяснения риска, без технической перегрузки; файлы, строки, детали кода и способ исправления даёшь ниже в блоке «Технические детали». Не перечисляешь, что выполнено хорошо или без замечаний. Затем в обычном режиме запускаешь `eda-review-check`, который проверяет ревью параллельными специализированными агентами; в `strict` он добавляет соседний CLI. В `draft` останавливаешься сразу после сохранения черновика.
9
9
 
10
10
  ## Режим запуска
11
11
 
@@ -33,7 +33,7 @@ description: 'Ревью изменений (незакоммиченный diff
33
33
  1. **Перед ревью** прочитай `docs/rules.md` и `docs/arch.md`, если есть, и строго следуй им. Замечания должны опираться на правила и архитектуру проекта, а не на твои общие представления.
34
34
  2. **Интерактивные вопросы** — по разделу ниже. Если контекст понятен, не спрашивай.
35
35
  3. **Не правишь код.** Только ревью. Запись только в `docs/reviews/`.
36
- 4. **План работ обязателен для ревью выполненных изменений.** Если путь к плану не указан в запросе и его нельзя однозначно определить из diff/ссылок, спроси путь к файлу плана и остановись до ответа. Не подставляй «последний план» наугад.
36
+ 4. **План работ обязателен для явно заданного ревью выполненных изменений.** Если пользователь указал файл, папку, PR, ветку, тип diff или другую цель ревью, а путь к плану не указан и его нельзя однозначно определить из diff/ссылок, спроси путь к файлу плана и остановись до ответа. Исключение: запуск без аргументов — ревью незакоммиченного `git diff HEAD` без проверки плана. Не подставляй «последний план» наугад.
37
37
  5. **Мета-ревью специализированными агентами — обязательно в normal/strict**, но выполняется отдельным скиллом `eda-review-check`. В `draft` мета-ревью не запускается.
38
38
  6. **Главный ревьюер — ты.** Мета-ревьюеры дают подсказки; решение — добавить, убрать или оставить пункт — за тобой. Не вставляй чужие пункты механически.
39
39
  7. **Простой язык** в формулировках замечаний и рекомендаций. Технические термины — только если без них нельзя, и сразу с пояснением.
@@ -48,7 +48,7 @@ description: 'Ревью изменений (незакоммиченный diff
48
48
 
49
49
  ## Интерактивные вопросы
50
50
 
51
- Если цель ревью понятна из запроса или текущего состояния репозитория, **не задавай вопрос о цели ревью**. Это не отменяет обязательный вопрос о `$PLAN_FILE`, если план не указан и не найден однозначно. Примеры понятного контекста:
51
+ Если цель ревью понятна из запроса или текущего состояния репозитория, **не задавай вопрос о цели ревью**. Это не отменяет обязательный вопрос о `$PLAN_FILE` для явно заданной цели, если план не указан и не найден однозначно. Для запуска без аргументов вопрос о плане не задавай: проверка плана пропускается. Примеры понятного контекста:
52
52
  - пользователь указал файл, папку, PR, ветку или тип diff;
53
53
  - в запросе есть «ревью незакоммиченных изменений», «ревью текущей ветки», «проверь PR #N»;
54
54
  - в рабочем дереве есть незакоммиченные изменения и пользователь просит «сделай ревью» без других целей.
@@ -70,16 +70,17 @@ description: 'Ревью изменений (незакоммиченный diff
70
70
 
71
71
  Получи diff/исходник в `$TARGET`. Прочитай `docs/rules.md`, `docs/arch.md` и строго следуй им.
72
72
 
73
- Определи `$PLAN_FILE`:
73
+ Определи `$PLAN_FILE` и `$PLAN_MODE`:
74
+ - если пользователь вызвал скилл без аргументов, а целью выбран незакоммиченный `git diff HEAD` — установи `$PLAN_FILE=none`, `$PLAN_MODE=skipped_no_args` и не спрашивай план;
74
75
  - если пользователь указал путь к плану — используй его;
75
76
  - если в diff, описании задачи или уже существующем review-файле есть однозначная ссылка на `docs/plans/...` — используй её;
76
- - если есть несколько возможных планов или нет ни одного — спроси: «Какой файл плана использовать для проверки выполнения работ?» и остановись до ответа;
77
+ - если цель ревью явно задана пользователем и есть несколько возможных планов или нет ни одного — спроси: «Какой файл плана использовать для проверки выполнения работ?» и остановись до ответа;
77
78
  - если пользователь явно просит ревью без сверки с планом — продолжай, но в ревью укажи, что проверка выполнения плана пропущена по явному указанию пользователя.
78
79
 
79
80
  Если в diff видно отсылки к исследованию из `docs/researches/` — прочитай его тоже.
80
81
 
81
82
  ### 2. Сделать первичное ревью и сохранить
82
- Пройдись по изменениям. Сначала проверь, выполнен ли `$PLAN_FILE`, но в ревью выноси только проблемы: что сделано частично, что не сделано, какие отклонения создают риск, какие проверки отсутствуют. Не перечисляй выполненные пункты плана. Затем проверь нарушения правил, архитектуры, баги, тестовые пробелы, безопасность, производительность и документацию. Если `review.include_code_quality: true` или пользователь явно попросил качество кода, отдельно проверь качество реализации: читаемость, сложность, дублирование, имена, границы ответственности, связность модулей, поддерживаемость и соответствие стилю уже существующего кода.
83
+ Пройдись по изменениям. Если `$PLAN_FILE` указывает на файл, сначала проверь, выполнен ли план, но в ревью выноси только проблемы: что сделано частично, что не сделано, какие отклонения создают риск, какие проверки отсутствуют. Если `$PLAN_FILE=none`, не делай проверку плана и не пытайся восстановить план из последних файлов. Не перечисляй выполненные пункты плана. Затем проверь нарушения правил, архитектуры, баги, тестовые пробелы, безопасность, производительность и документацию. Если `review.include_code_quality: true` или пользователь явно попросил качество кода, отдельно проверь качество реализации: читаемость, сложность, дублирование, имена, границы ответственности, связность модулей, поддерживаемость и соответствие стилю уже существующего кода.
83
84
 
84
85
  Каждое замечание должно быть самостоятельным блоком:
85
86
  - заголовок с номером и коротким смыслом;
@@ -95,6 +96,7 @@ description: 'Ревью изменений (незакоммиченный diff
95
96
  title: <заголовок>
96
97
  date: <YYYY-MM-DD HH:MM>
97
98
  target: <git diff HEAD | main...HEAD | path | PR#>
99
+ plan: <docs/plans/... | none>
98
100
  mode: <draft | normal | strict>
99
101
  score: <0..100>
100
102
  status: draft
@@ -109,7 +111,7 @@ meta_reviewers: []
109
111
 
110
112
  ## Проблемы сверки с планом
111
113
 
112
- <Если проблем по плану нет: «Явных проблем по плану не найдено.»>
114
+ <Если `$PLAN_FILE=none`: «Проверка плана пропущена: запуск без аргументов использует незакоммиченный `git diff HEAD` без сверки с планом.» Если проблем по плану нет: «Явных проблем по плану не найдено.»>
113
115
 
114
116
  ### 1. <недоделка, отклонение или непроверенный пункт>
115
117
 
@@ -154,7 +156,7 @@ meta_reviewers: []
154
156
  Если режим `draft` — не запускай субагентов и не вызывай `eda-review-check`; сразу переходи к финалу draft.
155
157
 
156
158
  ### 3. Проверить ревью через `eda-review-check`
157
- В normal/strict запусти `eda-review-check` для `$REVIEW_FILE` и передай выбранный режим (`normal` или `strict`). Именно `eda-review-check` запускает `plan-check`, `architecture-check`, `rules-check` и при включённой настройке `quality-check`, обновляет `status`, `meta_reviewers`, `score` и раздел `## Изменения после мета-ревью`.
159
+ В normal/strict запусти `eda-review-check` для `$REVIEW_FILE` и передай выбранный режим (`normal` или `strict`). Именно `eda-review-check` запускает `architecture-check`, `rules-check`, а если `plan` в front matter указывает на файл — ещё и `plan-check`; при включённой настройке `quality-check` тоже запускается. Затем `eda-review-check` обновляет `status`, `meta_reviewers`, `score` и раздел `## Изменения после мета-ревью`.
158
160
 
159
161
  Требования к средам остаются частью контракта ревью: Codex interactive: если доступен инструмент субагентов (`spawn_agent` или аналог), используй его; не используй отдельные `codex exec` для обычного мета-ревью, когда субагенты доступны. Codex exec / неинтерактивный fallback допустим только как fallback и описан в `eda-review-check`. Кросс-CLI выполняет только `eda-review-check strict`.
160
162
 
@@ -0,0 +1,226 @@
1
+ ---
2
+ name: eda-start
3
+ description: 'Помогает стартовать новый проект: собирает требования, критерии MVP, ограничения и риски; вместе с пользователем выбирает стек, архитектуру, инструменты качества кода, AI-скилы, агентные инструкции, MCP-серверы и правила проекта. Для библиотек, CLI, сервисов и MCP проверяет актуальные стабильные версии по официальным источникам, если они не заданы. Не пишет код и не устанавливает зависимости: сохраняет согласованный стартовый документ в docs/project-starts/ и черновики docs/rules.md / docs/arch.md / AGENTS.md, если пользователь это подтвердил.'
4
+ ---
5
+
6
+ # Скил: Старт проекта (eda-start)
7
+
8
+ Помогаешь начать новый проект с понятной рамкой: что делаем, для кого, на каком стеке, с какой архитектурой, какими проверками качества, какими AI-скилами и MCP-серверами, и какие правила сразу внедряем. Работаешь как технический партнёр: сначала собираешь факты, затем рекомендуешь варианты и принимаешь решения вместе с пользователем.
9
+
10
+ ## Вход из сообщения пользователя
11
+
12
+ Текст рядом с вызовом скилла в текущем сообщении пользователя — главный вход. Сначала разбери именно его: идею проекта, продуктовую цель, аудиторию, ограничения, сроки, предпочтения по стеку, инфраструктуре, бюджету, команде, требованиям к качеству, безопасности и эксплуатации.
13
+
14
+ Если входа достаточно для первого анализа, не спрашивай подтверждение самой темы, но всё равно задай вопросы по значимым стартовым решениям. `AskUserQuestion` до анализа задавай только если входа нет, он противоречивый, найдено несколько равных тем или есть риск стартовать не тот проект. Старое обсуждение в истории не считай входом, если пользователь не связал его с текущим вызовом явно.
15
+
16
+ ## Главные правила
17
+
18
+ 1. **Интерактивное совместное решение обязательно.** Нельзя молча выбрать стек, архитектуру, правила, MCP или инструменты качества, если это значимо влияет на проект.
19
+ 2. **Не пишешь код и не ставишь пакеты.** Запись только в `docs/project-starts/` и, после явного подтверждения пользователя, в `docs/rules.md`, `docs/arch.md`, `AGENTS.md`.
20
+ 3. **Требования раньше стека.** Сначала выясни продукт, пользователей, MVP, ограничения, данные, интеграции, безопасность, эксплуатацию и команду. Только после этого выбирай стек.
21
+ 4. **Стек подбирается под задачу.** Не навязывай любимые технологии. Для каждого ключевого выбора дай 2–3 реалистичных варианта, рекомендацию и причину.
22
+ 5. **Инструменты качества обязательны для выбранного стека.** Подбери форматтер, линтер, статанализатор/typecheck, тестовый стек, coverage, dependency/security audit, pre-commit и CI-проверки, если они есть и уместны в выбранной экосистеме.
23
+ 6. **MCP и скилы — только по делу.** Рекомендуй MCP-сервер или скил, когда он закрывает реальную нехватку контекста, интеграцию, повторяемый процесс или качество агентной работы.
24
+ 7. **Версии проверяй.** Если предлагаешь пакеты, CLI, фреймворки, сервисы или MCP-серверы, а версия не зафиксирована пользователем, проверь актуальную стабильную версию через context7, если он доступен, или через web search по официальным источникам.
25
+ 8. **Архитектура должна быть объяснима.** Выбранная архитектура обязана соответствовать масштабу MVP, рискам, команде и будущему росту. Не предлагай сложность без причины.
26
+ 9. **Правила должны быть применимы.** Каждое правило должно отвечать на конкретный риск проекта и иметь понятную проверку: автоматическую, ревью-проверку или договорённость в `docs/rules.md`.
27
+ 10. **Простой язык. Таблицы** используй для сравнений стека, инструментов, MCP, скилов, правил и архитектурных вариантов.
28
+
29
+ ## Интерактивные вопросы
30
+
31
+ Когда инструкция говорит `AskUserQuestion`, это означает блокирующий интерактивный вопрос.
32
+ - Claude Code: используй `AskUserQuestion`.
33
+ - Codex interactive: если доступен `request_user_input`, используй его. Если tool недоступен, задай один короткий вопрос в чат, дай варианты 1–3, напиши «Ответь номером или своим вариантом. Я продолжу только после ответа.» и остановись.
34
+ - Codex exec / неинтерактивный запуск: не задавай вопросы и не пытайся читать stdin. Если без ответа нельзя безопасно продолжать, заверши работу со статусом `blocked: нужен ответ пользователя`, перечисли вопросы и варианты, не выполняй рискованные действия.
35
+ - Не запускай команды, которые ждут интерактивного ввода в терминале.
36
+
37
+ Вопросы задавай пакетами по 1–3 за раз. Сначала спрашивай только то, без чего следующий шаг будет гаданием. После каждого пакета используй ответ, обновляй рекомендацию и продолжай.
38
+
39
+ ## Этапы
40
+
41
+ ### 1. Собрать требования
42
+
43
+ Собери и зафиксируй:
44
+ - цель проекта и аудиторию;
45
+ - MVP и что точно не входит в первую версию;
46
+ - основные пользовательские сценарии;
47
+ - типы данных, чувствительные данные, персональные данные и требования к хранению;
48
+ - интеграции, платежи, auth, уведомления, файлы, поиск, аналитика, админку;
49
+ - нагрузку, SLA, бюджет, сроки, размер команды и опыт команды;
50
+ - платформы: web, mobile, desktop, API, CLI, bot, internal tool;
51
+ - ограничения по хостингу, лицензиям, vendor lock-in, compliance и региону.
52
+
53
+ Если не хватает критичных требований, задай `AskUserQuestion` и остановись до ответа.
54
+
55
+ ### 2. Выбрать стек
56
+
57
+ Сравни 2–3 подходящих варианта стека. Для каждого укажи:
58
+ - где он силён для этого проекта;
59
+ - главный риск;
60
+ - стоимость внедрения и поддержки;
61
+ - зрелость экосистемы;
62
+ - совместимость с командой и MVP.
63
+
64
+ Рекомендуй один вариант. Если пользователь не дал режим «сам выбирай», задай `AskUserQuestion`: принять рекомендацию / выбрать альтернативу / сузить требования и пересчитать выбор.
65
+
66
+ Для выбранного стека зафиксируй конкретные версии основных компонентов или источник версии: runtime, framework, БД, ORM, тестовый фреймворк, build tool, package manager, контейнеры и ключевые сервисы.
67
+
68
+ ### 3. Подобрать инструменты качества
69
+
70
+ Для выбранного стека подбери инструменты с обоснованием:
71
+ - форматирование кода;
72
+ - линтеры;
73
+ - статический анализ и typecheck;
74
+ - unit/integration/e2e/contract-тесты;
75
+ - coverage;
76
+ - dependency audit и security scan;
77
+ - schema/API validation;
78
+ - миграции БД и проверки миграций;
79
+ - pre-commit hooks;
80
+ - CI pipeline;
81
+ - генераторы типов или клиентов, если API/схемы это требуют.
82
+
83
+ Не предлагай инструмент, если он дублирует уже выбранный инструмент того же класса без явной пользы. Если в экосистеме есть несколько нормальных вариантов, сравни их и выбери один.
84
+
85
+ ### 4. Выбрать архитектуру
86
+
87
+ Предложи 2–3 архитектурных варианта, соответствующих выбранному стеку и масштабу:
88
+ - простой монолит / modular monolith;
89
+ - API + frontend;
90
+ - event-driven части;
91
+ - serverless;
92
+ - mobile-first / offline-first;
93
+ - plugin/module architecture;
94
+ - другой вариант, если он лучше подходит.
95
+
96
+ Для каждого варианта покажи границы модулей, поток данных, риски и что будет сложно менять позже. Рекомендуй один вариант и задай `AskUserQuestion`, если выбор влияет на стоимость, сроки, масштабирование, данные или команду.
97
+
98
+ ### 5. Решить правила проекта
99
+
100
+ Сформируй набор правил, которые стоит внедрить с первого дня:
101
+ - структура проекта и границы модулей;
102
+ - стиль кода и naming;
103
+ - работа с ошибками и логированием;
104
+ - тестовая стратегия;
105
+ - миграции и данные;
106
+ - API-контракты;
107
+ - безопасность и секреты;
108
+ - доступность и UX, если есть UI;
109
+ - observability;
110
+ - работа с AI-агентами, планами, ревью и коммитами;
111
+ - политика зависимостей и обновлений.
112
+
113
+ Для каждого правила укажи: какой риск оно закрывает, как проверяется, где будет зафиксировано. Затем спроси пользователя, какие правила принять сейчас, какие оставить предложениями и какие убрать.
114
+
115
+ ### 6. Подобрать AI-скилы, агентные инструкции и MCP
116
+
117
+ Подбирай рабочий набор AI-инструментов только после требований, стека, инструментов качества, архитектуры и правил. Эти решения задают контекст: какие источники нужны агенту, какие проверки уже закрыты кодовыми инструментами, где нужны отдельные роли и какие права доступа допустимы.
118
+
119
+ Подбери:
120
+ - какие AI-скилы, slash-команды, агентные инструкции или специализированные роли нужны сразу: старт проекта, продуктовый discovery, планирование, исполнение задач, ревью, security review, проверка доступности, работа с документацией, релизный процесс, domain-expert по предметной области;
121
+ - какие готовые скилы можно взять из доступных наборов, включая `eda-*`, Claude/Codex skills, командные инструкции репозитория или публичные каталоги, если они подходят;
122
+ - какие проектные скилы стоит написать специально под этот проект: например для доменной модели, архитектурных границ, API-контрактов, миграций, дизайн-системы, ревью UI, работы с данными или внутренними интеграциями;
123
+ - какие скилы и агентные роли отложить до появления кода, команды или повторяющейся проблемы;
124
+ - какие MCP-серверы помогут агенту: файловая система, GitHub/GitLab, Postgres/SQLite, браузер, Playwright, Figma, документация, API-клиенты, issue tracker, cloud provider;
125
+ - какие MCP не нужны, потому что выбранная архитектура, правила или инструменты качества уже закрывают задачу.
126
+
127
+ Для каждого скила или агентной инструкции укажи: какую работу закрывает, кто запускает, на каких источниках должен основываться, какой артефакт создаёт, чем проверять результат и почему обычного промпта недостаточно. Не ограничивайся `eda-*`: они только один из возможных источников.
128
+
129
+ Для каждого MCP укажи: зачем он нужен именно при выбранной архитектуре и правилах, какие данные откроет агенту, риски доступа, минимальные права и когда подключать. MCP с доступом к продакшену, секретам, платежам или персональным данным не включай по умолчанию: вынеси на отдельное подтверждение.
130
+
131
+ ### 7. Сохранить стартовый документ
132
+
133
+ Сохрани стартовый документ в `docs/project-starts/{YYYY-MM-DD}_{HH-MM}_{slug}.md`.
134
+
135
+ Формат:
136
+
137
+ ```markdown
138
+ ---
139
+ title: <заголовок>
140
+ date: <YYYY-MM-DD HH:MM>
141
+ status: draft
142
+ sources:
143
+ existing_rules: <путь или —>
144
+ existing_arch: <путь или —>
145
+ ---
146
+
147
+ # Старт проекта
148
+
149
+ ## Требования
150
+ <цель, аудитория, MVP, ограничения, не входит>
151
+
152
+ ## Принятые решения
153
+ | Область | Решение | Почему | Подтверждение |
154
+ |---|---|---|---|
155
+ | Стек | ... | ... | ответ пользователя / рекомендация принята |
156
+
157
+ ## Стек
158
+ | Компонент | Выбор | Версия / источник | Обоснование |
159
+ |---|---|---|---|
160
+
161
+ ## Инструменты качества
162
+ | Класс | Инструмент | Где запускать | Почему |
163
+ |---|---|---|---|
164
+
165
+ ## Архитектура
166
+ <выбранный вариант, границы модулей, поток данных, важные ограничения>
167
+
168
+ ## Правила
169
+ | Правило | Риск | Проверка | Статус |
170
+ |---|---|---|---|
171
+
172
+ ## AI-скилы и агентные инструкции
173
+ | Скил / инструкция | Источник | Когда использовать | Артефакт | Почему |
174
+ |---|---|---|---|---|
175
+
176
+ ## MCP
177
+ | MCP | Когда подключать | Права доступа | Риски |
178
+ |---|---|---|---|
179
+
180
+ ## Открытые вопросы
181
+ - <если есть>
182
+
183
+ ## Следующие шаги
184
+ 1. <создать/обновить docs/rules.md>
185
+ 2. <создать/обновить docs/arch.md>
186
+ 3. <запустить eda-plan для первого инкремента>
187
+ ```
188
+
189
+ Quality gate перед сохранением:
190
+ - есть требования и границы MVP;
191
+ - выбран один основной стек, а не список равных вариантов;
192
+ - инструменты качества покрывают форматирование, lint/static analysis/typecheck, тесты и CI или объясняют, почему часть не нужна;
193
+ - выбрана архитектура и описаны границы;
194
+ - правила имеют риск и способ проверки;
195
+ - есть список AI-скилов, агентных инструкций или ролей с назначением, источником и артефактом, подобранный под выбранную архитектуру и правила;
196
+ - MCP-серверы имеют обоснование, права и риски, связанные с выбранной архитектурой, данными и интеграциями;
197
+ - все значимые решения имеют подтверждение пользователя или явно помечены как автономная рекомендация;
198
+ - версии пакетов/ПО проверены или объяснено, почему это не требуется.
199
+
200
+ ### 8. Создать черновики правил и архитектуры
201
+
202
+ После сохранения стартового документа спроси `AskUserQuestion`: создать черновики `docs/rules.md`, `docs/arch.md` и `AGENTS.md` сейчас / только стартовый документ / выбрать отдельные документы.
203
+
204
+ Если пользователь подтвердил:
205
+ - не перезаписывай существующие файлы молча;
206
+ - для каждого существующего файла спроси: дополнить / создать рядом / оставить как есть;
207
+ - в `docs/rules.md` перенеси только принятые правила, а предложения оставь отдельным разделом;
208
+ - в `docs/arch.md` перенеси выбранную архитектуру, границы модулей, поток данных, данные и интеграции;
209
+ - в `AGENTS.md` добавь краткую карту проекта и ссылки на `docs/rules.md`, `docs/arch.md`, стартовый документ и команды проверки.
210
+
211
+ Если пользователь отказался, не создавай эти файлы и запиши отказ в финале.
212
+
213
+ ### 9. Финал
214
+
215
+ Короткое сообщение: путь к стартовому документу, какие решения приняты, какие документы созданы или не созданы, какие вопросы остались открытыми, какой следующий скил логично использовать (`eda-plan` для первого инкремента или `eda-docs` для доработки правил и архитектуры).
216
+
217
+ ## Чего НЕ делать
218
+
219
+ - Создавать приложение, писать код, миграции, конфиги, CI или устанавливать зависимости.
220
+ - Выбирать стек до требований.
221
+ - Давать один вариант без объяснения альтернатив, если решение значимое.
222
+ - Ставить MCP по умолчанию с широкими правами доступа.
223
+ - Подменять линтеры, статанализаторы, typecheck и тесты агентными проверками.
224
+ - Внедрять правила без согласия пользователя.
225
+ - Перезаписывать существующие `docs/rules.md`, `docs/arch.md` или `AGENTS.md` без отдельного подтверждения.
226
+ - Сохранять стартовый документ куда-либо кроме `docs/project-starts/`.