Compare commits
13 Commits
5229f12536
...
d22697a4c6
| Author | SHA1 | Date |
|---|---|---|
|
|
d22697a4c6 | |
|
|
feab3d5e4e | |
|
|
49e9c2dd3a | |
|
|
12e1889301 | |
|
|
64fa6d1fe3 | |
|
|
111c9e6fd4 | |
|
|
327023a7ea | |
|
|
a3d7cf0fcc | |
|
|
ba50ddf4a0 | |
|
|
b0f818ecf9 | |
|
|
514f15e59f | |
|
|
106143f4d9 | |
|
|
c42bc2e090 |
|
|
@ -0,0 +1,113 @@
|
|||

|
||||
|
||||
[](https://www.npmjs.com/package/bmad-method)
|
||||
[](LICENSE)
|
||||
[](https://nodejs.org)
|
||||
[](https://www.python.org)
|
||||
[](https://docs.astral.sh/uv/)
|
||||
[](https://discord.gg/gk8jAdXWmj)
|
||||
|
||||
[English](README.md) | [简体中文](README_CN.md) | [Tiếng Việt](README_VN.md) | 한국어
|
||||
|
||||
**Build More Architect Dreams** - BMad Method 모듈 생태계를 위한 AI 기반 애자일 개발 모듈입니다. 버그 수정부터 엔터프라이즈 시스템까지, 프로젝트 규모와 도메인에 맞춰 계획 깊이를 조절하는 포괄적인 프레임워크입니다.
|
||||
|
||||
**100% 무료 오픈 소스입니다.** 유료 장벽도, 잠긴 콘텐츠도, 폐쇄형 Discord도 없습니다. 우리는 닫힌 커뮤니티나 강좌 비용을 낼 수 있는 사람만이 아니라 모두가 더 나은 도구를 쓸 수 있어야 한다고 믿습니다.
|
||||
|
||||
## 왜 BMad Method인가요?
|
||||
|
||||
전통적인 AI 도구는 사용자를 대신해 생각하고 평균적인 결과를 내는 데 그치는 경우가 많습니다. BMad의 전문 에이전트와 안내형 워크플로는 AI와 함께 더 나은 사고를 끌어내도록 돕는 전문가 협업자처럼 작동합니다.
|
||||
|
||||
- **AI 안내 도움말** - 언제든 `bmad-help` 스킬을 호출해 다음 단계 안내를 받습니다
|
||||
- **규모와 도메인에 적응** - 프로젝트 복잡도에 맞춰 계획 깊이를 자동으로 조절합니다
|
||||
- **구조화된 워크플로** - 분석, 계획, 아키텍처, 구현 전반에 애자일 모범 사례를 적용합니다
|
||||
- **전문 에이전트** - PM, 아키텍트, 개발자, UX 등 12개 이상의 역할별 전문가를 제공합니다
|
||||
- **파티 모드** - 여러 에이전트 페르소나를 한 세션에 불러와 함께 협업하고 토론합니다
|
||||
- **전체 수명주기 지원** - 브레인스토밍부터 배포까지 함께합니다
|
||||
|
||||
[**docs.bmad-method.org**에서 더 알아보기](https://docs.bmad-method.org/ko-kr/)
|
||||
|
||||
## BMad의 다음 단계
|
||||
|
||||
**V6가 출시됐고, 이제 시작입니다!** BMad Method는 크로스 플랫폼 에이전트 팀과 서브 에이전트 통합, 스킬 아키텍처, BMad 빌더 v1, 개발 루프 자동화 등 여러 개선과 함께 빠르게 진화하고 있습니다.
|
||||
|
||||
**[전체 로드맵 보기](https://docs.bmad-method.org/ko-kr/roadmap/)**
|
||||
|
||||
## 빠른 시작
|
||||
|
||||
**필수 조건**: [Node.js](https://nodejs.org) v20+ · [Python](https://www.python.org) 3.10+ · [uv](https://docs.astral.sh/uv/)
|
||||
|
||||
```bash
|
||||
npx bmad-method install
|
||||
```
|
||||
|
||||
> 최신 사전 릴리스 빌드를 사용하려면 `npx bmad-method@next install`을 실행하세요. 기본 설치보다 변경이 더 잦을 수 있습니다.
|
||||
|
||||
설치 프로그램의 안내를 따른 다음, Claude Code나 Cursor 같은 AI IDE를 프로젝트 폴더에서 엽니다.
|
||||
|
||||
**비대화형 설치**(CI/CD용):
|
||||
|
||||
```bash
|
||||
npx bmad-method install --directory /path/to/project --modules bmm --tools claude-code --yes
|
||||
```
|
||||
|
||||
모듈 설정 옵션은 `--set <module>.<key>=<value>`로 재정의할 수 있습니다. 여러 번 사용할 수 있습니다. 로컬에서 알려진 공식 키를 보려면 `--list-options [module]`을 실행하세요.
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes \
|
||||
--modules bmm --tools claude-code \
|
||||
--set bmm.project_knowledge=research \
|
||||
--set bmm.user_skill_level=expert
|
||||
```
|
||||
|
||||
[전체 설치 옵션 보기](https://docs.bmad-method.org/ko-kr/how-to/non-interactive-installation/)
|
||||
|
||||
> **무엇을 해야 할지 모르겠나요?** `bmad-help`에게 물어보세요. 다음에 해야 할 일과 선택 사항을 정확히 알려줍니다. `bmad-help 아키텍처를 막 끝냈는데 다음에 무엇을 해야 하나요?`처럼 질문할 수도 있습니다.
|
||||
|
||||
## 모듈
|
||||
|
||||
BMad Method는 전문 도메인을 위한 공식 모듈로 확장됩니다. 설치 중에 선택하거나 나중에 추가할 수 있습니다.
|
||||
|
||||
| 모듈 | 목적 |
|
||||
| ----------------------------------------------------------------------------------------------------------------- | -------------------------------------------- |
|
||||
| **[BMad Method(BMM)](https://github.com/bmad-code-org/BMAD-METHOD)** | 34개 이상의 워크플로를 제공하는 핵심 프레임워크 |
|
||||
| **[BMad 빌더(BMB)](https://github.com/bmad-code-org/bmad-builder)** | 커스텀 BMad 에이전트와 워크플로 생성 |
|
||||
| **[테스트 설계자(TEA)](https://github.com/bmad-code-org/bmad-method-test-architecture-enterprise)** | 위험 기반 테스트 전략과 자동화 |
|
||||
| **[게임 개발 스튜디오(BMGD)](https://github.com/bmad-code-org/bmad-module-game-dev-studio)** | Unity, Unreal, Godot 워크플로 |
|
||||
| **[창의적 지능 제품군(CIS)](https://github.com/bmad-code-org/bmad-module-creative-intelligence-suite)** | 혁신, 브레인스토밍, 디자인 사고 |
|
||||
|
||||
## 문서
|
||||
|
||||
[BMad Method 문서 사이트](https://docs.bmad-method.org/ko-kr/) - 튜토리얼, 가이드, 개념 설명, 참조 문서
|
||||
|
||||
**빠른 링크:**
|
||||
|
||||
- [시작하기 튜토리얼](https://docs.bmad-method.org/ko-kr/tutorials/getting-started/)
|
||||
- [이전 버전에서 업그레이드](https://docs.bmad-method.org/ko-kr/how-to/upgrade-to-v6/)
|
||||
- [테스트 설계자 문서](https://bmad-code-org.github.io/bmad-method-test-architecture-enterprise/)
|
||||
|
||||
## 커뮤니티
|
||||
|
||||
- [Discord](https://discord.gg/gk8jAdXWmj) - 도움을 받고, 아이디어를 나누고, 협업하세요
|
||||
- [YouTube](https://youtube.com/@BMadCode) - 튜토리얼, 마스터 클래스 등
|
||||
- [X / Twitter](https://x.com/BMadCode)
|
||||
- [웹사이트](https://bmadcode.com)
|
||||
- [GitHub Issues](https://github.com/bmad-code-org/BMAD-METHOD/issues) - 버그 제보와 기능 요청
|
||||
- [토론](https://github.com/bmad-code-org/BMAD-METHOD/discussions) - 커뮤니티 대화
|
||||
|
||||
## BMad 후원
|
||||
|
||||
BMad는 모두에게 무료이며 앞으로도 그럴 것입니다. 이 저장소에 스타를 눌러 주거나, [커피 한 잔 후원](https://buymeacoffee.com/bmad)을 보내거나, 기업 후원은 <contact@bmadcode.com>으로 문의해 주세요.
|
||||
|
||||
## 기여
|
||||
|
||||
기여를 환영합니다! 자세한 지침은 [CONTRIBUTING.md](CONTRIBUTING.md)를 확인하세요.
|
||||
|
||||
## 라이선스
|
||||
|
||||
MIT 라이선스입니다. 자세한 내용은 [LICENSE](LICENSE)를 확인하세요.
|
||||
|
||||
**BMad**와 **BMAD-METHOD**는 BMad Code, LLC의 상표입니다. 자세한 내용은 [TRADEMARK.md](TRADEMARK.md)를 확인하세요.
|
||||
|
||||
[](https://github.com/bmad-code-org/BMAD-METHOD/graphs/contributors)
|
||||
|
||||
기여자 정보는 [CONTRIBUTORS.md](CONTRIBUTORS.md)를 확인하세요.
|
||||
|
|
@ -0,0 +1,8 @@
|
|||
---
|
||||
title: 페이지를 찾을 수 없음
|
||||
template: splash
|
||||
---
|
||||
|
||||
찾으려는 페이지가 없거나 이동되었습니다.
|
||||
|
||||
[홈으로 돌아가기](./index.md)
|
||||
|
|
@ -0,0 +1,370 @@
|
|||
---
|
||||
title: "문서 스타일 가이드"
|
||||
description: Google 스타일과 Diataxis 구조를 바탕으로 한 프로젝트별 문서 작성 규칙
|
||||
---
|
||||
|
||||
이 프로젝트는 [Google Developer 문서 스타일 가이드](https://developers.google.com/style)를 따르고 [Diataxis](https://diataxis.fr/)로 콘텐츠를 구조화합니다. 아래에는 프로젝트별 규칙만 정리합니다.
|
||||
|
||||
## 프로젝트별 규칙
|
||||
|
||||
| 규칙 | 사양 |
|
||||
| --- | --- |
|
||||
| 가로 구분선(`---`) 사용 금지 | 읽기 흐름을 끊습니다 |
|
||||
| `####` 헤더 사용 금지 | 대신 굵은 글씨나 알림 상자를 사용합니다 |
|
||||
| "관련 항목" 또는 "다음:" 섹션 금지 | 사이드바가 탐색을 담당합니다 |
|
||||
| 깊게 중첩된 목록 금지 | 섹션으로 나누세요 |
|
||||
| 코드가 아닌 내용에 코드 블록 사용 금지 | 대화 예시는 알림 상자를 사용합니다 |
|
||||
| 콜아웃용 굵은 문단 금지 | 대신 알림 상자를 사용합니다 |
|
||||
| 섹션당 알림 상자 1-2개까지 | 튜토리얼은 큰 섹션당 3-4개까지 허용합니다 |
|
||||
| 표 셀 / 목록 항목 | 최대 1-2문장 |
|
||||
| 헤더 예산 | 문서당 `##` 8-12개, 섹션당 `###` 2-3개 |
|
||||
|
||||
## 알림 상자(Starlight 문법)
|
||||
|
||||
```md
|
||||
:::tip[제목]
|
||||
단축키, 모범 사례
|
||||
:::
|
||||
|
||||
:::note[제목]
|
||||
맥락, 정의, 예시, 필수 조건
|
||||
:::
|
||||
|
||||
:::caution[제목]
|
||||
주의 사항, 잠재적 문제
|
||||
:::
|
||||
|
||||
:::danger[제목]
|
||||
데이터 손실, 보안 문제 같은 중대한 경고에만 사용
|
||||
:::
|
||||
```
|
||||
|
||||
### 표준 용도
|
||||
|
||||
| 알림 상자 | 사용처 |
|
||||
| --- | --- |
|
||||
| `:::note[필수 조건]` | 시작 전 필요한 의존성 |
|
||||
| `:::tip[빠른 경로]` | 문서 상단의 짧은 요약 |
|
||||
| `:::caution[중요]` | 중요한 주의 사항 |
|
||||
| `:::note[예시]` | 명령/응답 예시 |
|
||||
|
||||
## 표준 표 형식
|
||||
|
||||
**단계:**
|
||||
|
||||
```md
|
||||
| 단계 | 이름 | 내용 |
|
||||
| --- | --- | --- |
|
||||
| 1 | 분석 | 브레인스토밍, 리서치 *(선택 사항)* |
|
||||
| 2 | 계획 | 요구사항 - PRD 또는 사양 *(필수)* |
|
||||
```
|
||||
|
||||
**스킬:**
|
||||
|
||||
```md
|
||||
| 스킬 | 에이전트 | 목적 |
|
||||
| --- | --- | --- |
|
||||
| `bmad-brainstorming` | 분석가 | 새 프로젝트 브레인스토밍 |
|
||||
| `bmad-create-prd` | PM | 제품 요구사항 문서 생성 |
|
||||
```
|
||||
|
||||
## 폴더 구조 블록
|
||||
|
||||
"달성한 것" 섹션에서는 다음처럼 표시합니다.
|
||||
|
||||
````md
|
||||
```
|
||||
your-project/
|
||||
├── _bmad/ # BMad 설정
|
||||
├── _bmad-output/
|
||||
│ ├── planning-artifacts/
|
||||
│ │ └── PRD.md # 요구사항 문서
|
||||
│ ├── implementation-artifacts/
|
||||
│ └── project-context.md # 구현 규칙 (선택 사항)
|
||||
└── ...
|
||||
```
|
||||
````
|
||||
|
||||
## 튜토리얼 구조
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(결과를 설명하는 1-2문장)
|
||||
2. 버전/모듈 안내(정보 또는 경고 알림 상자, 선택)
|
||||
3. 배울 내용(결과 중심 글머리표 목록)
|
||||
4. 필수 조건(정보 알림 상자)
|
||||
5. 빠른 경로(tip 알림 상자 - 짧은 요약)
|
||||
6. [주제] 이해하기(단계 전 맥락 - 단계/에이전트 표)
|
||||
7. 설치(선택)
|
||||
8. 1단계: [첫 번째 주요 작업]
|
||||
9. 2단계: [두 번째 주요 작업]
|
||||
10. 3단계: [세 번째 주요 작업]
|
||||
11. 달성한 것(요약 + 폴더 구조)
|
||||
12. 빠른 참조(스킬 표)
|
||||
13. 자주 묻는 질문(FAQ 형식)
|
||||
14. 도움 받기(커뮤니티 링크)
|
||||
15. 핵심 요약(tip 알림 상자)
|
||||
```
|
||||
|
||||
### 튜토리얼 체크리스트
|
||||
|
||||
- [ ] 후킹 문장이 결과를 1-2문장으로 설명합니다
|
||||
- [ ] "배울 내용" 섹션이 있습니다
|
||||
- [ ] 필수 조건이 알림 상자에 있습니다
|
||||
- [ ] 상단에 빠른 경로 요약 알림 상자가 있습니다
|
||||
- [ ] 단계, 스킬, 에이전트를 표로 제시합니다
|
||||
- [ ] "달성한 것" 섹션이 있습니다
|
||||
- [ ] 빠른 참조 표가 있습니다
|
||||
- [ ] 자주 묻는 질문 섹션이 있습니다
|
||||
- [ ] 도움 받기 섹션이 있습니다
|
||||
- [ ] 마지막에 핵심 요약 알림 상자가 있습니다
|
||||
|
||||
## 사용 가이드 구조
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장("`X` 워크플로를 사용해..." 한 문장)
|
||||
2. 사용 시점(3-5개 글머리표 목록)
|
||||
3. 건너뛸 시점(선택)
|
||||
4. 필수 조건(note 알림 상자)
|
||||
5. 단계(번호가 붙은 ### 하위 섹션)
|
||||
6. 얻는 결과(생성되는 산출물)
|
||||
7. 예시(선택)
|
||||
8. 팁(선택)
|
||||
9. 다음 단계(선택)
|
||||
```
|
||||
|
||||
### 사용 가이드 체크리스트
|
||||
|
||||
- [ ] 후킹 문장이 "`X` 워크플로를 사용해..."로 시작합니다
|
||||
- [ ] "사용 시점"에 3-5개 글머리표가 있습니다
|
||||
- [ ] 필수 조건이 나열되어 있습니다
|
||||
- [ ] 단계는 동작 동사로 시작하는 번호가 붙은 `###` 하위 섹션입니다
|
||||
- [ ] "얻는 결과"가 산출물을 설명합니다
|
||||
|
||||
## 개념 설명 구조
|
||||
|
||||
### 유형
|
||||
|
||||
| 유형 | 예시 |
|
||||
| --- | --- |
|
||||
| **인덱스/랜딩** | `core-concepts/index.md` |
|
||||
| **개념** | `what-are-agents.md` |
|
||||
| **기능** | `quick-dev.md` |
|
||||
| **철학** | `why-solutioning-matters.md` |
|
||||
| **FAQ** | `established-projects-faq.md` |
|
||||
|
||||
### 일반 템플릿
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(1-2문장)
|
||||
2. 개요/정의(무엇이며 왜 중요한지)
|
||||
3. 핵심 개념(### 하위 섹션)
|
||||
4. 비교 표(선택)
|
||||
5. 사용할 때 / 사용하지 않을 때(선택)
|
||||
6. 다이어그램(선택 - mermaid, 문서당 최대 1개)
|
||||
7. 다음 단계(선택)
|
||||
```
|
||||
|
||||
### 인덱스/랜딩 페이지
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(한 문장)
|
||||
2. 콘텐츠 표(설명이 있는 링크)
|
||||
3. 시작하기(번호 목록)
|
||||
4. 경로 선택(선택 - 의사결정 트리)
|
||||
```
|
||||
|
||||
### 개념 설명 문서
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(무엇인지)
|
||||
2. 유형/범주(### 하위 섹션, 선택)
|
||||
3. 주요 차이 표
|
||||
4. 구성 요소/부분
|
||||
5. 무엇을 사용해야 하나요?
|
||||
6. 생성/커스터마이징(사용 가이드 링크)
|
||||
```
|
||||
|
||||
### 기능 설명 문서
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(무엇을 하는지)
|
||||
2. 빠른 정보(선택 - "적합한 경우:", "소요 시간:")
|
||||
3. 사용할 때 / 사용하지 않을 때
|
||||
4. 작동 방식(mermaid 다이어그램 선택)
|
||||
5. 핵심 이점
|
||||
6. 비교 표(선택)
|
||||
7. 졸업/업그레이드 시점(선택)
|
||||
```
|
||||
|
||||
### 철학/근거 문서
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(원칙)
|
||||
2. 문제
|
||||
3. 해결책
|
||||
4. 핵심 원칙(### 하위 섹션)
|
||||
5. 이점
|
||||
6. 적용 시점
|
||||
```
|
||||
|
||||
### 개념 설명 체크리스트
|
||||
|
||||
- [ ] 후킹 문장이 문서가 설명하는 내용을 말합니다
|
||||
- [ ] 스캔하기 쉬운 `##` 섹션으로 구성합니다
|
||||
- [ ] 3개 이상의 선택지가 있으면 비교 표를 사용합니다
|
||||
- [ ] 다이어그램에는 명확한 라벨이 있습니다
|
||||
- [ ] 절차적 질문에는 사용 가이드 링크를 제공합니다
|
||||
- [ ] 문서당 알림 상자는 최대 2-3개입니다
|
||||
|
||||
## 참조 문서 구조
|
||||
|
||||
### 유형
|
||||
|
||||
| 유형 | 예시 |
|
||||
| --- | --- |
|
||||
| **인덱스/랜딩** | `workflows/index.md` |
|
||||
| **카탈로그** | `agents/index.md` |
|
||||
| **심층 설명** | `document-project.md` |
|
||||
| **설정** | `core-tasks.md` |
|
||||
| **용어집** | `glossary/index.md` |
|
||||
| **종합 가이드** | `bmgd-workflows.md` |
|
||||
|
||||
### 참조 인덱스 페이지
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(한 문장)
|
||||
2. 콘텐츠 섹션(각 범주에 ## 사용)
|
||||
- 링크와 설명이 있는 글머리표 목록
|
||||
```
|
||||
|
||||
### 카탈로그 참조
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장
|
||||
2. 항목(각 항목에 ## 사용)
|
||||
- 짧은 설명(한 문장)
|
||||
- **스킬:** 또는 **핵심 정보:** 형태의 평평한 목록
|
||||
3. 공통/공유 섹션(## 섹션, 선택)
|
||||
```
|
||||
|
||||
### 항목 심층 참조
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장(한 문장 목적)
|
||||
2. 빠른 정보(note 알림 상자, 선택)
|
||||
- 모듈, 스킬, 입력, 출력 목록
|
||||
3. 목적/개요(## 섹션)
|
||||
4. 호출 방법(코드 블록)
|
||||
5. 핵심 섹션(각 측면에 ## 사용)
|
||||
- 하위 선택지에는 ### 사용
|
||||
6. 참고/주의 사항(tip 또는 caution 알림 상자)
|
||||
```
|
||||
|
||||
### 설정 참조
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장
|
||||
2. 목차(항목이 4개 이상이면 점프 링크)
|
||||
3. 항목(각 설정/작업에 ## 사용)
|
||||
- **굵은 요약** — 한 문장
|
||||
- **사용 시점:** 글머리표 목록
|
||||
- **작동 방식:** 번호 목록(최대 3-5개)
|
||||
- **출력:** 예상 결과(선택)
|
||||
```
|
||||
|
||||
### 종합 참조 가이드
|
||||
|
||||
```text
|
||||
1. 제목 + 후킹 문장
|
||||
2. 개요(## 섹션)
|
||||
- 구성을 보여주는 다이어그램 또는 표
|
||||
3. 주요 섹션(각 단계/범주에 ## 사용)
|
||||
- 항목(각 항목에 ### 사용)
|
||||
- 표준 필드: 스킬, 에이전트, 입력, 출력, 설명
|
||||
4. 다음 단계(선택)
|
||||
```
|
||||
|
||||
### 참조 체크리스트
|
||||
|
||||
- [ ] 후킹 문장이 문서가 참조하는 내용을 말합니다
|
||||
- [ ] 구조가 참조 유형에 맞습니다
|
||||
- [ ] 항목은 전체적으로 일관된 구조를 사용합니다
|
||||
- [ ] 구조화/비교 데이터에는 표를 사용합니다
|
||||
- [ ] 개념적 깊이가 필요한 곳에는 개념 설명 문서 링크를 둡니다
|
||||
- [ ] 알림 상자는 최대 1-2개입니다
|
||||
|
||||
## 용어집 구조
|
||||
|
||||
Starlight는 헤더에서 오른쪽 "이 페이지에서" 탐색을 생성합니다.
|
||||
|
||||
- 범주는 `##` 헤더로 작성합니다. 오른쪽 탐색에 표시됩니다
|
||||
- 용어는 개별 헤더가 아니라 표 안의 간결한 행으로 작성합니다
|
||||
- 인라인 TOC는 사용하지 않습니다. 오른쪽 사이드바가 탐색을 담당합니다
|
||||
|
||||
### 표 형식
|
||||
|
||||
```md
|
||||
## 범주 이름
|
||||
|
||||
| 용어 | 정의 |
|
||||
| --- | --- |
|
||||
| **에이전트** | 특정 전문성을 갖고 워크플로 전반에서 사용자를 안내하는 특화 AI 페르소나입니다. |
|
||||
| **워크플로** | 산출물을 만들기 위해 AI 에이전트 활동을 조율하는 여러 단계의 안내형 프로세스입니다. |
|
||||
```
|
||||
|
||||
### 정의 규칙
|
||||
|
||||
| 해야 할 것 | 하지 말 것 |
|
||||
| --- | --- |
|
||||
| 무엇인지 또는 무엇을 하는지로 시작합니다 | "이것은..." 또는 "이 용어는..."으로 시작합니다 |
|
||||
| 1-2문장으로 유지합니다 | 여러 문단으로 설명합니다 |
|
||||
| 셀 안의 용어명을 굵게 표시합니다 | 용어를 일반 텍스트로 둡니다 |
|
||||
|
||||
### 컨텍스트 표시
|
||||
|
||||
범위가 제한된 용어는 정의 시작에 이탤릭 컨텍스트를 추가합니다.
|
||||
|
||||
- `*빠른 흐름 전용.*`
|
||||
- `*BMad Method/엔터프라이즈.*`
|
||||
- `*N단계.*`
|
||||
- `*BMGD.*`
|
||||
- `*기존 프로젝트.*`
|
||||
|
||||
### 용어집 체크리스트
|
||||
|
||||
- [ ] 용어는 개별 헤더가 아니라 표에 있습니다
|
||||
- [ ] 범주 안에서 용어를 사전순으로 정렬합니다
|
||||
- [ ] 정의는 1-2문장입니다
|
||||
- [ ] 컨텍스트 표시는 이탤릭입니다
|
||||
- [ ] 셀 안의 용어명은 굵게 표시합니다
|
||||
- [ ] "이것은..." 또는 "이 용어는..." 형태의 정의를 사용하지 않습니다
|
||||
|
||||
## FAQ 섹션
|
||||
|
||||
```md
|
||||
## 질문
|
||||
|
||||
- [항상 아키텍처가 필요한가요?](#항상-아키텍처가-필요한가요)
|
||||
- [나중에 계획을 바꿀 수 있나요?](#나중에-계획을-바꿀-수-있나요)
|
||||
|
||||
### 항상 아키텍처가 필요한가요?
|
||||
|
||||
BMad Method와 엔터프라이즈 트랙에서만 필요합니다. 빠른 흐름은 구현으로 바로 넘어갑니다.
|
||||
|
||||
### 나중에 계획을 바꿀 수 있나요?
|
||||
|
||||
예. `bmad-correct-course` 워크플로가 구현 중 범위 변경을 처리합니다.
|
||||
|
||||
**여기에 답이 없는 질문이 있나요?** [이슈를 열거나](...) [Discord](...)에서 물어보세요.
|
||||
```
|
||||
|
||||
## 검증 명령
|
||||
|
||||
문서 변경을 제출하기 전에 다음을 실행하세요.
|
||||
|
||||
```bash
|
||||
npm run docs:fix-links # 링크 형식 수정 미리보기
|
||||
npm run docs:fix-links -- --write # 수정 적용
|
||||
npm run docs:validate-links # 링크 존재 여부 확인
|
||||
npm run docs:build # 빌드 오류 없음 확인
|
||||
```
|
||||
|
|
@ -0,0 +1,49 @@
|
|||
---
|
||||
title: "고급 도출"
|
||||
description: 구조화된 추론 방법으로 LLM이 자신의 작업을 다시 생각하게 합니다
|
||||
sidebar:
|
||||
order: 9
|
||||
---
|
||||
|
||||
LLM이 방금 생성한 결과를 다시 검토하게 만드세요. 추론 방법을 선택하면 LLM이 그 방법을 자신의 출력에 적용하고, 사용자는 개선 사항을 유지할지 결정합니다.
|
||||
|
||||
## 고급 도출이란?
|
||||
|
||||
구조화된 두 번째 검토 단계입니다. AI에게 막연히 "다시 해봐" 또는 "더 좋게 만들어"라고 말하는 대신, 특정 추론 방법을 선택하고 AI가 그 렌즈를 통해 자신의 출력을 다시 살핍니다.
|
||||
|
||||
이 차이는 중요합니다. 모호한 요청은 모호한 수정을 낳습니다. 이름 있는 방법은 특정한 검토 관점을 강제해 일반적인 재시도로는 놓칠 인사이트를 드러냅니다.
|
||||
|
||||
## 사용 시점
|
||||
|
||||
- 워크플로가 콘텐츠를 생성한 뒤 대안을 보고 싶을 때
|
||||
- 출력은 괜찮아 보이지만 더 깊이가 있을 것 같을 때
|
||||
- 가정을 스트레스 테스트하거나 약점을 찾고 싶을 때
|
||||
- 다시 생각하는 과정이 도움이 되는 중요도가 높은 콘텐츠일 때
|
||||
|
||||
워크플로는 결정 지점에서 고급 도출을 제안합니다. LLM이 무언가를 생성한 뒤 실행할지 묻습니다.
|
||||
|
||||
## 작동 방식
|
||||
|
||||
1. LLM이 콘텐츠에 관련 있는 방법 5개를 제안합니다
|
||||
2. 하나를 고릅니다(또는 다른 선택지를 보려고 다시 섞습니다)
|
||||
3. 방법이 적용되고 개선 사항이 표시됩니다
|
||||
4. 수락하거나 버리고, 반복하거나 계속합니다
|
||||
|
||||
## 내장 방법
|
||||
|
||||
수십 가지 추론 방법을 사용할 수 있습니다. 예시는 다음과 같습니다.
|
||||
|
||||
- **사전 실패 분석** - 프로젝트가 이미 실패했다고 가정하고 이유를 역추적합니다
|
||||
- **제1원칙 사고** - 가정을 걷어내고 근거 사실에서 다시 세웁니다
|
||||
- **역전 사고** - 실패를 보장하는 방법을 묻고, 그 일을 피합니다
|
||||
- **레드 팀 vs 블루 팀** - 자신의 작업을 공격한 뒤 방어합니다
|
||||
- **소크라테스식 질문** - 모든 주장에 "왜?"와 "어떻게 알아?"를 던집니다
|
||||
- **제약 제거** - 모든 제약을 제거해 무엇이 바뀌는지 보고, 선택적으로 다시 추가합니다
|
||||
- **이해관계자 매핑** - 각 이해관계자 관점에서 다시 평가합니다
|
||||
- **유추 추론** - 다른 도메인의 유사점을 찾아 그 교훈을 적용합니다
|
||||
|
||||
그 밖에도 훨씬 많습니다. AI는 콘텐츠에 가장 관련 있는 선택지를 고르고, 사용자는 실행할 방법을 선택합니다.
|
||||
|
||||
:::tip[시작점]
|
||||
사전 실패 분석은 어떤 사양이나 계획에도 좋은 첫 선택입니다. 표준 리뷰가 놓치는 공백을 꾸준히 찾아냅니다.
|
||||
:::
|
||||
|
|
@ -0,0 +1,59 @@
|
|||
---
|
||||
title: "적대적 리뷰"
|
||||
description: “괜찮아 보이네”라는 식의 대충 넘어가는 검토를 방지하는 논리적 추론 기법
|
||||
sidebar:
|
||||
order: 8
|
||||
---
|
||||
|
||||
문제를 반드시 찾게 만들어 더 깊은 분석을 강제합니다.
|
||||
|
||||
## 적대적 리뷰란?
|
||||
|
||||
리뷰어가 *반드시* 이슈를 찾아야 하는 리뷰 기법입니다. "좋아 보입니다"는 허용되지 않습니다. 리뷰어는 문제가 존재한다고 가정하고, 냉정한 태도로 그것을 찾아냅니다.
|
||||
|
||||
부정적이 되자는 뜻이 아닙니다. 제출물을 도장 찍듯 승인하는 대충 훑기가 아니라 실제 분석을 강제하기 위한 것입니다.
|
||||
|
||||
**핵심 규칙:** 이슈를 찾아야 합니다. 발견 항목이 0개면 중단하고 다시 분석하거나 이유를 설명합니다.
|
||||
|
||||
## 왜 효과적인가
|
||||
|
||||
일반 리뷰는 확증 편향에 취약합니다. 작업을 훑고, 눈에 띄는 것이 없으면 승인합니다. "문제를 찾아라"라는 요구는 이 패턴을 끊습니다.
|
||||
|
||||
- **철저함을 강제** - 충분히 열심히 살펴 이슈를 찾기 전까지 승인할 수 없습니다
|
||||
- **빠진 것을 잡아냄** - "여기에 없는 것은 무엇인가?"가 자연스러운 질문이 됩니다
|
||||
- **신호 품질 향상** - 발견 사항이 막연한 우려가 아니라 구체적이고 실행 가능해집니다
|
||||
- **정보 비대칭** - 원래 의사결정 과정을 보지 않은 새 컨텍스트에서 검토해 의도가 아니라 산출물을 평가합니다
|
||||
|
||||
## 사용 위치
|
||||
|
||||
적대적 리뷰는 코드 리뷰, 구현 준비 상태 점검, 사양 검증 등 BMad 워크플로 전반에 나타납니다. 어떤 때는 필수 단계이고, 어떤 때는 고급 도출이나 파티 모드처럼 선택 사항입니다. 검토가 필요한 산출물에 맞춰 패턴이 적응합니다.
|
||||
|
||||
## 사람의 필터링 필요
|
||||
|
||||
AI는 문제를 찾도록 *지시*받았으므로 문제를 찾습니다. 실제로는 존재하지 않을 때도 그렇습니다. 사소한 지적을 이슈처럼 포장하거나, 의도를 오해하거나, 아예 환각성 발견 사항을 낼 수 있습니다.
|
||||
|
||||
**무엇이 실제인지 사용자가 결정합니다.** 각 발견 사항을 검토하고 노이즈를 버리고 중요한 것을 고치세요.
|
||||
|
||||
## 예시
|
||||
|
||||
다음 대신:
|
||||
|
||||
> "인증 구현은 괜찮아 보입니다. 승인합니다."
|
||||
|
||||
적대적 리뷰는 다음처럼 나옵니다.
|
||||
|
||||
> 1. **HIGH** - `login.ts:47` - 실패한 로그인 시도에 속도 제한 없음
|
||||
> 2. **HIGH** - 세션 토큰이 localStorage에 저장됨(XSS 취약)
|
||||
> 3. **MEDIUM** - 비밀번호 검증이 클라이언트 측에서만 수행됨
|
||||
> 4. **MEDIUM** - 실패한 로그인 시도에 대한 감사 로깅 없음
|
||||
> 5. **LOW** - 매직 넘버 `3600`은 `SESSION_TIMEOUT_SECONDS`가 되어야 함
|
||||
|
||||
첫 번째 리뷰는 보안 취약점을 놓칠 수 있습니다. 두 번째는 네 가지를 잡았습니다.
|
||||
|
||||
## 반복과 수확 체감
|
||||
|
||||
발견 사항을 처리한 뒤 다시 실행하는 것도 고려하세요. 두 번째 실행은 대개 더 많은 것을 잡아냅니다. 세 번째도 항상 쓸모없지는 않습니다. 하지만 각 실행에는 시간이 들고, 언젠가는 사소한 지적과 거짓 발견 사항만 남는 수확 체감 구간에 들어갑니다.
|
||||
|
||||
:::tip[더 나은 리뷰]
|
||||
문제가 존재한다고 가정하세요. 잘못된 것뿐 아니라 빠진 것을 찾으세요.
|
||||
:::
|
||||
|
|
@ -0,0 +1,70 @@
|
|||
---
|
||||
title: "분석 단계: 아이디어에서 기반까지"
|
||||
description: 브레인스토밍, 리서치, 제품 개요, PRFAQ가 무엇이며 언제 쓰는지 설명합니다
|
||||
sidebar:
|
||||
order: 1
|
||||
---
|
||||
|
||||
분석 단계(단계 1)는 제품을 만들기로 확정하기 전에 명확하게 생각하도록 돕습니다. 이 단계의 모든 도구는 선택 사항이지만, 분석을 완전히 건너뛰면 PRD가 인사이트가 아니라 가정 위에 세워집니다.
|
||||
|
||||
## 왜 계획 전에 분석이 필요한가?
|
||||
|
||||
PRD는 "무엇을 만들고 왜 만드는가?"에 답합니다. 모호한 생각을 넣으면 모호한 PRD가 나오고, 이후 모든 문서가 그 모호함을 상속합니다. 약한 PRD 위에 세운 아키텍처는 잘못된 기술적 베팅을 합니다. 약한 아키텍처에서 나온 스토리는 엣지 케이스를 놓칩니다. 비용은 누적됩니다.
|
||||
|
||||
분석 도구는 PRD를 날카롭게 만들기 위해 존재합니다. 창의적 탐색, 시장 현실, 고객 명확성, 실행 가능성 등 서로 다른 각도에서 문제를 검토해 PM 에이전트와 마주 앉을 때 무엇을 누구를 위해 만드는지 알게 합니다.
|
||||
|
||||
## 도구들
|
||||
|
||||
### 브레인스토밍
|
||||
|
||||
**무엇인가요.** 검증된 아이디어 발상 기법을 사용하는 안내형 창의 세션입니다. AI는 아이디어를 대신 생성하지 않고, 구조화된 연습으로 사용자 안의 아이디어를 끌어내는 코치 역할을 합니다.
|
||||
|
||||
**왜 있나요.** 원석 같은 아이디어는 요구사항에 고정되기 전에 발전할 공간이 필요합니다. 브레인스토밍은 그 공간을 만듭니다. 문제 도메인은 있지만 명확한 해결책이 없거나, 확정하기 전에 여러 방향을 탐색하고 싶을 때 특히 유용합니다.
|
||||
|
||||
**언제 쓰나요.** 만들고 싶은 것에 대한 막연한 감은 있지만 개념이 아직 굳지 않았을 때 사용합니다. 또는 개념은 있지만 대안과 비교해 압박 테스트하고 싶을 때 사용합니다.
|
||||
|
||||
세션 작동 방식은 [브레인스토밍](./brainstorming.md)을 참고하세요.
|
||||
|
||||
### 리서치(시장, 도메인, 기술)
|
||||
|
||||
**무엇인가요.** 아이디어의 서로 다른 차원을 조사하는 세 가지 집중 연구 워크플로입니다. 시장 조사는 경쟁자, 트렌드, 사용자 반응을 봅니다. 도메인 조사는 주제 전문성과 용어를 쌓습니다. 기술 조사는 실현 가능성, 아키텍처 선택지, 구현 접근을 평가합니다.
|
||||
|
||||
**왜 있나요.** 가정 위에 만드는 것은 아무도 필요로 하지 않는 것을 만드는 가장 빠른 길입니다. 리서치는 개념을 현실에 연결합니다. 이미 어떤 경쟁자가 있는지, 사용자가 실제로 무엇에 어려움을 겪는지, 기술적으로 가능한지, 산업별 제약이 무엇인지 확인합니다.
|
||||
|
||||
**언제 쓰나요.** 낯선 도메인에 들어가거나, 경쟁자가 있을 것 같지만 아직 파악하지 않았거나, 검증하지 않은 기술 능력에 개념이 의존할 때 사용합니다. 하나만 실행해도, 둘을 조합해도, 세 가지를 모두 실행해도 됩니다. 각각 독립적으로 의미가 있습니다.
|
||||
|
||||
### 제품 개요
|
||||
|
||||
**무엇인가요.** 제품 개념의 1-2페이지 요약을 만드는 안내형 발견 세션입니다. AI는 협업형 비즈니스 분석가로서 비전, 대상 독자, 가치 제안, 범위를 표현하도록 돕습니다.
|
||||
|
||||
**왜 있나요.** 제품 개요는 계획으로 들어가는 가벼운 경로입니다. 전략적 비전을 구조화된 형식으로 포착해 PRD 작성에 직접 공급합니다. 이미 개념에 확신이 있을 때 가장 잘 맞습니다. 고객, 문제, 대략 만들고 싶은 것을 알고 있을 때 제품 개요가 그 생각을 정리하고 날카롭게 합니다.
|
||||
|
||||
**언제 쓰나요.** 개념이 비교적 명확하고 PRD를 만들기 전에 효율적으로 문서화하고 싶을 때 사용합니다. 방향에 확신이 있고 가정을 강하게 도전받을 필요가 없을 때 적합합니다.
|
||||
|
||||
### PRFAQ Working Backwards(워킹 백워드)
|
||||
|
||||
**무엇인가요.** Amazon의 워킹 백워드 방법론을 대화형 챌린지로 적용한 것입니다. 코드 한 줄이 존재하기 전에 완성된 제품을 발표하는 보도자료를 쓰고, 고객과 이해관계자가 물을 가장 어려운 질문에 답합니다. AI는 집요하지만 건설적인 제품 코치로 행동합니다.
|
||||
|
||||
**왜 있나요.** PRFAQ는 계획으로 들어가는 엄격한 경로입니다. 모든 주장을 방어하게 만들어 고객 우선의 명확성을 강제합니다. 설득력 있는 보도자료를 쓸 수 없다면 제품은 준비되지 않은 것입니다. 고객 FAQ 답변이 공백을 드러내면, 그 공백은 구현 중 훨씬 늦고 비싸게 발견했을 것입니다. 이 관문은 약한 생각을 가장 싸게 고칠 수 있는 초기에 드러냅니다.
|
||||
|
||||
**언제 쓰나요.** 리소스를 투입하기 전에 개념을 스트레스 테스트하고 싶을 때 사용합니다. 사용자가 실제로 관심을 가질지 확신이 없거나, 명확하고 방어 가능한 가치 제안을 말할 수 있는지 검증하고 싶을 때, 또는 워킹 백워드의 규율로 생각을 날카롭게 하고 싶을 때 적합합니다.
|
||||
|
||||
## 무엇을 사용해야 하나요?
|
||||
|
||||
| 상황 | 권장 도구 |
|
||||
| --- | --- |
|
||||
| "막연한 아이디어가 있는데 어디서 시작할지 모르겠어요" | 브레인스토밍 |
|
||||
| "결정하기 전에 시장을 이해해야 해요" | 리서치 |
|
||||
| "만들고 싶은 건 알아요. 문서화만 필요해요" | 제품 개요 |
|
||||
| "이 아이디어가 정말 만들 가치가 있는지 확인하고 싶어요" | PRFAQ |
|
||||
| "탐색하고, 검증하고, 문서화하고 싶어요" | 브레인스토밍 → 리서치 → PRFAQ 또는 제품 개요 |
|
||||
|
||||
제품 개요와 PRFAQ는 둘 다 PRD 입력을 만듭니다. 얼마나 강한 챌린지를 원하는지에 따라 고르세요. 제품 개요는 협업형 발견 과정이고, PRFAQ는 더 엄격한 검증 관문입니다. 둘 다 같은 목적지로 가지만 PRFAQ는 그 개념이 그 단계로 갈 준비가 되었는지 시험합니다.
|
||||
|
||||
:::tip[확실하지 않나요?]
|
||||
`bmad-help`를 실행하고 상황을 설명하세요. 이미 한 일과 달성하려는 것에 따라 적절한 시작점을 추천합니다.
|
||||
:::
|
||||
|
||||
## 분석 후에는 무엇이 일어나나요?
|
||||
|
||||
분석 출력은 단계 2(계획)로 직접 이어집니다. PRD 워크플로는 제품 개요, PRFAQ 문서, 리서치 발견 사항, 브레인스토밍 보고서를 입력으로 받아 사용자가 만든 모든 것을 구조화된 요구사항으로 종합합니다. 분석을 더 많이 할수록 PRD는 더 날카로워집니다.
|
||||
|
|
@ -0,0 +1,33 @@
|
|||
---
|
||||
title: "브레인스토밍"
|
||||
description: 60가지 이상의 검증된 아이디어 도출 기법을 활용한 참여형 창의 세션
|
||||
sidebar:
|
||||
order: 3
|
||||
---
|
||||
|
||||
안내에 따라 직접 탐색하며 창의력을 마음껏 펼쳐보세요.
|
||||
|
||||
## 브레인스토밍이란?
|
||||
|
||||
`bmad-brainstorming`을 실행하면 아이디어를 대신 만들어 주는 AI가 아니라, 당신 안의 아이디어를 끌어내는 창의 촉진자를 얻게 됩니다. AI는 코치와 가이드로 행동하며 검증된 기법을 사용해 최고의 생각이 떠오를 조건을 만듭니다.
|
||||
|
||||
**잘 맞는 경우:**
|
||||
|
||||
- 창의적 막힘 돌파
|
||||
- 제품 또는 기능 아이디어 생성
|
||||
- 새로운 각도에서 문제 탐색
|
||||
- 날것의 개념을 실행 계획으로 발전
|
||||
|
||||
## 작동 방식
|
||||
|
||||
1. **준비** - 주제, 목표, 제약 정의
|
||||
2. **접근 방식 선택** - 직접 기법을 고르거나, AI 추천을 받거나, 무작위로 진행하거나, 점진적 흐름을 따릅니다
|
||||
3. **진행** - 탐색 질문과 협업형 코칭으로 기법을 진행합니다
|
||||
4. **정리** - 아이디어를 주제로 묶고 우선순위를 정합니다
|
||||
5. **실행** - 핵심 아이디어에 다음 단계와 성공 지표를 연결합니다
|
||||
|
||||
모든 내용은 나중에 참고하거나 이해관계자와 공유할 수 있는 세션 문서에 기록됩니다.
|
||||
|
||||
:::note[당신의 아이디어]
|
||||
모든 아이디어는 당신에게서 나옵니다. 워크플로는 통찰이 생기는 조건을 만들 뿐입니다. 출처는 당신입니다.
|
||||
:::
|
||||
|
|
@ -0,0 +1,92 @@
|
|||
---
|
||||
title: "체크포인트 미리보기"
|
||||
description: 목적에서 세부 사항에 이르기까지의 변경 과정을 단계별로 안내하는, LLM을 활용한 인간 중심 검토
|
||||
sidebar:
|
||||
order: 5
|
||||
---
|
||||
|
||||
`bmad-checkpoint-preview`는 LLM이 보조하는 대화형 human-in-the-loop 리뷰 워크플로입니다. 코드 변경을 목적과 컨텍스트에서 세부 사항까지 안내해, 출시할지, 다시 작업할지, 더 파고들지에 대해 충분한 정보를 바탕으로 판단할 수 있게 합니다.
|
||||
|
||||

|
||||
|
||||
## 일반적인 흐름
|
||||
|
||||
`bmad-quick-dev`를 실행합니다. 의도를 명확히 하고, 사양을 만들고, 변경을 구현합니다. 완료되면 사양 파일에 리뷰 경로를 붙이고 에디터에서 엽니다. 사양을 보니 여러 모듈에 걸쳐 20개 파일이 변경되었습니다.
|
||||
|
||||
diff를 눈으로 훑을 수도 있습니다. 하지만 20개 파일쯤 되면 눈대중 리뷰가 흔들리기 시작합니다. 흐름을 놓치고, 떨어진 두 변경 사이의 연결을 놓치거나, 충분히 이해하지 못한 것을 승인할 수 있습니다. 그래서 "checkpoint"라고 말하면 LLM이 변경을 따라가게 해 줍니다.
|
||||
|
||||
자율 구현에서 인간 판단으로 돌아오는 이 전환이 주된 사용 사례입니다. 빠른 개발은 최소 감독으로 오래 실행됩니다. 체크포인트 미리보기는 사용자가 다시 운전대를 잡는 지점입니다.
|
||||
|
||||
## 왜 존재하나요?
|
||||
|
||||
코드 리뷰에는 두 실패 모드가 있습니다. 하나는 리뷰어가 diff를 훑고 눈에 띄는 것이 없어 승인하는 경우입니다. 다른 하나는 모든 파일을 꼼꼼히 읽지만 흐름을 잃는 경우입니다. 나무는 보지만 숲을 놓칩니다. 둘 다 같은 결과를 낳습니다. 중요한 것을 잡지 못한 리뷰입니다.
|
||||
|
||||
근본 문제는 순서입니다. 원시 diff는 파일 순서로 변경을 보여주지만, 이 순서는 이해가 쌓이는 순서와 거의 일치하지 않습니다. 왜 필요한지 알기 전에 도우미 함수를 보고, 어떤 기능을 지원하는지 알기 전에 스키마 변경을 봅니다. 리뷰어는 흩어진 단서에서 작성자의 의도를 재구성해야 하고, 그 재구성 과정에서 집중력이 무너집니다.
|
||||
|
||||
체크포인트 미리보기는 재구성 작업을 LLM에게 맡겨 이 문제를 해결합니다. diff, 사양(있다면), 주변 코드베이스를 읽고 `git diff`가 아니라 이해를 위해 설계된 순서로 변경을 제시합니다.
|
||||
|
||||
## 작동 방식
|
||||
|
||||
워크플로는 다섯 단계입니다. 각 단계는 이전 단계 위에 쌓이며 "이게 뭐지?"에서 "출시해도 되나?"로 점진적으로 이동합니다.
|
||||
|
||||
### 1. 방향 잡기
|
||||
|
||||
워크플로는 변경(PR, 커밋, 브랜치, 사양 파일, 현재 Git 상태)을 식별하고 한 줄 의도 요약과 영역 통계를 생성합니다. 변경 파일 수, 건드린 모듈, 논리 줄 수, 경계 넘나듦, 새 공개 인터페이스 등입니다.
|
||||
|
||||
이 단계는 "내가 보고 있는 게 맞나?"를 확인하는 순간입니다. 코드를 읽기 전에 리뷰어는 올바른 것을 보고 있는지 확인하고 범위 기대치를 맞춥니다.
|
||||
|
||||
### 2. 둘러보기
|
||||
|
||||
변경은 파일이 아니라 **관심사** 기준으로 구성됩니다. "입력 검증"이나 "API 계약" 같은 응집력 있는 설계 의도입니다. 각 관심사에는 왜 이 접근을 택했는지 짧은 설명과 리뷰어가 코드에서 따라갈 수 있는 클릭 가능한 `path:line` 지점이 붙습니다.
|
||||
|
||||
이 단계는 설계 판단입니다. 리뷰어는 코드가 정확한지가 아니라 시스템에 맞는 접근인지 평가합니다. 관심사는 하향식으로 배치됩니다. 가장 높은 수준의 의도가 먼저 나오고 보조 구현이 뒤따릅니다. 리뷰어는 아직 보지 않은 것에 대한 참조를 만나지 않습니다.
|
||||
|
||||
### 3. 상세 검토
|
||||
|
||||
리뷰어가 설계를 이해한 뒤 워크플로는 실수했을 때 영향 범위가 가장 큰 2-5개 지점을 드러냅니다. 이들은 `[auth]`, `[schema]`, `[billing]`, `[public API]`, `[security]` 같은 위험 범주로 태그되고, 틀렸을 때 얼마나 많이 깨지는지 기준으로 정렬됩니다.
|
||||
|
||||
이것은 버그 찾기가 아닙니다. 자동화 테스트와 CI가 정확성을 다룹니다. 상세 검토는 위험 인식을 활성화합니다. "틀렸을 때 비용이 가장 큰 곳은 여기입니다." 특정 영역을 더 깊게 보고 싶다면 "이 영역을 더 파고들어 줘"라고 말해 정확성에 초점을 맞춘 재리뷰를 요청할 수 있습니다.
|
||||
|
||||
사양이 적대적 리뷰 루프를 거쳤다면 그 발견 사항도 여기서 드러납니다. 고쳐진 버그가 아니라, 리뷰 루프가 리뷰어가 알아야 한다고 표시한 결정입니다.
|
||||
|
||||
### 4. 테스트
|
||||
|
||||
변경이 작동하는 것을 수동으로 관찰하는 방법 2-5개를 제안합니다. 자동화 테스트 명령이 아니라 어떤 테스트 모음도 주지 못하는 확신을 만드는 수동 관찰입니다. 시도할 UI 상호작용, 실행할 CLI 명령, 보낼 API 요청과 각 예상 결과가 포함됩니다.
|
||||
|
||||
사용자에게 보이는 동작이 없다면 그렇다고 말합니다. 가짜 확인 작업은 만들지 않습니다.
|
||||
|
||||
### 5. 마무리
|
||||
|
||||
리뷰어가 결정을 내립니다. 승인, 재작업, 계속 논의 중 하나입니다. PR을 승인한다면 워크플로가 `gh pr review --approve`를 도울 수 있습니다. 재작업한다면 문제가 접근 방식, 사양, 구현 중 어디에서 왔는지 진단하고 특정 코드 위치와 연결된 실행 가능한 피드백 초안을 돕습니다.
|
||||
|
||||
## 보고서가 아니라 대화입니다
|
||||
|
||||
워크플로는 각 단계를 최종 답이 아니라 출발점으로 제시합니다. 단계 사이 또는 단계 도중에도 LLM과 대화하고, 질문하고, 구성 방식에 이의를 제기하고, 다른 스킬을 불러 다른 관점을 얻을 수 있습니다.
|
||||
|
||||
- **"오류 처리를 고급 도출로 다시 검토해 줘"** - 특정 영역 분석을 다시 생각하고 다듬게 합니다
|
||||
- **"이 스키마 마이그레이션이 안전한지 파티 모드로 토론해 줘"** - 집중 토론에 여러 에이전트 관점을 불러옵니다
|
||||
- **"코드 리뷰 실행"** - 적대적 리뷰와 엣지 케이스 분석을 포함한 구조화된 에이전트 기반 발견 사항을 생성합니다
|
||||
|
||||
체크포인트 워크플로는 선형 경로에 가두지 않습니다. 구조가 필요할 때는 구조를 주고, 탐색하고 싶을 때는 여지를 남깁니다. 다섯 단계는 전체 그림을 보게 하기 위한 것이지만, 각 단계에서 얼마나 깊게 들어갈지와 어떤 도구를 가져올지는 전적으로 사용자에게 달려 있습니다.
|
||||
|
||||
## 리뷰 경로
|
||||
|
||||
둘러보기 단계는 **권장 리뷰 순서**가 있을 때 가장 잘 작동합니다. 이는 사양 작성자가 리뷰어를 변경으로 안내하기 위해 쓴 지점 목록입니다. 사양에 이 정보가 있으면 워크플로가 그대로 사용합니다.
|
||||
|
||||
작성자가 만든 경로가 없으면 워크플로가 diff와 코드베이스 컨텍스트에서 생성합니다. 생성된 경로는 작성자가 만든 경로보다 품질이 낮지만, 파일 순서로 변경을 읽는 것보다는 훨씬 낫습니다.
|
||||
|
||||
## 사용 시점
|
||||
|
||||
주요 시나리오는 `bmad-quick-dev`에서의 인계입니다. 구현이 끝났고, 리뷰 경로가 붙은 사양 파일이 에디터에 열려 있으며, 출시 여부를 결정해야 합니다. "checkpoint"라고 말하면 됩니다.
|
||||
|
||||
단독으로도 동작합니다.
|
||||
|
||||
- **PR 리뷰** - 특히 몇 개 파일을 넘거나 여러 영역에 걸친 변경이 있을 때
|
||||
- **변경 온보딩** - 직접 작성하지 않은 브랜치에서 무슨 일이 있었는지 이해해야 할 때
|
||||
- **스프린트 리뷰** - 스프린트 상태 파일에서 `review`로 표시된 스토리를 집어올 수 있습니다
|
||||
|
||||
"checkpoint" 또는 "이 변경을 따라가며 설명해 줘"라고 호출하세요. 어떤 터미널에서도 작동하지만 IDE(VS Code, Cursor 등) 안에서 더 편하게 사용할 수 있습니다. 워크플로가 모든 단계에서 `path:line` 참조를 생성하고, IDE 내장 터미널에서는 이들이 클릭 가능하므로 리뷰 경로를 따라 파일 사이를 이동할 수 있습니다.
|
||||
|
||||
## 아닌 것
|
||||
|
||||
체크포인트 미리보기는 자동화 리뷰의 대체물이 아닙니다. 린터, 타입 검사기, 테스트 모음을 실행하지 않습니다. 심각도 점수를 붙이거나 통과/실패 결정을 만들지 않습니다. 사람이 가장 중요한 곳에 판단을 적용하도록 돕는 읽기 가이드입니다.
|
||||
|
|
@ -0,0 +1,51 @@
|
|||
---
|
||||
title: "기존 프로젝트 FAQ"
|
||||
description: 기존 프로젝트에서 BMad Method를 사용할 때의 일반 질문
|
||||
sidebar:
|
||||
order: 13
|
||||
---
|
||||
|
||||
BMad Method(BMM)로 기존 프로젝트에서 작업할 때 자주 묻는 질문에 빠르게 답합니다.
|
||||
|
||||
## 질문
|
||||
|
||||
- [프로젝트 문서화를 먼저 실행해야 하나요?](#프로젝트-문서화를-먼저-실행해야-하나요)
|
||||
- [프로젝트 문서화 실행을 잊었다면 어떻게 하나요?](#프로젝트-문서화-실행을-잊었다면-어떻게-하나요)
|
||||
- [기존 프로젝트에 빠른 흐름을 사용할 수 있나요?](#기존-프로젝트에-빠른-흐름을-사용할-수-있나요)
|
||||
- [기존 코드가 모범 사례를 따르지 않으면 어떻게 하나요?](#기존-코드가-모범-사례를-따르지-않으면-어떻게-하나요)
|
||||
|
||||
### 프로젝트 문서화를 먼저 실행해야 하나요?
|
||||
|
||||
특히 다음 상황에서는 강력히 권장합니다.
|
||||
|
||||
- 기존 문서가 없습니다
|
||||
- 문서가 오래되었습니다
|
||||
- AI 에이전트가 기존 코드에 대한 컨텍스트가 필요합니다
|
||||
|
||||
`docs/index.md`를 포함한 포괄적이고 최신 문서가 있거나, 에이전트가 기존 시스템을 바탕으로 작업할 만큼 다른 도구나 기법으로 충분한 발견 과정을 제공할 예정이라면 건너뛸 수 있습니다.
|
||||
|
||||
### 프로젝트 문서화 실행을 잊었다면 어떻게 하나요?
|
||||
|
||||
걱정하지 마세요. 언제든 실행할 수 있습니다. 프로젝트 도중이나 나중에 실행해 문서를 최신 상태로 유지할 수도 있습니다.
|
||||
|
||||
### 기존 프로젝트에 빠른 흐름을 사용할 수 있나요?
|
||||
|
||||
네. 빠른 흐름은 기존 프로젝트에서 잘 작동합니다. 다음을 수행합니다.
|
||||
|
||||
- 기존 기술 스택 자동 감지
|
||||
- 기존 코드 패턴 분석
|
||||
- 관례 감지 및 확인 요청
|
||||
- 기존 코드를 존중하는, 맥락이 충분히 담긴 사양 생성
|
||||
|
||||
기존 코드베이스의 버그 수정과 작은 기능에 특히 잘 맞습니다.
|
||||
|
||||
### 기존 코드가 모범 사례를 따르지 않으면 어떻게 하나요?
|
||||
|
||||
빠른 흐름은 관례를 감지하고 묻습니다. "이 기존 관례를 따를까요?" 사용자가 결정합니다.
|
||||
|
||||
- **예** → 현재 코드베이스와의 일관성 유지
|
||||
- **아니요** → 새 표준 수립(사양에 이유를 문서화)
|
||||
|
||||
BMM은 선택을 존중합니다. 현대화를 강제하지 않지만 필요한 제안은 합니다.
|
||||
|
||||
**여기에 답이 없는 질문이 있나요?** [GitHub Issue](https://github.com/bmad-code-org/BMAD-METHOD/issues)를 열거나 [Discord](https://discord.gg/gk8jAdXWmj)에서 물어보세요. 추가하겠습니다.
|
||||
|
|
@ -0,0 +1,94 @@
|
|||
---
|
||||
title: "포렌식 조사"
|
||||
description: bmad-investigate가 모든 이슈를 현장처럼 다루고, 증거를 등급화하며, 엔지니어가 바로 행동할 수 있는 구조화된 사례 파일을 만드는 방법
|
||||
sidebar:
|
||||
order: 10
|
||||
---
|
||||
|
||||
`bmad-investigate`에 충돌 로그, 스택 추적, 또는 단순히 "예전엔 됐는데 지금은 안 돼요"를 건네면, 스킬은 실행되는 동안 조사자의 규율을 적용합니다. 바로 고치기 시작하지 않습니다. 사례 파일을 엽니다.
|
||||
|
||||
모든 발견 사항은 등급이 매겨집니다. 모든 가설은 상태를 가집니다. 잘못된 방향도 지우지 않고 남깁니다. 산출물은 다른 엔지니어가 아무 배경 없이 집어 들어도 이해할 수 있는 문서입니다.
|
||||
|
||||
이 페이지는 조사가 왜 별도의 규율인지, 그리고 일반 개발 워크플로가 주지 못하는 것을 이 스킬이 어떤 방식으로 제공하는지 설명합니다.
|
||||
|
||||
## "그냥 디버깅해"의 문제
|
||||
|
||||
일반 디버깅은 세 가지를 섞습니다. 증거를 보고, 원인을 추론하고, 이론을 시험하기 위해 코드를 바꿉니다. 이것들이 섞이면 두 가지 실패 모드가 나타납니다.
|
||||
|
||||
첫 번째는 **서사 고착**입니다. 처음 그럴듯한 이야기가 작업 가설이 되고, 모든 관찰이 거기에 맞춰 끼워집니다. 누군가 포기하고 처음부터 다시 시작할 때까지 버그는 고쳐지지 않습니다. 몇 시간 뒤에야 말입니다.
|
||||
|
||||
두 번째는 **증거 망각**입니다. 무언가를 추적하고 배제했지만 왜 배제했는지 적지 않았습니다. 이틀 뒤 새로운 눈으로 같은 것을 다시 추적합니다. 더 나쁘게는 동료가 버그를 넘겨받아 이미 제거한 막다른 경로를 다시 실행합니다.
|
||||
|
||||
이 스킬의 설계는 이 둘에 대한 직접적인 응답입니다.
|
||||
|
||||
## 증거 등급화
|
||||
|
||||
조사의 모든 발견 사항은 세 가지 중 하나입니다.
|
||||
|
||||
- **Confirmed(확인됨).** 로그, 코드, 덤프에서 직접 관찰되었고 특정 참조(`path:line`, 로그 타임스탬프, 커밋 해시)로 인용됩니다. 누군가 "어떻게 알아?"라고 물으면 인용을 가리킵니다.
|
||||
- **Deduced(추론됨).** 확인된 증거에서 논리적으로 따릅니다. 추론 사슬이 표시됩니다. 사슬의 한 단계가 틀리면 추론도 틀리고, 어느 단계인지 볼 수 있습니다.
|
||||
- **Hypothesized(가설).** 그럴듯하지만 확인되지 않았습니다. 무엇이 확인하거나 반박할지와 무엇이 닫을지를 미리 선언합니다. 가설은 명시적으로 *사실이 아닙니다*.
|
||||
|
||||
등급화는 겸손해 보이기 위한 것이 아닙니다. 사례 파일을 읽을 수 있게 만들기 위한 것입니다. 독자는 `Confirmed` 섹션에서 무엇이 사실인지, `Deduced` 섹션에서 무엇이 따라오는지, `Hypothesized` 섹션에서 무엇이 아직 열려 있는지 훑어볼 수 있습니다. 이 셋의 혼동이 조사가 빙빙 도는 가장 흔한 이유입니다.
|
||||
|
||||
## 기준점 먼저 확보하기
|
||||
|
||||
조사는 이론에서 시작하지 않습니다. 하나의 확인된 증거에서 시작해 바깥으로 확장합니다. 그 기준점은 특정 오류 메시지, 스택 프레임, 타임스탬프가 있는 로그 항목일 수 있습니다.
|
||||
|
||||
이는 흔한 조사 방식과 반대입니다. 누군가 직감을 갖고 이론을 세운 뒤 그것을 지지하는 증거를 찾습니다. 직감이 맞을 수도 있지만, 그 *방법*은 확증 편향을 기본값으로 만들기 때문에 취약합니다.
|
||||
|
||||
기준점은 추론이 흐려질 때 돌아갈 수 있는 사실입니다. 추론이 이상한 곳으로 가면 기준점까지 되돌아가 다른 갈래를 시도할 수 있습니다. 기준점이 없으면 어느 단계를 되돌려야 하는지 알 수 없습니다.
|
||||
|
||||
증거가 부족하면 스킬은 그렇게 말하고 가설 주도 탐색으로 전환합니다. 가능한 것에서 가설을 만들고, 각각을 시험할 증거를 식별하며, 우선순위가 있는 데이터 수집 목록을 제시합니다. 빠진 증거 자체도 발견 사항입니다.
|
||||
|
||||
## 가설 규율
|
||||
|
||||
가설은 사례 파일에서 절대 삭제되지 않습니다. 증거가 확인하거나 반박하면 **Status** 필드가 `Open`에서 `Confirmed` 또는 `Refuted`로 바뀌고, 어떤 증거가 결론을 냈는지 **Resolution**이 설명합니다.
|
||||
|
||||
이 규칙에는 비용이 있습니다. 사례 파일이 길어집니다. 하지만 이점도 큽니다. 전체 추론 이력이 산출물의 일부가 됩니다. 여섯 달 뒤 비슷한 버그가 나타나면 다음 조사자는 원래 사례 파일을 읽고 어떤 경로가 이미 제거되었고 왜 그런지 볼 수 있습니다. 그 이력이 없으면 새 조사자마다 같은 막다른 경로를 다시 실행합니다.
|
||||
|
||||
현재의 조사자에게도 규율을 부여합니다. 틀린 가설을 지울 수 없다면, 인용된 증거로 반박해야 합니다. 불편해졌다고 조용히 떨어뜨리는 선택지는 사라집니다.
|
||||
|
||||
## 전제에 도전하기
|
||||
|
||||
사용자의 문제 설명은 사실이 아니라 가설입니다. "캐시가 깨졌다"는 사용자가 *믿는 것*입니다. 스킬은 그 전제를 중심으로 조사를 세우기 전에 기술적 주장을 독립적으로 검증합니다. 증거가 전제와 모순되면 보고서가 직접 그렇게 말합니다.
|
||||
|
||||
이것이 포렌식 감각입니다. 목격자 진술은 데이터이지 진실이 아닙니다. 때로 보고된 버그는 진짜지만 이름표가 틀립니다. 때로 설명된 증상은 다른 원인의 파생 결과입니다. 전제를 절대적 진실로 받아들이는 조사는 잘못된 결함을 진단하고, 버그는 약간 다른 형태로 돌아옵니다.
|
||||
|
||||
## 보정된 진행
|
||||
|
||||
스킬은 두 가지 모드가 아니라 하나의 절차입니다. 입력이 요구하는 결함 추적과 영역 탐색의 비율을 계속 보정합니다.
|
||||
|
||||
증상 기반 사례(티켓, 충돌, 오류 메시지, "예전엔 됐다")는 가설 추적, 타임라인 재구성, 수정 방향에 기울어집니다. 증상 없는 사례(만지기 전 모듈 이해, 재사용성 평가, 정신 모델 구축)는 I/O 매핑, 제어 흐름 필터링, 검증 계획에 기울어집니다. 실제 사례 대부분은 그 사이 어딘가에 있고, 사례 파일은 증거가 요구한 균형을 반영합니다.
|
||||
|
||||
사례가 어디에 있든 원칙은 같습니다. 먼저 기준점 확보, 증거 등급화, 가설 추적, 절대 지우지 않기입니다. 출력은 항상 `{implementation_artifacts}/investigations/{slug}-investigation.md`이며, 해당 사례에 적용되지 않는 섹션은 비어 있거나 생략됩니다.
|
||||
|
||||
깊은 버그가 더 넓은 하위 시스템 이해를 요구할 때 절차는 I/O 매핑, 제어 흐름 필터링, 출력에서 역추적하기, 구성 요소 간 경계 추적 기법을 한 흐름 안에 통합합니다. 영역 모델은 같은 사례 파일에 들어갑니다. 모드 전환은 없습니다.
|
||||
|
||||
## 방법론은 스킬 안에 있습니다
|
||||
|
||||
조사자의 원칙은 스킬 자체의 속성입니다. `bmad-investigate`를 호출한 사람은 실행되는 동안 방법론과 커뮤니케이션 스타일을 채택합니다. 냉정한 정확성, 증거 우선 언어, 회피 없는 표현, 사례 파일 중심의 구성입니다. 스킬이 끝나면 호출자는 이전 말투로 돌아갑니다. 페르소나 교체가 아니라 스킬 원칙에서 오는 말투 전환입니다.
|
||||
|
||||
조사와 구현은 서로 다른 감각을 보상하기 때문에 중요합니다. 조사자는 느리고 정확합니다. 구현자는 빠르고 자신감 있습니다. 같은 세션에서 둘을 모두 하려 하면 둘 다 애매해지는 경향이 있습니다. 스킬은 별도 정체성으로 컨텍스트를 전환하지 않고, 진행 흐름 안에서 조사자의 태도를 적용합니다.
|
||||
|
||||
## 얻는 것
|
||||
|
||||
완성된 조사 파일:
|
||||
|
||||
- `Confirmed` 발견 사항(인용 포함)을 `Deductions` 및 `Hypotheses`와 분리합니다
|
||||
- 형성된 모든 가설을 최종 `Status`와 `Resolution`과 함께 보존합니다
|
||||
- 여러 증거 소스에서 이벤트 타임라인을 재구성합니다
|
||||
- 데이터 공백과 그것이 무엇을 해결할지 식별합니다
|
||||
- 증거에 기반한 실행 가능한 결론을 제공합니다
|
||||
- 근본 원인이 식별되면 재현 계획을 포함합니다
|
||||
- 아직 탐색할 경로의 조사 백로그를 유지합니다
|
||||
|
||||
그 자리에 없던 엔지니어에게 건네도 무슨 일이 있었고, 무엇을 알고 있으며, 무엇이 아직 불확실한지 이해해야 합니다. 기준은 그것입니다.
|
||||
|
||||
## 더 큰 아이디어
|
||||
|
||||
오늘날 대부분의 "AI 디버깅"은 증거, 추론, 코드 변경을 그럴듯한 텍스트의 한 흐름으로 섞습니다. 신호는 찾기 어렵고, 막다른 경로는 반복되며, 사례 파일이 있더라도 아무도 읽고 싶지 않은 채팅 로그처럼 보이는 경우가 많습니다.
|
||||
|
||||
`bmad-investigate`는 조사를 고유한 산출물이 있는 규율로 다룹니다. 증거에는 등급이 있습니다. 가설에는 상태가 있습니다. 잘못된 방향은 지워지지 않고 문서화됩니다. 사례 파일은 세션보다 오래 살아남습니다.
|
||||
|
||||
이미 본 적 있는 것처럼 보이는 다음 버그가 나타났을 때, 빈 프롬프트가 아니라 시작할 곳이 생깁니다.
|
||||
|
|
@ -0,0 +1,94 @@
|
|||
---
|
||||
title: "이름 있는 에이전트"
|
||||
description: BMad 에이전트가 이름, 페르소나, 커스터마이징 영역을 갖는 이유와 메뉴 기반 또는 프롬프트 기반 대안보다 무엇을 가능하게 하는지
|
||||
sidebar:
|
||||
order: 2
|
||||
---
|
||||
|
||||
"Mary, 브레인스토밍하자"라고 말하면 Mary가 활성화됩니다. 그녀는 설정한 언어로 당신의 이름을 부르고, 고유한 페르소나로 인사합니다. `bmad-help`가 언제나 가능하다고 알려줍니다. 그리고 의도가 명확했기 때문에 메뉴를 건너뛰고 바로 브레인스토밍으로 들어갑니다.
|
||||
|
||||
이 페이지는 실제로 무엇이 일어나고 있고 왜 BMad가 이렇게 설계되었는지 설명합니다.
|
||||
|
||||
## 세 축
|
||||
|
||||
BMad의 에이전트 모델은 서로 조합되는 세 가지 기본 요소 위에 놓여 있습니다.
|
||||
|
||||
| 기본 요소 | 제공하는 것 | 위치 |
|
||||
| --- | --- | --- |
|
||||
| **스킬** | 기능 - 어시스턴트가 할 수 있는 구체적인 일(브레인스토밍, PRD 초안 작성, 스토리 구현) | `.claude/skills/{skill-name}/SKILL.md` 또는 IDE별 동등 경로 |
|
||||
| **이름 있는 에이전트** | 페르소나의 연속성 - 일관된 목소리, 원칙, 시각적 단서로 관련 스킬 메뉴를 묶는 알아볼 수 있는 정체성 | 디렉터리가 `bmad-agent-*`로 시작하는 스킬 |
|
||||
| **커스터마이징** | 우리 방식으로 맞추기 - 에이전트 동작을 재구성하고, MCP 통합을 추가하고, 템플릿을 교체하고, 조직 관례를 겹쳐 적용하는 오버라이드 | `_bmad/custom/{skill-name}.toml`(팀 오버라이드) 및 `.user.toml`(개인, git에서 무시됨) |
|
||||
|
||||
세 요소 중 하나라도 빠지면 경험이 무너집니다.
|
||||
|
||||
- 에이전트 없는 스킬 → 사용자가 이름이나 코드로 탐색해야 하는 기능 목록
|
||||
- 스킬 없는 에이전트 → 할 일이 없는 페르소나
|
||||
- 커스터마이징 없음 → 모든 사용자가 같은 기본 제공 동작을 받고, 조직별 필요에는 포크를 강요받음
|
||||
|
||||
## 이름 있는 에이전트가 주는 것
|
||||
|
||||
BMad는 BMad Method의 단계에 맞춘 여섯 이름 있는 에이전트를 제공합니다.
|
||||
|
||||
| 에이전트 | 단계 | 모듈 |
|
||||
| --- | --- | --- |
|
||||
| 📊 **Mary**, 비즈니스 분석가 | 분석 | 시장 조사, 브레인스토밍, 제품 개요, PRFAQ |
|
||||
| 📚 **Paige**, 기술 작성자 | 분석 | 프로젝트 문서화, 다이어그램, 문서 검증 |
|
||||
| 📋 **John**, 제품 관리자 | 계획 | PRD 작성, 에픽/스토리 분해, 구현 준비 상태 점검 |
|
||||
| 🎨 **Sally**, UX 디자이너 | 계획 | UX 설계 사양 |
|
||||
| 🏗️ **Winston**, 시스템 아키텍트 | 솔루션 설계 | 기술 아키텍처, 정렬 점검 |
|
||||
| 💻 **Amelia**, 시니어 엔지니어 | 구현 | 스토리 실행, 빠른 개발, 코드 리뷰, 스프린트 계획 |
|
||||
|
||||
각 에이전트는 하드코딩된 정체성(이름, 역할명, 도메인)과 커스터마이즈 가능한 계층(역할, 원칙, 커뮤니케이션 스타일, 아이콘, 메뉴)을 가집니다. Mary의 원칙을 다시 쓰거나 메뉴 항목을 추가할 수는 있지만 이름을 바꿀 수는 없습니다. 이는 의도적입니다. 이름 인식은 커스터마이징 후에도 유지되므로, 팀이 Mary의 동작을 어떻게 조정했든 "Mary"는 항상 분석가를 활성화합니다.
|
||||
|
||||
## 활성화 흐름
|
||||
|
||||
이름 있는 에이전트를 호출하면 여덟 단계가 순서대로 실행됩니다.
|
||||
|
||||
1. **에이전트 블록 해석** - 제공된 `customize.toml`을 팀 및 개인 오버라이드와 병합합니다. Python 병합 스크립트가 표준 라이브러리 `tomllib`을 사용합니다
|
||||
2. **사전 단계 실행** - 팀이 설정한 사전 동작
|
||||
3. **페르소나 채택** - 하드코딩된 정체성과 커스터마이즈된 역할, 커뮤니케이션 스타일, 원칙
|
||||
4. **지속 사실 로드** - 조직 규칙, 컴플라이언스 메모, `file:` 접두사로 로드되는 파일(예: `file:{project-root}/docs/project-context.md`)
|
||||
5. **설정 로드** - 사용자 이름, 커뮤니케이션 언어, 출력 언어, 산출물 경로
|
||||
6. **인사** - 설정 언어로 개인화된 인사를 하고, 누가 말하는지 한눈에 보이도록 에이전트 이모지 접두사를 포함합니다
|
||||
7. **추가 단계 실행** - 팀이 설정한 인사 후 설정
|
||||
8. **바로 실행 또는 메뉴 표시** - 첫 메시지가 메뉴 항목에 매핑되면 바로 이동하고, 아니면 메뉴를 보여주고 입력을 기다립니다
|
||||
|
||||
8단계는 의도와 기능이 만나는 곳입니다. "Mary, 브레인스토밍하자"는 `bmad-brainstorming`이 Mary 메뉴의 `BP`와 명확히 맞으므로 메뉴 표시를 건너뜁니다. 모호하게 말하면 확인 절차가 아니라 한 번 짧게 묻습니다. 맞는 것이 없으면 일반 대화를 계속합니다.
|
||||
|
||||
## 왜 그냥 메뉴가 아닌가요?
|
||||
|
||||
메뉴는 사용자가 도구에 반쯤 맞춰야 합니다. 브레인스토밍이 PM 에이전트가 아니라 분석가 에이전트의 `BP` 코드 아래 있다는 것을 기억하고, 어떤 페르소나가 어떤 기능을 갖는지 알아야 합니다. 도구가 사용자에게 떠넘기는 인지 부담입니다.
|
||||
|
||||
이름 있는 에이전트는 이를 뒤집습니다. 자연스러운 말로 원하는 것을 누구에게 할지 말합니다. 에이전트는 자신이 누구이고 무엇을 하는지 압니다. 의도가 충분히 명확하면 그냥 진행합니다.
|
||||
|
||||
메뉴는 여전히 대체 경로로 있습니다. 탐색할 때는 보여주고, 필요 없을 때는 건너뜁니다.
|
||||
|
||||
## 왜 그냥 빈 프롬프트가 아닌가요?
|
||||
|
||||
빈 프롬프트는 사용자가 마법 단어를 안다고 가정합니다. "브레인스토밍을 도와줘"는 될 수 있지만 "내 SaaS 아이디어를 같이 발전시켜 보자"는 안 될 수 있고, 결과는 표현 방식에 의존합니다. 사용자가 프롬프트 엔지니어링을 책임지게 됩니다.
|
||||
|
||||
이름 있는 에이전트는 자유를 닫지 않고 구조를 더합니다. 페르소나는 일관되고, 기능은 발견 가능하며, `bmad-help`는 항상 한 명령 거리에 있습니다. 에이전트가 무엇을 할 수 있는지 추측할 필요도, 사용 설명서가 필요하지도 않습니다.
|
||||
|
||||
## 커스터마이징은 일급 기능입니다
|
||||
|
||||
커스터마이징 모델이 있어야 이 방식이 개별 개발자를 넘어 확장됩니다.
|
||||
|
||||
모든 에이전트는 합리적인 기본값이 담긴 `customize.toml`을 제공합니다. 팀은 `_bmad/custom/bmad-agent-{role}.toml`에 오버라이드를 커밋합니다. 개인은 `.user.toml`(git에서 무시됨)에 개인 선호를 겹쳐 적용할 수 있습니다. 병합 스크립트는 활성화 시점에 세 파일을 예측 가능한 구조 규칙으로 병합합니다.
|
||||
|
||||
대부분의 사용자는 이 파일을 직접 작성하지 않습니다. `bmad-customize` 스킬은 대상을 고르고, 에이전트와 워크플로 중 범위를 선택하고, 오버라이드를 작성하고, 병합을 검증하는 과정을 안내합니다. 그래서 TOML에 익숙한 사람만이 아니라 자신의 의도를 이해하는 누구나 커스터마이징 영역에 접근할 수 있습니다.
|
||||
|
||||
구체적 예: 팀이 Amelia에게 라이브러리 문서는 항상 Context7 MCP 도구를 사용하고 로컬 에픽 목록에 스토리가 없으면 Linear를 대체 경로로 사용하라고 하는 단일 파일을 커밋합니다. Amelia가 실행하는 모든 개발 워크플로(dev-story, quick-dev, create-story, code-review)가 소스 편집이나 워크플로별 중복 없이 이 동작을 상속합니다.
|
||||
|
||||
교차 관심사를 위한 두 번째 커스터마이징 영역도 있습니다. 중앙 `_bmad/config.toml`과 `_bmad/config.user.toml`(둘 다 설치 프로그램 소유, 각 모듈의 `module.yaml`에서 재구성됨), 그리고 오버라이드용 `_bmad/custom/config.toml`(팀, 커밋됨)과 `_bmad/custom/config.user.toml`(개인, git에서 무시됨)입니다. 여기에 **에이전트 명단**이 있습니다. `bmad-party-mode`, `bmad-retrospective`, `bmad-advanced-elicitation`처럼 명단을 사용하는 스킬이 누가 가능하고 어떻게 표현될지 알기 위해 읽는 가벼운 설명자입니다. 팀 오버라이드로 에이전트를 조직 전체에서 다시 표현하고, `.user.toml` 오버라이드로 가상 목소리(Kirk, Spock, 도메인 전문가 페르소나)를 개인 실험으로 추가할 수 있습니다. 스킬 폴더를 건드리지 않습니다. 스킬별 파일은 Mary가 활성화될 때 *어떻게 행동하는지*를 조정하고, 중앙 설정은 다른 스킬이 명단에서 Mary를 *어떻게 보는지*를 조정합니다.
|
||||
|
||||
전체 커스터마이징 영역과 작동 예시는 다음을 참고하세요.
|
||||
|
||||
- [BMad 커스터마이징 방법](../how-to/customize-bmad.md) - 무엇을 커스터마이즈할 수 있고 병합이 어떻게 동작하는지의 참조
|
||||
- [조직을 위해 BMad 확장하기](../how-to/expand-bmad-for-your-org.md) - 에이전트 전반 규칙, 워크플로 관례, 외부 게시, 템플릿 교체, 에이전트 명단 커스터마이징을 다루는 실전 레시피
|
||||
- `bmad-customize` 스킬 - 의도를 올바른 위치의 검증된 오버라이드 파일로 바꿔 주는 안내형 작성 도우미
|
||||
|
||||
## 더 큰 아이디어
|
||||
|
||||
오늘날 대부분의 AI 어시스턴트는 메뉴이거나 프롬프트입니다. 둘 다 인지 부하를 사용자에게 넘깁니다. 이름 있는 에이전트와 커스터마이즈 가능한 스킬은 이미 일을 아는 팀원과 대화하게 해 주고, 조직이 포크 없이 그 팀원을 조정하게 합니다.
|
||||
|
||||
다음에 "Mary, 브레인스토밍하자"라고 입력했을 때 그녀가 바로 진행한다면, 무엇이 일어나지 않았는지 보세요. 슬래시 명령도, 탐색해야 할 메뉴도, 그녀가 무엇을 할 수 있는지 어색하게 상기시키는 일도 없었습니다. 바로 그 부재가 설계의 핵심입니다.
|
||||
|
|
@ -0,0 +1,59 @@
|
|||
---
|
||||
title: "파티 모드"
|
||||
description: 다중 에이전트 협업 - 모든 AI 에이전트를 하나의 대화에 모읍니다
|
||||
sidebar:
|
||||
order: 11
|
||||
---
|
||||
|
||||
모든 AI 에이전트를 하나의 대화에 모으세요.
|
||||
|
||||
## 파티 모드란?
|
||||
|
||||
`bmad-party-mode`를 실행하면 PM, 아키텍트, 개발자, UX 디자이너 등 필요한 AI 팀 전체가 한 방에 모입니다. BMad Master가 조율하고 메시지마다 관련 에이전트를 선택합니다. 에이전트들은 각 페르소나에 맞게 답하고, 동의하거나 반대하며, 서로의 아이디어를 이어받아 발전시킵니다.
|
||||
|
||||
대화는 원하는 만큼 계속됩니다. 후속 질문을 묻고, 답에 반박하고, 토론 방향을 바꿀 수 있습니다. 끝날 때까지 에이전트들과 실제 주고받는 대화를 합니다.
|
||||
|
||||
**잘 맞는 경우:**
|
||||
|
||||
- 절충이 필요한 큰 결정
|
||||
- 브레인스토밍 세션
|
||||
- 문제가 생겼을 때의 사후 분석
|
||||
- 스프린트 회고와 계획
|
||||
|
||||
## 예시
|
||||
|
||||
### 나쁜 아키텍처 지적하기
|
||||
|
||||
**사용자:** "좋아요 팀, 지난 스프린트는 엉망이었어요. 인증 서비스가 세 번이나 내려갔습니다. 어디서 문제가 생겼나요?"
|
||||
|
||||
**아키텍트:** "설계 자체는 건전했습니다. 분산 인증과 적절한 대체 경로가 있었죠. 구현이 사양에서 벗어났다면..."
|
||||
|
||||
**개발자:** "저는 아키텍처 문서를 그대로 따랐습니다. 사양이 동시 세션 무효화 경쟁 조건을 다루지 않았어요."
|
||||
|
||||
**PM:** "두 분 모두 더 큰 이슈를 놓쳤습니다. PRD에서 세션 관리 요구사항을 검증하지 않았어요. 그걸 잡지 못한 건 제 책임입니다."
|
||||
|
||||
**TEA:** "통합 테스트에서 제가 잡았어야 했습니다. 테스트 시나리오가 동시 무효화를 다루지 않았어요."
|
||||
|
||||
### 창의적 브레인스토밍
|
||||
|
||||
**사용자:** "온보딩이 지루하지 않고 특별하게 느껴지게 하려면 어떻게 해야 할까요?"
|
||||
|
||||
**UX 디자이너:** "점진적 공개부터 시작하세요. 기능을 튜토리얼에서 한꺼번에 보여주지 말고, 사용자가 필요로 할 때 드러내는 겁니다."
|
||||
|
||||
**스토리텔러:** "온보딩이 하나의 이야기라면 어떨까요? 각 단계가 캐릭터의 여정을 드러내고, 사용자가 바로 그 주인공이 되는 겁니다."
|
||||
|
||||
**게임 디자이너:** "그 아이디어를 이어가 보죠. 첫 번째 '퀘스트'가 실제 사용자 문제를 해결하는 일이라면 어떨까요? 사용자는 가치 있는 일을 해내며 배웁니다."
|
||||
|
||||
### 기술 결정
|
||||
|
||||
**사용자:** "MVP에는 모놀리스가 좋을까요, 마이크로서비스가 좋을까요?"
|
||||
|
||||
**아키텍트:** "모놀리스로 시작하세요. 사용자 1,000명 규모에서는 마이크로서비스가 필요 없는 복잡성을 더합니다."
|
||||
|
||||
**PM:** "동의합니다. 이론적인 확장성보다 출시 속도가 더 중요합니다."
|
||||
|
||||
**개발자:** "명확한 모듈 경계를 둔 모놀리스가 좋겠습니다. 필요해지면 나중에 서비스를 분리할 수 있습니다."
|
||||
|
||||
:::tip[더 나은 결정]
|
||||
다양한 관점을 통해 더 나은 결정을 내립니다. 파티 모드에 오신 것을 환영합니다.
|
||||
:::
|
||||
|
|
@ -0,0 +1,121 @@
|
|||
---
|
||||
title: "에이전트 충돌 방지"
|
||||
description: 여러 에이전트가 시스템을 구현할 때 아키텍처가 충돌을 방지하는 방법
|
||||
sidebar:
|
||||
order: 7
|
||||
---
|
||||
|
||||
여러 AI 에이전트가 시스템의 서로 다른 부분을 구현하면 충돌하는 기술 결정을 내릴 수 있습니다. 아키텍처 문서화는 공유 표준을 세워 이를 방지합니다.
|
||||
|
||||
## 일반적인 충돌 유형
|
||||
|
||||
### API 스타일 충돌
|
||||
|
||||
아키텍처가 없으면:
|
||||
|
||||
- 에이전트 A는 REST와 `/users/{id}`를 사용합니다
|
||||
- 에이전트 B는 GraphQL 뮤테이션을 사용합니다
|
||||
- 결과: 일관되지 않은 API 패턴과 혼란스러운 API 사용 경험
|
||||
|
||||
아키텍처가 있으면:
|
||||
|
||||
- ADR이 명시합니다. "모든 클라이언트-서버 통신에는 GraphQL을 사용"
|
||||
- 모든 에이전트가 같은 패턴을 따릅니다
|
||||
|
||||
### 데이터베이스 설계 충돌
|
||||
|
||||
아키텍처가 없으면:
|
||||
|
||||
- 에이전트 A는 snake_case 컬럼명을 사용합니다
|
||||
- 에이전트 B는 camelCase 컬럼명을 사용합니다
|
||||
- 결과: 일관되지 않은 스키마와 혼란스러운 쿼리
|
||||
|
||||
아키텍처가 있으면:
|
||||
|
||||
- 표준 문서가 이름 규칙을 명시합니다
|
||||
- 모든 에이전트가 같은 패턴을 따릅니다
|
||||
|
||||
### 상태 관리 충돌
|
||||
|
||||
아키텍처가 없으면:
|
||||
|
||||
- 에이전트 A는 전역 상태에 Redux를 사용합니다
|
||||
- 에이전트 B는 React 컨텍스트를 사용합니다
|
||||
- 결과: 여러 상태 관리 방식과 복잡성
|
||||
|
||||
아키텍처가 있으면:
|
||||
|
||||
- ADR이 상태 관리 방식을 명시합니다
|
||||
- 모든 에이전트가 일관되게 구현합니다
|
||||
|
||||
## 아키텍처가 충돌을 방지하는 방법
|
||||
|
||||
### 1. ADR을 통한 명시적 결정
|
||||
|
||||
모든 중요한 기술 선택은 다음과 함께 문서화됩니다.
|
||||
|
||||
- 컨텍스트(왜 이 결정이 중요한가)
|
||||
- 고려한 대안(어떤 선택지가 있는가)
|
||||
- 결정(무엇을 선택했는가)
|
||||
- 근거(왜 선택했는가)
|
||||
- 결과(받아들인 절충)
|
||||
|
||||
### 2. FR/NFR별 지침
|
||||
|
||||
아키텍처는 각 기능 요구사항을 기술적 접근에 연결합니다.
|
||||
|
||||
- FR-001: 사용자 관리 → GraphQL 뮤테이션
|
||||
- FR-002: 모바일 앱 → 최적화된 쿼리
|
||||
|
||||
### 3. 표준과 관례
|
||||
|
||||
다음을 명시적으로 문서화합니다.
|
||||
|
||||
- 디렉터리 구조
|
||||
- 이름 규칙
|
||||
- 코드 구성
|
||||
- 테스트 패턴
|
||||
|
||||
## 공유 컨텍스트로서의 아키텍처
|
||||
|
||||
아키텍처를 구현 전 모든 에이전트가 읽는 공유 컨텍스트로 생각하세요.
|
||||
|
||||
```text
|
||||
PRD: "무엇을 만들 것인가"
|
||||
↓
|
||||
아키텍처: "어떻게 만들 것인가"
|
||||
↓
|
||||
에이전트 A가 아키텍처를 읽음 → 에픽 1 구현
|
||||
에이전트 B가 아키텍처를 읽음 → 에픽 2 구현
|
||||
에이전트 C가 아키텍처를 읽음 → 에픽 3 구현
|
||||
↓
|
||||
결과: 일관된 구현
|
||||
```
|
||||
|
||||
## 주요 ADR 주제
|
||||
|
||||
충돌을 방지하는 일반적인 결정:
|
||||
|
||||
| 주제 | 예시 결정 |
|
||||
| --- | --- |
|
||||
| API 스타일 | GraphQL vs REST vs gRPC |
|
||||
| 데이터베이스 | PostgreSQL vs MongoDB |
|
||||
| 인증 | JWT vs 세션 |
|
||||
| 상태 관리 | Redux vs 컨텍스트 vs Zustand |
|
||||
| 스타일링 | CSS Modules vs Tailwind vs Styled Components |
|
||||
| 테스트 | Jest + Playwright vs Vitest + Cypress |
|
||||
|
||||
## 피해야 할 안티패턴
|
||||
|
||||
:::caution[흔한 실수]
|
||||
- **암묵적 결정** - "API 스타일은 하면서 정하자"는 태도는 일관성 부족으로 이어집니다
|
||||
- **과도한 문서화** - 모든 사소한 선택을 문서화하면 분석 마비가 생깁니다
|
||||
- **오래된 아키텍처** - 한 번 쓰고 업데이트하지 않은 문서는 에이전트가 오래된 패턴을 따르게 합니다
|
||||
:::
|
||||
|
||||
:::tip[올바른 접근]
|
||||
- 에픽 경계를 넘는 결정을 문서화하세요
|
||||
- 충돌이 생기기 쉬운 영역에 집중하세요
|
||||
- 배운 것을 반영해 아키텍처를 업데이트하세요
|
||||
- 중요한 변경에는 `bmad-correct-course`를 사용하세요
|
||||
:::
|
||||
|
|
@ -0,0 +1,160 @@
|
|||
---
|
||||
title: "프로젝트 컨텍스트"
|
||||
description: project-context.md가 프로젝트 규칙과 선호도로 AI 에이전트를 안내하는 방법
|
||||
sidebar:
|
||||
order: 12
|
||||
---
|
||||
|
||||
`project-context.md` 파일은 AI 에이전트를 위한 프로젝트 구현 가이드입니다. 다른 개발 체계의 "헌장"처럼 모든 워크플로에서 일관된 코드 생성을 보장하는 규칙, 패턴, 선호 사항을 포착합니다.
|
||||
|
||||
## 하는 일
|
||||
|
||||
AI 에이전트는 구현 중 계속 결정을 내립니다. 어떤 패턴을 따를지, 코드를 어떻게 구조화할지, 어떤 관례를 사용할지 등입니다. 명확한 안내가 없으면 다음이 일어날 수 있습니다.
|
||||
|
||||
- 코드베이스와 맞지 않는 범용 모범 사례를 따릅니다
|
||||
- 스토리마다 일관되지 않은 결정을 내립니다
|
||||
- 프로젝트별 요구사항이나 제약을 놓칩니다
|
||||
|
||||
`project-context.md` 파일은 에이전트가 알아야 할 것을 간결하고 LLM에 최적화된 형식으로 문서화해 이 문제를 해결합니다.
|
||||
|
||||
## 작동 방식
|
||||
|
||||
모든 구현 워크플로는 `project-context.md`가 있으면 자동으로 로드합니다. 아키텍트 워크플로도 아키텍처를 설계할 때 기술 선호 사항을 존중하기 위해 이 파일을 로드합니다.
|
||||
|
||||
**이 워크플로들이 로드합니다:**
|
||||
|
||||
- `bmad-create-architecture` - 솔루션 설계 중 기술 선호 사항을 존중합니다
|
||||
- `bmad-create-story` - 프로젝트 패턴으로 스토리 작성을 안내합니다
|
||||
- `bmad-dev-story` - 구현 결정을 안내합니다
|
||||
- `bmad-code-review` - 프로젝트 표준과 비교해 검증합니다
|
||||
- `bmad-quick-dev` - 사양을 구현할 때 패턴을 적용합니다
|
||||
- `bmad-sprint-planning`, `bmad-retrospective`, `bmad-correct-course` - 프로젝트 전반의 컨텍스트를 제공합니다
|
||||
|
||||
## 언제 만들까요?
|
||||
|
||||
`project-context.md` 파일은 프로젝트 어느 단계에서든 유용합니다.
|
||||
|
||||
| 시나리오 | 만들 시점 | 목적 |
|
||||
| --- | --- | --- |
|
||||
| **새 프로젝트, 아키텍처 전** | `bmad-create-architecture` 전에 수동 작성 | 아키텍트가 기술 선호 사항을 존중하도록 문서화 |
|
||||
| **새 프로젝트, 아키텍처 후** | `bmad-generate-project-context` 또는 수동 작성 | 구현 에이전트를 위해 아키텍처 결정 포착 |
|
||||
| **기존 프로젝트** | `bmad-generate-project-context`로 생성 | 기존 패턴을 발견해 에이전트가 기존 관례를 따르게 함 |
|
||||
| **빠른 흐름 프로젝트** | `bmad-quick-dev` 전 또는 중 | 빠른 구현이 패턴을 존중하도록 보장 |
|
||||
|
||||
:::tip[권장]
|
||||
새 프로젝트에서 강한 기술 선호 사항이 있다면 아키텍처 전에 수동으로 만드세요. 그렇지 않다면 아키텍처 후 생성해 그 결정을 포착하세요.
|
||||
:::
|
||||
|
||||
## 무엇이 들어가나요?
|
||||
|
||||
파일에는 두 주요 섹션이 있습니다.
|
||||
|
||||
### 기술 스택과 버전
|
||||
|
||||
프로젝트가 사용하는 프레임워크, 언어, 도구를 구체적 버전과 함께 문서화합니다.
|
||||
|
||||
```markdown
|
||||
## 기술 스택과 버전
|
||||
|
||||
- Node.js 20.x, TypeScript 5.3, React 18.2
|
||||
- 상태 관리: Zustand(Redux 아님)
|
||||
- 테스트: Vitest, Playwright, MSW
|
||||
- 스타일링: 커스텀 디자인 토큰을 사용하는 Tailwind CSS
|
||||
```
|
||||
|
||||
### 중요한 구현 규칙
|
||||
|
||||
에이전트가 놓칠 수 있는 패턴과 관례를 문서화합니다.
|
||||
|
||||
```markdown
|
||||
## 중요한 구현 규칙
|
||||
|
||||
**TypeScript 설정:**
|
||||
- 엄격 모드 사용 - 명시적 승인 없이 `any` 타입 금지
|
||||
- 공개 API에는 `interface`, 유니언/인터섹션에는 `type` 사용
|
||||
|
||||
**코드 구성:**
|
||||
- 컴포넌트는 `/src/components/`에 두고 `.test.tsx`를 함께 배치
|
||||
- 재사용 가능한 순수 함수는 `/src/lib/` 유틸리티에 배치
|
||||
- API 호출은 `apiClient` 싱글턴 사용 - 직접 fetch 금지
|
||||
|
||||
**테스트 패턴:**
|
||||
- 단위 테스트는 구현 세부사항이 아니라 비즈니스 로직에 집중
|
||||
- 통합 테스트는 MSW로 API 응답을 모킹
|
||||
- E2E 테스트는 중요한 사용자 여정만 다룸
|
||||
|
||||
**프레임워크별 규칙:**
|
||||
- 모든 비동기 작업은 일관된 오류 처리를 위해 `handleError` 래퍼 사용
|
||||
- 기능 플래그는 `@/lib/flags`의 `featureFlag()`로 접근
|
||||
- 새 라우트는 `/src/app/`의 파일 기반 라우팅 패턴을 따름
|
||||
```
|
||||
|
||||
코드 스니펫을 읽고 에이전트가 추론하지 못할 **겉으로 잘 드러나지 않는 것**에 집중하세요. 보편적으로 적용되는 표준 관행은 문서화하지 마세요.
|
||||
|
||||
## 파일 만들기
|
||||
|
||||
세 가지 선택지가 있습니다.
|
||||
|
||||
### 수동 작성
|
||||
|
||||
`_bmad-output/project-context.md`에 파일을 만들고 규칙을 추가합니다.
|
||||
|
||||
```bash
|
||||
# 프로젝트 루트에서
|
||||
mkdir -p _bmad-output
|
||||
touch _bmad-output/project-context.md
|
||||
```
|
||||
|
||||
기술 스택과 구현 규칙을 편집하세요. 아키텍트와 구현 워크플로가 자동으로 찾아 로드합니다.
|
||||
|
||||
### 아키텍처 후 생성
|
||||
|
||||
아키텍처를 완료한 뒤 `bmad-generate-project-context` 워크플로를 실행합니다.
|
||||
|
||||
```bash
|
||||
bmad-generate-project-context
|
||||
```
|
||||
|
||||
이 워크플로는 아키텍처 문서와 프로젝트 파일을 스캔해 내려진 결정을 담은 컨텍스트 파일을 생성합니다.
|
||||
|
||||
### 기존 프로젝트용 생성
|
||||
|
||||
기존 프로젝트에서는 `bmad-generate-project-context`를 실행해 기존 패턴을 발견합니다.
|
||||
|
||||
```bash
|
||||
bmad-generate-project-context
|
||||
```
|
||||
|
||||
워크플로가 코드베이스를 분석해 관례를 식별한 뒤 검토하고 다듬을 수 있는 컨텍스트 파일을 생성합니다.
|
||||
|
||||
## 왜 중요한가
|
||||
|
||||
`project-context.md`가 없으면 에이전트는 프로젝트에 맞지 않는 가정을 할 수 있습니다.
|
||||
|
||||
| 컨텍스트 없음 | 컨텍스트 있음 |
|
||||
| --- | --- |
|
||||
| 일반 패턴 사용 | 기존 관례 따름 |
|
||||
| 스토리마다 일관되지 않은 스타일 | 일관된 구현 |
|
||||
| 프로젝트별 제약을 놓칠 수 있음 | 모든 기술 요구사항 존중 |
|
||||
| 각 에이전트가 독립적으로 결정 | 모든 에이전트가 같은 규칙에 맞춰 동작 |
|
||||
|
||||
특히 다음에 중요합니다.
|
||||
|
||||
- **빠른 흐름** - PRD와 아키텍처를 건너뛰므로 컨텍스트 파일이 공백을 채웁니다
|
||||
- **팀 프로젝트** - 모든 에이전트가 같은 표준을 따르게 합니다
|
||||
- **기존 프로젝트** - 기존 패턴을 깨뜨리지 않게 합니다
|
||||
|
||||
## 편집과 업데이트
|
||||
|
||||
`project-context.md` 파일은 살아 있는 문서입니다. 다음 때 업데이트하세요.
|
||||
|
||||
- 아키텍처 결정이 바뀝니다
|
||||
- 새 관례가 확립됩니다
|
||||
- 구현 중 패턴이 진화합니다
|
||||
- 에이전트 동작에서 공백을 발견합니다
|
||||
|
||||
언제든 수동으로 편집하거나, 큰 변경 후 `bmad-generate-project-context`를 다시 실행해 업데이트할 수 있습니다.
|
||||
|
||||
:::note[파일 위치]
|
||||
기본 위치는 `_bmad-output/project-context.md`입니다. 워크플로는 그곳을 검색하고, 프로젝트 어디에 있든 `**/project-context.md`도 확인합니다.
|
||||
:::
|
||||
|
|
@ -0,0 +1,73 @@
|
|||
---
|
||||
title: "빠른 개발"
|
||||
description: 출력 품질을 보호하는 체크포인트를 포기하지 않고 사람이 개입하는 검토의 마찰을 줄입니다
|
||||
sidebar:
|
||||
order: 4
|
||||
---
|
||||
|
||||
의도를 넣으면 코드 변경이 나오고, 사람이 개입하는 검토 단계는 가능한 한 적게 사용합니다. 품질은 희생하지 않습니다.
|
||||
|
||||
모델이 체크포인트 사이에서 더 오래 실행되게 한 뒤, 작업이 인간 판단 없이 안전하게 계속될 수 없거나 최종 결과를 리뷰할 때만 사람을 다시 불러옵니다.
|
||||
|
||||

|
||||
|
||||
## 왜 존재하나요?
|
||||
|
||||
사람이 개입하는 검토 단계는 필요하지만 비용이 큽니다.
|
||||
|
||||
현재 LLM은 여전히 예측 가능한 방식으로 실패합니다. 의도를 잘못 읽고, 공백을 자신 있게 추측으로 채우고, 관련 없는 작업으로 흐름이 새며, 잡음 많은 리뷰 출력을 만듭니다. 동시에 지속적인 인간 개입은 개발 속도를 제한합니다. 사람의 주의력이 병목이 됩니다.
|
||||
|
||||
`bmad-quick-dev`는 이 절충점을 다시 조정합니다. 워크플로가 안전을 위한 충분히 강한 경계를 만든 뒤에는 모델이 더 긴 구간을 감독 없이 실행하도록 신뢰합니다.
|
||||
|
||||
## 핵심 설계
|
||||
|
||||
### 1. 먼저 의도를 압축합니다
|
||||
|
||||
워크플로는 사람과 모델이 요청을 하나의 일관된 목표로 압축하는 것에서 시작합니다. 입력은 거친 의도 표현일 수 있지만, 워크플로가 자율적으로 실행되기 전에는 실행 가능한 만큼 작고, 명확하고, 모순이 없어야 합니다.
|
||||
|
||||
의도는 다양한 형태로 올 수 있습니다. 몇 문구, 버그 추적기 링크, 계획 모드 출력, 채팅 세션에서 복사한 텍스트, 또는 BMAD의 `epics.md`에 있는 스토리 번호일 수 있습니다. 마지막 경우 워크플로는 BMAD 스토리 추적 규칙을 이해하지는 않지만, 스토리 자체를 가져와 실행할 수 있습니다.
|
||||
|
||||
이 워크플로는 인간 통제를 없애지 않습니다. 통제를 소수의 가치가 큰 순간으로 옮깁니다.
|
||||
|
||||
- **의도 명확화** - 정돈되지 않은 요청을 숨은 모순 없는 하나의 일관된 목표로 바꿉니다
|
||||
- **사양 승인** - 고정된 이해가 만들 올바른 것인지 확인합니다
|
||||
- **최종 결과 검토** - 최종 결과를 받아들일 수 있는지 사람이 결정하는 핵심 체크포인트입니다
|
||||
|
||||
### 2. 가장 작은 안전한 경로를 선택합니다
|
||||
|
||||
목표가 명확해지면 워크플로는 정말 한 번에 처리 가능한 변경인지, 더 완전한 경로가 필요한지 결정합니다. 작고 영향 범위가 거의 없는 변경은 바로 구현으로 갈 수 있습니다. 그 밖의 모든 것은 모델이 더 오래 혼자 실행되기 전에 더 강한 경계를 갖도록 계획을 거칩니다.
|
||||
|
||||
### 3. 더 적은 감독으로 더 오래 실행합니다
|
||||
|
||||
경로 결정 이후 모델은 더 많은 작업을 스스로 수행할 수 있습니다. 더 완전한 경로에서는 승인된 사양이 모델이 적은 감독으로 실행하는 경계가 되며, 이것이 설계의 핵심입니다.
|
||||
|
||||
### 4. 올바른 계층에서 실패를 진단합니다
|
||||
|
||||
의도가 틀려 구현이 틀렸다면 코드 패치는 잘못된 수정입니다. 사양이 약해서 코드가 틀렸다면 diff 패치도 잘못된 수정입니다. 워크플로는 실패가 시스템에 들어온 계층을 진단하고, 그 계층으로 돌아가 다시 생성하도록 설계되었습니다.
|
||||
|
||||
리뷰 발견 사항은 문제가 의도, 사양 생성, 로컬 구현 중 어디에서 왔는지 결정하는 데 쓰입니다. 정말 로컬 문제만 로컬 패치를 받습니다.
|
||||
|
||||
### 5. 필요할 때만 사람을 다시 부릅니다
|
||||
|
||||
의도 인터뷰는 사람이 개입하는 과정이지만 반복 체크포인트와는 다른 중단입니다. 워크플로는 반복 체크포인트를 최소화하려 합니다. 초기 구체화 이후 사람은 워크플로가 판단 없이 안전하게 계속할 수 없을 때와 마지막 리뷰 시점에 주로 돌아옵니다.
|
||||
|
||||
- **의도 공백 해소** - 리뷰가 워크플로가 의도를 안전하게 추론할 수 없었음을 보여줄 때 다시 들어옵니다
|
||||
|
||||
나머지는 더 긴 자율 실행 후보입니다. 이 절충은 의도적입니다. 오래된 패턴은 지속적인 감독에 더 많은 사람의 주의력을 씁니다. 빠른 개발은 모델에 더 많은 신뢰를 주지만, 사람의 판단이 가장 큰 효과를 내는 순간을 위해 주의력을 아낍니다.
|
||||
|
||||
## 리뷰 시스템이 중요한 이유
|
||||
|
||||
리뷰 단계는 버그를 찾기 위해서만 있는 것이 아닙니다. 추진력을 잃지 않고 수정을 올바른 경로로 보내기 위해 있습니다.
|
||||
|
||||
이 워크플로는 하위 에이전트를 생성할 수 있거나, 적어도 명령줄로 다른 LLM을 호출하고 결과를 기다릴 수 있는 플랫폼에서 가장 잘 동작합니다. 플랫폼이 기본으로 지원하지 않는다면 이를 수행하는 스킬을 추가할 수 있습니다. 컨텍스트 없는 하위 에이전트는 리뷰 설계의 핵심입니다.
|
||||
|
||||
에이전트 기반 리뷰는 보통 두 방식으로 잘못됩니다.
|
||||
|
||||
- 발견 사항이 너무 많아 사람이 노이즈를 걸러야 합니다.
|
||||
- 관련 없는 이슈를 끌어들여 현재 변경의 흐름을 깨고, 모든 실행을 즉석 정리 작업으로 바꿉니다.
|
||||
|
||||
빠른 개발은 리뷰를 분류 작업으로 다뤄 둘 다 해결합니다.
|
||||
|
||||
어떤 발견 사항은 현재 변경에 속합니다. 어떤 발견 사항은 그렇지 않습니다. 발견 사항이 현재 작업과 인과적으로 연결되지 않은 부수적 이슈라면, 워크플로는 즉시 처리하도록 강제하지 않고 미룰 수 있습니다. 이렇게 하면 실행이 집중되고 무작위 곁가지가 주의력 예산을 소비하지 않습니다.
|
||||
|
||||
분류는 때때로 완벽하지 않습니다. 괜찮습니다. 수천 개의 낮은 가치 리뷰 댓글로 사람을 압도하는 것보다 일부 발견 사항을 잘못 판단하는 편이 보통 낫습니다. 이 시스템은 모든 이슈를 빠짐없이 회수하는 것보다 신호 품질을 최적화합니다.
|
||||
|
|
@ -0,0 +1,77 @@
|
|||
---
|
||||
title: "솔루션 설계가 중요한 이유"
|
||||
description: 다중 에픽 프로젝트에서 솔루션 설계 단계가 중요한 이유
|
||||
sidebar:
|
||||
order: 6
|
||||
---
|
||||
|
||||
단계 3(솔루션 설계)은 계획 단계의 **무엇을** 만들지를 **어떻게** 만들지로 바꿉니다. 구현이 시작되기 전에 아키텍처 결정을 문서화해 다중 에픽 프로젝트에서 에이전트 충돌을 방지합니다.
|
||||
|
||||
## 솔루션 설계가 없을 때의 문제
|
||||
|
||||
```text
|
||||
에이전트 1은 에픽 1을 REST API로 구현
|
||||
에이전트 2는 에픽 2를 GraphQL로 구현
|
||||
결과: 일관되지 않은 API 설계와 통합 난이도 증가
|
||||
```
|
||||
|
||||
여러 에이전트가 공유 아키텍처 지침 없이 시스템의 서로 다른 부분을 구현하면 서로 충돌하는 독립적 기술 결정을 내릴 수 있습니다.
|
||||
|
||||
## 솔루션 설계가 있을 때의 해결책
|
||||
|
||||
```text
|
||||
아키텍처 워크플로가 결정: "모든 API에 GraphQL 사용"
|
||||
모든 에이전트가 아키텍처 결정을 따름
|
||||
결과: 일관된 구현, 충돌 없음
|
||||
```
|
||||
|
||||
기술 결정을 명시적으로 문서화하면 모든 에이전트가 일관되게 구현하고 통합이 단순해집니다.
|
||||
|
||||
## 솔루션 설계 vs 계획
|
||||
|
||||
| 측면 | 계획 (단계 2) | 솔루션 설계 (단계 3) |
|
||||
| --- | --- | --- |
|
||||
| 질문 | 무엇을, 왜? | 어떻게? 그리고 어떤 작업 단위로? |
|
||||
| 출력 | FRs/NFRs(요구사항) | 아키텍처 + 에픽/스토리 |
|
||||
| 에이전트 | PM | 아키텍트 → PM |
|
||||
| 대상 | 이해관계자 | 개발자 |
|
||||
| 문서 | PRD(기능/비기능 요구사항) | 아키텍처 + 에픽 파일 |
|
||||
| 수준 | 비즈니스 로직 | 기술 설계 + 작업 분해 |
|
||||
|
||||
## 핵심 원칙
|
||||
|
||||
**기술 결정을 명시적으로 문서화**해 모든 에이전트가 일관되게 구현하도록 합니다.
|
||||
|
||||
이것은 다음을 방지합니다.
|
||||
|
||||
- API 스타일 충돌(REST vs GraphQL)
|
||||
- 데이터베이스 설계 불일치
|
||||
- 상태 관리 방식 차이
|
||||
- 이름 규칙 불일치
|
||||
- 보안 접근 방식 차이
|
||||
|
||||
## 솔루션 설계가 필요한 때
|
||||
|
||||
| 트랙 | 솔루션 설계 필요 여부 |
|
||||
| --- | --- |
|
||||
| 빠른 흐름 | 아니요 - 완전히 건너뜁니다 |
|
||||
| BMad Method 단순 | 선택 사항 |
|
||||
| BMad Method 복잡 | 예 |
|
||||
| 엔터프라이즈 | 예 |
|
||||
|
||||
:::tip[경험칙]
|
||||
서로 다른 에이전트가 구현할 수 있는 여러 에픽이 있다면 솔루션 설계가 필요합니다.
|
||||
:::
|
||||
|
||||
## 건너뛸 때의 비용
|
||||
|
||||
복잡한 프로젝트에서 솔루션 설계를 건너뛰면 다음으로 이어집니다.
|
||||
|
||||
- 스프린트 중 발견되는 **통합 이슈**
|
||||
- 충돌하는 구현으로 인한 **재작업**
|
||||
- 전체적으로 **더 긴 개발 시간**
|
||||
- 일관되지 않은 패턴에서 생기는 **기술 부채**
|
||||
|
||||
:::caution[비용 배율]
|
||||
방향이 어긋나는 문제를 솔루션 설계에서 잡는 것이 구현 중 발견하는 것보다 10배 빠릅니다.
|
||||
:::
|
||||
|
|
@ -0,0 +1,387 @@
|
|||
---
|
||||
title: 'BMad 커스터마이징 방법'
|
||||
description: 업데이트 호환성을 유지하면서 에이전트와 워크플로를 커스터마이징합니다
|
||||
sidebar:
|
||||
order: 8
|
||||
---
|
||||
|
||||
설치된 파일을 수정하지 않고 에이전트 페르소나를 조정하고, 도메인 컨텍스트를 주입하고, 기능을 추가하고, 워크플로 동작을 설정하세요. 커스터마이징은 업데이트 후에도 유지됩니다.
|
||||
|
||||
:::tip[TOML을 직접 쓰고 싶지 않나요? `bmad-customize`를 사용하세요]
|
||||
`bmad-customize` 스킬은 이 문서에서 설명하는 **스킬별 에이전트/워크플로 오버라이드 영역**을 안내형으로 작성해 주는 도우미입니다. 설치된 항목 중 무엇을 커스터마이즈할 수 있는지 스캔하고, 의도에 맞는 영역(에이전트 또는 워크플로)을 고르게 하고, 오버라이드 파일을 작성하고, 병합이 적용되었는지 검증합니다. 중앙 설정 오버라이드(`_bmad/custom/config.toml`)는 v1 범위 밖이므로 아래 중앙 설정 섹션에 따라 직접 작성해야 합니다.
|
||||
:::
|
||||
|
||||
## 사용 시점
|
||||
|
||||
- 에이전트의 성격이나 커뮤니케이션 스타일을 바꾸고 싶습니다
|
||||
- 에이전트가 계속 기억할 사실이 필요합니다(예: "우리 조직은 AWS만 사용")
|
||||
- 매 세션 시작 시 에이전트가 반드시 수행해야 하는 절차적 단계를 추가하고 싶습니다
|
||||
- 자체 스킬이나 프롬프트를 실행하는 커스텀 메뉴 항목을 추가하고 싶습니다
|
||||
- 팀 공통 커스터마이징은 git에 커밋하고, 개인 선호는 그 위에 덧씌우고 싶습니다
|
||||
|
||||
:::note[필수 조건]
|
||||
|
||||
- 프로젝트에 BMad 설치([BMad 설치 방법](./install-bmad.md) 참고)
|
||||
- PATH의 Python 3.11+(병합 스크립트용, stdlib `tomllib`만 사용하며 `pip install`, `uv`, virtualenv 불필요)
|
||||
- TOML 파일을 편집할 텍스트 에디터
|
||||
:::
|
||||
|
||||
## 작동 방식
|
||||
|
||||
커스터마이즈 가능한 모든 스킬은 기본값이 들어 있는 `customize.toml` 파일을 제공합니다. 이 파일은 스킬의 전체 커스터마이징 영역을 정의합니다. 무엇을 바꿀 수 있는지 보려면 이 파일을 읽으세요. 이 파일은 직접 편집하지 않습니다. 대신 바꾸려는 필드만 담은 오버라이드 파일을 만듭니다.
|
||||
|
||||
### 3계층 오버라이드 모델
|
||||
|
||||
```text
|
||||
우선순위 1(승리): _bmad/custom/{skill-name}.user.toml (개인, git 무시)
|
||||
우선순위 2: _bmad/custom/{skill-name}.toml (팀/조직, 커밋)
|
||||
우선순위 3(마지막): 스킬 자체 customize.toml (기본값)
|
||||
```
|
||||
|
||||
`_bmad/custom/` 폴더는 처음엔 비어 있습니다. 누군가 실제로 커스터마이즈할 때만 파일이 생깁니다.
|
||||
|
||||
### 병합 규칙(필드명이 아니라 모양 기준)
|
||||
|
||||
병합 스크립트는 네 가지 구조 규칙을 적용합니다. 필드명은 특별 취급되지 않습니다. 값의 구조가 동작을 결정합니다.
|
||||
|
||||
| 모양 | 규칙 |
|
||||
| --- | --- |
|
||||
| 스칼라 값(문자열, 정수, 불리언, 실수) | 오버라이드가 이깁니다 |
|
||||
| 테이블 | 깊은 병합(재귀적으로 이 규칙을 적용) |
|
||||
| 모든 항목이 **같은** 식별자 필드(`code` 또는 `id`)를 공유하는 테이블 배열 | 해당 키로 병합합니다. 같은 키는 **제자리에서 교체**, 새 키는 **추가**됩니다 |
|
||||
| 그 밖의 배열(스칼라 값, 식별자가 없는 테이블, `code`와 `id`가 섞인 배열) | **추가**됩니다. 기본값, 팀, 사용자 순서입니다 |
|
||||
|
||||
**삭제 메커니즘은 없습니다.** 오버라이드는 기본값 항목을 지울 수 없습니다. 기본 메뉴 항목을 숨겨야 한다면 같은 `code`로 동작 없는 설명이나 프롬프트를 넣어 덮어쓰세요. 배열을 더 깊게 재구성해야 한다면 스킬을 포크하세요.
|
||||
|
||||
**`code` / `id` 관례.** BMad는 테이블 배열의 병합 키로 `code`(예: `"BP"`, `"R1"` 같은 짧은 식별자)와 `id`(더 긴 안정 식별자)를 사용합니다. 직접 만든 테이블 배열이 추가 전용이 아니라 키로 교체 가능해야 한다면 한 가지 관례만 고르고 전체 배열에서 일관되게 사용하세요. 일부 항목은 `code`, 일부 항목은 `id`를 쓰면 키 병합 대신 추가 방식으로 처리됩니다.
|
||||
|
||||
### 일부 에이전트 필드는 읽기 전용입니다
|
||||
|
||||
`agent.name`과 `agent.title`은 기준 메타데이터로 `customize.toml`에 있지만, 에이전트의 SKILL.md는 런타임에 이를 읽지 않습니다. 정체성은 하드코딩되어 있습니다. 오버라이드 파일에 `name = "Bob"`을 넣어도 효과가 없습니다. 정말 다른 이름의 에이전트가 필요하다면 스킬 폴더를 복사해 이름을 바꾸고 커스텀 스킬로 배포하세요.
|
||||
|
||||
## 단계
|
||||
|
||||
### 1. 스킬의 커스터마이징 영역 찾기
|
||||
|
||||
설치된 디렉터리에서 스킬의 `customize.toml`을 확인합니다. PM 에이전트 예:
|
||||
|
||||
```text
|
||||
.claude/skills/bmad-agent-pm/customize.toml
|
||||
```
|
||||
|
||||
경로는 IDE별로 다릅니다. Cursor는 `.cursor/skills/`, Cline은 `.cline/skills/`를 사용합니다.
|
||||
|
||||
이 파일이 기준 스키마입니다. 읽기 전용 정체성 필드를 제외하고 보이는 모든 필드는 커스터마이즈할 수 있습니다.
|
||||
|
||||
### 2. 오버라이드 파일 만들기
|
||||
|
||||
프로젝트 루트에 `_bmad/custom/` 디렉터리가 없다면 만듭니다. 그런 다음 스킬 이름을 딴 파일을 만듭니다.
|
||||
|
||||
```text
|
||||
_bmad/custom/
|
||||
bmad-agent-pm.toml # 팀 오버라이드(git에 커밋)
|
||||
bmad-agent-pm.user.toml # 개인 선호(git에서 무시)
|
||||
```
|
||||
|
||||
:::caution[전체 `customize.toml`을 복사하지 마세요]
|
||||
오버라이드 파일은 **희소**입니다. 바꾸는 필드만 포함하세요. 생략한 필드는 아래 계층(팀은 기본값에서, 사용자는 팀 또는 기본값에서) 자동 상속됩니다.
|
||||
|
||||
전체 `customize.toml`을 오버라이드로 복사하면 해롭습니다. 다음 업데이트가 새 기본값을 제공해도 오버라이드 파일이 옛 값을 고정하기 때문에 릴리스마다 조용히 어긋납니다.
|
||||
:::
|
||||
|
||||
**예시 - 아이콘을 바꾸고 원칙 하나 추가:**
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-agent-pm.toml
|
||||
# 바꾸는 필드만 둡니다. 나머지는 모두 상속됩니다.
|
||||
|
||||
[agent]
|
||||
icon = "🏥"
|
||||
principles = [
|
||||
"FDA 감사를 통과할 수 없는 것은 출시하지 않습니다.",
|
||||
]
|
||||
```
|
||||
|
||||
이 설정은 새 원칙을 기본값에 추가하고(제공된 원칙은 그대로 유지), 아이콘을 교체합니다. 나머지 필드는 제공된 값으로 남습니다.
|
||||
|
||||
### 3. 필요한 항목 커스터마이즈하기
|
||||
|
||||
아래 예시는 BMad의 평면 에이전트 스키마를 가정합니다. 필드는 `[agent]` 아래에 직접 위치하며 중첩된 `metadata`나 `persona` 하위 테이블은 없습니다.
|
||||
|
||||
**스칼라 값(icon, 역할, 정체성, communication_style).** 스칼라 값 오버라이드가 이깁니다. 바꾸는 필드만 설정하면 됩니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-agent-pm.toml
|
||||
|
||||
[agent]
|
||||
icon = "🏥"
|
||||
role = "규제 대상 헬스케어 도메인의 제품 발견을 이끕니다."
|
||||
communication_style = "정밀하고 규제를 의식하며, 초반부터 컴플라이언스 관점의 질문을 던집니다."
|
||||
```
|
||||
|
||||
**영구 사실, 원칙, 활성화 후크(추가 배열).** 아래 네 배열은 추가 전용입니다. 팀 항목은 기본값 뒤에 실행되고, 사용자 항목은 마지막에 실행됩니다.
|
||||
|
||||
```toml
|
||||
[agent]
|
||||
# 에이전트가 세션 내내 염두에 둘 정적 사실입니다. 조직 규칙, 도메인
|
||||
# 상수, 사용자 선호 등이 여기에 들어갑니다. 런타임 메모리 사이드카와는 다릅니다.
|
||||
#
|
||||
# 각 항목은 문장 그대로이거나, 내용을 사실로 로드하는 `file:` 참조입니다
|
||||
# glob 패턴도 지원합니다.
|
||||
persistent_facts = [
|
||||
"우리 조직은 AWS만 사용합니다. GCP나 Azure를 제안하지 마세요.",
|
||||
"모든 PRD는 엔지니어링 착수 전에 법무 승인을 받아야 합니다.",
|
||||
"대상 사용자는 환자가 아니라 임상의입니다. 예시도 그에 맞춰 구성하세요.",
|
||||
"file:{project-root}/docs/compliance/hipaa-overview.md",
|
||||
"file:{project-root}/_bmad/custom/company-glossary.md",
|
||||
]
|
||||
|
||||
# 에이전트의 가치 체계에 추가합니다
|
||||
principles = [
|
||||
"FDA 감사를 통과할 수 없는 것은 출시하지 않습니다.",
|
||||
"사용자 가치를 먼저, 컴플라이언스는 항상 지킵니다.",
|
||||
]
|
||||
|
||||
# 표준 활성화(페르소나, persistent_facts, 설정, 인사) 전에 실행합니다.
|
||||
activation_steps_prepend = [
|
||||
"{project-root}/docs/compliance/를 스캔하고 HIPAA 관련 문서를 컨텍스트로 로드하세요.",
|
||||
]
|
||||
|
||||
# 인사 후, 메뉴 전에 실행합니다.
|
||||
activation_steps_append = [
|
||||
"{project-root}/_bmad/custom/company-glossary.md가 있으면 읽으세요.",
|
||||
]
|
||||
```
|
||||
|
||||
두 후크는 역할이 다릅니다. Prepend는 인사 전에 실행되어 인사 자체를 개인화하는 데 필요한 컨텍스트를 로드할 수 있습니다. Append는 인사 후 실행되어 무거운 스캔이 끝날 때까지 사용자가 빈 화면만 보지 않게 합니다.
|
||||
|
||||
**메뉴 커스터마이징(`code`로 병합).** 메뉴는 테이블 배열입니다. 각 항목에는 `code` 필드가 있으므로 병합 스크립트는 코드로 병합합니다. 같은 코드는 제자리에서 교체되고, 새 코드는 추가됩니다.
|
||||
|
||||
TOML 테이블 배열 문법은 항목마다 `[[agent.menu]]`를 사용합니다.
|
||||
|
||||
```toml
|
||||
# 기존 CE 항목을 커스텀 스킬로 교체
|
||||
[[agent.menu]]
|
||||
code = "CE"
|
||||
description = "우리 전달 프레임워크로 에픽 생성"
|
||||
skill = "custom-create-epics"
|
||||
|
||||
# 새 항목 추가(기본값에는 RC 코드가 없음)
|
||||
[[agent.menu]]
|
||||
code = "RC"
|
||||
description = "컴플라이언스 사전 점검 실행"
|
||||
prompt = """
|
||||
{project-root}/_bmad/custom/compliance-checklist.md를 읽고
|
||||
{planning_artifacts}의 모든 문서를 그 기준에 맞춰 스캔하세요.
|
||||
공백이 있으면 관련 규제 조항을 인용해 보고하세요.
|
||||
"""
|
||||
```
|
||||
|
||||
각 메뉴 항목은 `skill`(등록된 스킬 호출) 또는 `prompt`(텍스트 직접 실행) 중 정확히 하나를 가집니다. 오버라이드에 나열하지 않은 항목은 기본값을 유지합니다.
|
||||
|
||||
**파일 참조.** `persistent_facts`, `activation_steps_prepend`/`activation_steps_append`, 메뉴 항목의 `prompt`처럼 텍스트가 파일을 가리켜야 할 때는 `{project-root}`를 기준으로 한 전체 경로를 사용하세요. 파일이 `_bmad/custom/`에서 오버라이드 옆에 있더라도 `{project-root}/_bmad/custom/info.md`처럼 전체 경로를 적습니다.
|
||||
|
||||
### 4. 개인 vs 팀
|
||||
|
||||
**팀 파일**(`bmad-agent-pm.toml`): git에 커밋합니다. 조직 전체에 공유됩니다. 컴플라이언스 규칙, 회사 페르소나, 커스텀 기능에 사용합니다.
|
||||
|
||||
**개인 파일**(`bmad-agent-pm.user.toml`): 자동으로 git에서 무시됩니다. 말투 조정, 개인 워크플로 선호 사항, 에이전트가 기억해야 하는 개인 사실에 사용합니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-agent-pm.user.toml
|
||||
|
||||
[agent]
|
||||
persistent_facts = [
|
||||
"선택지를 제시할 때 항상 대략적인 복잡도 추정(낮음/중간/높음)을 포함하세요.",
|
||||
]
|
||||
```
|
||||
|
||||
## 해석이 작동하는 방식
|
||||
|
||||
활성화 시 에이전트의 SKILL.md가 공유 Python 스크립트를 실행해 3계층 병합을 수행하고 해석된 블록을 JSON으로 반환합니다. 스크립트는 Python 표준 라이브러리의 `tomllib`만 사용하므로 기본 `python3`이면 충분합니다.
|
||||
|
||||
```bash
|
||||
python3 {project-root}/_bmad/scripts/resolve_customization.py \
|
||||
--skill {skill-root} \
|
||||
--key agent
|
||||
```
|
||||
|
||||
**요구사항**: Python 3.11+(이전 버전에는 `tomllib`이 없습니다). `pip install`, `uv`, virtualenv는 필요 없습니다. `python3 --version`으로 확인하세요. Homebrew 없는 macOS나 Ubuntu 22.04 같은 플랫폼은 기본 `python3`이 3.10 이하일 수 있으므로 3.11+를 별도 설치해야 할 수 있습니다.
|
||||
|
||||
`--skill`은 스킬이 설치된 디렉터리(`customize.toml`이 있는 위치)를 가리킵니다. 스킬 이름은 디렉터리의 basename에서 파생되며, 스크립트는 `_bmad/custom/{skill-name}.toml`과 `{skill-name}.user.toml`을 자동으로 찾습니다.
|
||||
|
||||
유용한 호출:
|
||||
|
||||
```bash
|
||||
# 전체 에이전트 블록 해석
|
||||
python3 {project-root}/_bmad/scripts/resolve_customization.py \
|
||||
--skill /abs/path/to/bmad-agent-pm \
|
||||
--key agent
|
||||
|
||||
# 단일 필드 해석
|
||||
python3 {project-root}/_bmad/scripts/resolve_customization.py \
|
||||
--skill /abs/path/to/bmad-agent-pm \
|
||||
--key agent.icon
|
||||
|
||||
# 전체 덤프
|
||||
python3 {project-root}/_bmad/scripts/resolve_customization.py \
|
||||
--skill /abs/path/to/bmad-agent-pm
|
||||
```
|
||||
|
||||
출력은 항상 JSON입니다. 특정 플랫폼에서 스크립트를 사용할 수 없다면 SKILL.md는 에이전트에게 세 TOML 파일을 직접 읽고 같은 병합 규칙을 적용하라고 지시합니다.
|
||||
|
||||
## 워크플로 커스터마이징
|
||||
|
||||
`bmad-product-brief`처럼 여러 단계 프로세스를 구동하는 워크플로(스킬)도 에이전트와 같은 오버라이드 메커니즘을 공유합니다. 커스터마이즈 가능한 영역은 `[agent]` 대신 `[workflow]` 아래에 있습니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-product-brief.toml
|
||||
|
||||
[workflow]
|
||||
activation_steps_prepend = [
|
||||
"Load {project-root}/docs/product/north-star-principles.md as context.",
|
||||
]
|
||||
|
||||
activation_steps_append = []
|
||||
|
||||
persistent_facts = [
|
||||
"모든 개요에는 명시적인 규제 위험 섹션이 포함되어야 합니다.",
|
||||
"file:{project-root}/docs/compliance/product-brief-checklist.md",
|
||||
]
|
||||
|
||||
on_complete = "개요를 세 개의 글머리표로 요약하고 gws-gmail-send 스킬로 이메일 발송을 제안하세요."
|
||||
```
|
||||
|
||||
동일한 필드 관례가 에이전트/워크플로 경계를 넘습니다. `activation_steps_prepend`/`activation_steps_append`, `persistent_facts`(`file:` 참조 포함), 그리고 키 기반 병합용 `code`/`id`가 있는 메뉴 스타일 `[[...]]` 테이블이 모두 같은 방식으로 동작합니다. 병합 스크립트는 최상위 키와 관계없이 네 구조 규칙을 적용합니다. SKILL.md 참조는 네임스페이스를 따릅니다: `{workflow.activation_steps_prepend}`, `{workflow.persistent_facts}`, `{workflow.on_complete}`. 워크플로가 노출하는 추가 필드(출력 경로, 토글, 리뷰 설정, 단계 플래그 등)도 같은 구조 기반 병합 규칙을 따릅니다. 무엇을 커스터마이즈할 수 있는지는 워크플로의 `customize.toml`을 읽으세요.
|
||||
|
||||
### 활성화 순서
|
||||
|
||||
커스터마이즈 가능한 워크플로는 후크가 언제 실행되는지 알 수 있도록 고정된 순서로 활성화됩니다.
|
||||
|
||||
1. `[workflow]` 블록 해석(기본값 → 팀 → 사용자 병합)
|
||||
2. `activation_steps_prepend`를 순서대로 실행
|
||||
3. 실행의 기반 컨텍스트로 `persistent_facts` 로드
|
||||
4. 설정(`_bmad/bmm/config.yaml`) 로드 및 표준 변수(프로젝트 이름, 언어, 경로, 날짜) 해석
|
||||
5. 사용자에게 인사
|
||||
6. `activation_steps_append`를 순서대로 실행
|
||||
|
||||
6단계 이후 워크플로 본문이 시작됩니다. 인사를 개인화하기 전에 컨텍스트가 필요하면 `activation_steps_prepend`를 사용하고, 설정이 무거워 사용자에게 인사를 먼저 보여주고 싶다면 `activation_steps_append`를 사용하세요.
|
||||
|
||||
### 현재 초기 단계의 범위
|
||||
|
||||
커스터마이징은 점진적으로 출시됩니다. 위에서 문서화한 `activation_steps_prepend`, `activation_steps_append`, `persistent_facts`, `on_complete`는 모든 커스터마이즈 가능한 워크플로가 노출하는 **기준 영역**이며 버전 간 안정적으로 유지됩니다. 오늘 당장 사전/사후 단계 주입, 기반 컨텍스트 고정, 후속 작업 트리거 같은 큰 단위의 제어를 제공합니다.
|
||||
|
||||
시간이 지나면 개별 워크플로가 실제로 하는 일에 맞춘 **더 세밀한 커스터마이징 지점**을 노출할 것입니다. 단계별 토글, 단계 플래그, 출력 템플릿 경로, 리뷰 게이트 같은 것들입니다. 그런 항목이 추가되면 기준 필드를 대체하지 않고 그 위에 쌓이므로 오늘 작성한 커스터마이징은 계속 동작합니다.
|
||||
|
||||
아직 노출되지 않은 세밀한 조절점이 필요하다면 `activation_steps_*`와 `persistent_facts`로 동작을 조정하거나, 원하는 커스터마이징 지점을 구체적으로 설명하는 이슈를 열어 주세요.
|
||||
|
||||
## 중앙 설정
|
||||
|
||||
스킬별 `customize.toml`은 **깊은 동작**(후크, 메뉴, persistent_facts, 단일 에이전트/워크플로의 페르소나 오버라이드)을 다룹니다. 별도 영역은 **공유 상태**를 다룹니다. 설치 답변과 `bmad-party-mode`, `bmad-retrospective`, `bmad-advanced-elicitation` 같은 외부 스킬이 사용하는 에이전트 명단입니다. 이 영역은 프로젝트 루트의 네 TOML 파일에 있습니다.
|
||||
|
||||
```text
|
||||
_bmad/config.toml (설치 프로그램 소유) 팀 범위: 설치 답변 + 에이전트 명단
|
||||
_bmad/config.user.toml (설치 프로그램 소유) 사용자 범위: user_name, 언어, 스킬 수준
|
||||
_bmad/custom/config.toml (사람이 작성) 팀 오버라이드(git에 커밋)
|
||||
_bmad/custom/config.user.toml (사람이 작성) 개인 오버라이드(git에서 무시)
|
||||
```
|
||||
|
||||
### 4계층 병합
|
||||
|
||||
```text
|
||||
우선순위 1(승리): _bmad/custom/config.user.toml
|
||||
우선순위 2: _bmad/custom/config.toml
|
||||
우선순위 3: _bmad/config.user.toml
|
||||
우선순위 4(기반): _bmad/config.toml
|
||||
```
|
||||
|
||||
스킬별 커스터마이즈와 같은 구조 규칙을 사용합니다. 스칼라 값 오버라이드, 테이블 깊은 병합, `code`/`id` 키 기반 배열 병합, 그 밖의 배열 추가입니다.
|
||||
|
||||
### 무엇이 어디에 있나요?
|
||||
|
||||
설치 프로그램은 `module.yaml`의 각 프롬프트에 선언된 `scope:`에 따라 답변을 나눕니다.
|
||||
|
||||
- `[core]`와 `[modules.<code>]` 섹션 - 설치 답변입니다. `team` 범위는 `_bmad/config.toml`에, `user` 범위는 `_bmad/config.user.toml`에 들어갑니다.
|
||||
- `[agents.<code>]` - 각 모듈의 `module.yaml` `agents:` 블록에서 추출한 에이전트 핵심 정보(코드, 이름, 직함, 아이콘, 설명, 팀)입니다. 항상 팀 범위입니다.
|
||||
|
||||
### 편집 규칙
|
||||
|
||||
- `_bmad/config.toml`과 `_bmad/config.user.toml`은 **설치할 때마다 재생성**됩니다. 읽기 전용 출력으로 취급하세요. 직접 수정하면 다음 설치에서 덮어쓰입니다. 설치 답변을 지속적으로 바꾸려면 설치 프로그램을 다시 실행하거나 `_bmad/custom/config.toml`에서 값을 덮어쓰세요.
|
||||
- `_bmad/custom/config.toml`과 `_bmad/custom/config.user.toml`은 설치 프로그램이 **절대 건드리지 않습니다**. 커스텀 에이전트, 에이전트 설명자 오버라이드, 팀 강제 설정, 설치 답변과 무관하게 고정하려는 값을 넣는 올바른 영역입니다.
|
||||
|
||||
### 예시 - 에이전트 리브랜딩
|
||||
|
||||
```toml
|
||||
# _bmad/custom/config.toml (git에 커밋, 모든 개발자에게 적용)
|
||||
|
||||
[agents.bmad-agent-pm]
|
||||
description = "헬스케어 PM - 규제를 의식하고 이해관계자 중심이며, FDA 관점의 질문을 먼저 던집니다."
|
||||
icon = "🏥"
|
||||
```
|
||||
|
||||
병합 스크립트가 설치 프로그램이 작성한 `[agents.bmad-agent-pm]` 위로 병합합니다. `bmad-party-mode`와 명단을 사용하는 스킬은 새 설명을 자동으로 사용합니다.
|
||||
|
||||
### 예시 - 가상 에이전트 추가
|
||||
|
||||
```toml
|
||||
# _bmad/custom/config.user.toml (개인용, git에서 무시)
|
||||
|
||||
[agents.kirk]
|
||||
team = "startrek"
|
||||
name = "Captain James T. Kirk"
|
||||
title = "우주선 선장"
|
||||
icon = "🖖"
|
||||
description = "대담하고 규칙을 굽힐 줄 아는 지휘관입니다. 극적인 쉼표를 두고 말하며 지휘의 무게를 소리 내어 생각합니다."
|
||||
```
|
||||
|
||||
스킬 폴더가 없어도 핵심 정보만으로 파티 모드가 Kirk를 하나의 목소리로 생성할 수 있습니다. `team` 필드로 필터링해 엔터프라이즈 승무원만 라운드테이블에 초대할 수 있습니다.
|
||||
|
||||
### 예시 - 모듈 설치 설정 오버라이드
|
||||
|
||||
```toml
|
||||
# _bmad/custom/config.toml
|
||||
|
||||
[modules.bmm]
|
||||
planning_artifacts = "/shared/org-planning-artifacts"
|
||||
```
|
||||
|
||||
오버라이드는 각 개발자가 로컬 설치 중 답한 값보다 우선합니다. 팀 관례를 고정할 때 유용합니다.
|
||||
|
||||
### 어떤 영역을 사용할까요?
|
||||
|
||||
| 필요 | 사용 |
|
||||
| --- | --- |
|
||||
| 모든 개발 워크플로에 MCP 도구 호출 추가 | 스킬별: `_bmad/custom/bmad-agent-dev.toml` `persistent_facts` |
|
||||
| 에이전트에 메뉴 항목 추가 | 스킬별: `_bmad/custom/bmad-agent-{role}.toml` `[[agent.menu]]` |
|
||||
| 워크플로의 출력 템플릿 교체 | 스킬별: `_bmad/custom/{workflow}.toml` 스칼라 값 오버라이드 |
|
||||
| 에이전트 공개 설명자 리브랜딩 | **중앙**: `_bmad/custom/config.toml` `[agents.<code>]` |
|
||||
| 커스텀 또는 가상 에이전트를 명단에 추가 | **중앙**: `_bmad/custom/config.*.toml` 새 `[agents.<code>]` 항목 |
|
||||
| 팀 강제 설치 설정 고정 | **중앙**: `_bmad/custom/config.toml` `[modules.<code>]` 또는 `[core]` |
|
||||
|
||||
필요에 따라 한 프로젝트에서 두 영역을 함께 사용하세요.
|
||||
|
||||
## 실전 예시
|
||||
|
||||
에이전트가 실행하는 모든 워크플로에 걸친 동작 조정, 조직 관례 강제, Confluence와 Jira로 출력 게시, 에이전트 명단 커스터마이즈, 출력 템플릿 교체 같은 엔터프라이즈 지향 레시피는 [조직을 위해 BMad 확장하기](./expand-bmad-for-your-org.md)를 참고하세요.
|
||||
|
||||
## 문제 해결
|
||||
|
||||
**커스터마이징이 보이지 않나요?**
|
||||
|
||||
- 파일이 `_bmad/custom/`에 올바른 스킬 이름으로 있는지 확인하세요
|
||||
- TOML 문법을 확인하세요. 문자열은 따옴표가 필요하고, 테이블 헤더는 `[section]`, 테이블 배열은 `[[section]]`입니다. 테이블의 스칼라 값 또는 배열 키는 해당 테이블의 `[[subtables]]`보다 먼저 와야 합니다
|
||||
- 에이전트의 경우 커스터마이징은 `[agent]` 아래에 있습니다. 그 헤더 아래에 쓴 필드는 다른 테이블 헤더가 시작될 때까지 `agent`에 속합니다
|
||||
- `agent.name`과 `agent.title`은 읽기 전용입니다. 오버라이드해도 효과가 없습니다
|
||||
|
||||
**업데이트가 커스터마이징을 망가뜨렸나요?**
|
||||
|
||||
- 전체 `customize.toml`을 오버라이드 파일에 복사했나요? **하지 마세요.** 오버라이드 파일은 바꾸는 필드만 포함해야 합니다. 전체 복사는 옛 기본값을 고정하고 릴리스마다 조용히 어긋납니다. 오버라이드를 변경분만 남기도록 줄이세요.
|
||||
|
||||
**무엇을 커스터마이즈할 수 있는지 봐야 하나요?**
|
||||
|
||||
- `bmad-customize` 스킬을 실행하세요. 프로젝트에 설치된 모든 커스터마이즈 가능한 스킬을 열거하고, 이미 오버라이드가 있는 항목을 보여주며, 추가 또는 업데이트 과정을 안내합니다
|
||||
- 또는 스킬의 `customize.toml`을 직접 읽으세요. `name`과 `title`을 제외하고 모든 필드가 커스터마이즈 가능합니다
|
||||
|
||||
**초기화가 필요하나요?**
|
||||
|
||||
- `_bmad/custom/`에서 오버라이드 파일을 삭제하세요. 스킬은 내장 기본값으로 돌아갑니다
|
||||
|
|
@ -0,0 +1,119 @@
|
|||
---
|
||||
title: '기존 프로젝트'
|
||||
description: 기존 코드베이스에서 BMad Method를 사용하는 방법
|
||||
sidebar:
|
||||
order: 7
|
||||
---
|
||||
|
||||
기존 프로젝트와 레거시 코드베이스에서 작업할 때 BMad Method를 효과적으로 사용하세요.
|
||||
|
||||
이 가이드는 BMad Method로 기존 프로젝트에 적응하는 핵심 워크플로를 다룹니다.
|
||||
|
||||
:::note[필수 조건]
|
||||
|
||||
- BMad Method 설치(`npx bmad-method install`)
|
||||
- 작업하려는 기존 코드베이스
|
||||
- AI 기반 IDE(Claude Code 또는 Cursor) 접근 권한
|
||||
:::
|
||||
|
||||
## 1단계: 완료된 계획 산출물 정리
|
||||
|
||||
BMad 과정으로 모든 PRD 에픽과 스토리를 완료했다면 해당 파일을 정리하세요. 필요하다면 보관하거나 삭제하거나 버전 기록에 의존하세요. 다음 위치에 이 파일들을 계속 두지 마세요.
|
||||
|
||||
- `docs/`
|
||||
- `_bmad-output/planning-artifacts/`
|
||||
- `_bmad-output/implementation-artifacts/`
|
||||
|
||||
## 2단계: 프로젝트 컨텍스트 만들기
|
||||
|
||||
:::tip[기존 프로젝트에 권장]
|
||||
`project-context.md`를 생성해 기존 코드베이스의 패턴과 규칙을 포착하세요. 이렇게 하면 변경을 구현할 때 AI 에이전트가 이미 자리 잡은 관례를 따릅니다.
|
||||
:::
|
||||
|
||||
프로젝트 컨텍스트 생성 워크플로를 실행합니다.
|
||||
|
||||
```bash
|
||||
bmad-generate-project-context
|
||||
```
|
||||
|
||||
이 워크플로는 코드베이스를 스캔해 다음을 식별합니다.
|
||||
|
||||
- 기술 스택과 버전
|
||||
- 코드 구성 패턴
|
||||
- 명명 규칙
|
||||
- 테스트 접근 방식
|
||||
- 프레임워크별 패턴
|
||||
|
||||
생성된 파일을 검토하고 다듬거나, 원한다면 `_bmad-output/project-context.md`에 직접 만들 수 있습니다.
|
||||
|
||||
[프로젝트 컨텍스트 자세히 알아보기](../explanation/project-context.md)
|
||||
|
||||
## 3단계: 품질 높은 프로젝트 문서 유지
|
||||
|
||||
`docs/` 폴더에는 프로젝트를 정확하게 나타내는 간결하고 잘 구성된 문서가 있어야 합니다.
|
||||
|
||||
- 의도와 비즈니스 근거
|
||||
- 비즈니스 규칙
|
||||
- 아키텍처
|
||||
- 그 밖의 관련 프로젝트 정보
|
||||
|
||||
복잡한 프로젝트라면 `bmad-document-project` 워크플로 사용을 고려하세요. 전체 프로젝트를 스캔하고 실제 현재 상태를 문서화하는 실행 시 선택 가능한 변형을 제공합니다.
|
||||
|
||||
## 4단계: 도움 받기
|
||||
|
||||
### BMad 도움말: 시작점
|
||||
|
||||
**다음에 무엇을 해야 할지 확실하지 않을 때 언제든 `bmad-help`를 실행하세요.** 이 지능형 가이드는 다음을 수행합니다.
|
||||
|
||||
- 프로젝트를 검사해 이미 완료된 작업을 확인합니다
|
||||
- 설치된 모듈을 기준으로 선택지를 보여줍니다
|
||||
- 자연어 질문을 이해합니다
|
||||
|
||||
```
|
||||
bmad-help 기존 Rails 앱이 있는데 어디서 시작하면 좋나요?
|
||||
bmad-help 빠른 흐름과 전체 BMad Method는 무엇이 다른가요?
|
||||
bmad-help 사용할 수 있는 워크플로를 보여 주세요
|
||||
```
|
||||
|
||||
BMad 도움말은 **모든 워크플로 끝에서 자동으로 실행되어** 다음에 무엇을 해야 할지 명확히 안내합니다.
|
||||
|
||||
### 접근 방식 선택
|
||||
|
||||
변경 범위에 따라 두 가지 주요 선택지가 있습니다.
|
||||
|
||||
| 범위 | 권장 접근 방식 |
|
||||
| --- | --- |
|
||||
| **작은 업데이트나 추가** | `bmad-quick-dev`를 실행해 의도 정리, 계획, 구현, 리뷰를 하나의 워크플로에서 처리합니다. 전체 4단계 BMad Method는 과할 가능성이 큽니다. |
|
||||
| **큰 변경이나 추가** | 필요한 만큼만 엄격하게 적용하면서 BMad Method로 시작합니다. |
|
||||
|
||||
### PRD 작성 중
|
||||
|
||||
제품 개요를 만들거나 바로 PRD로 들어갈 때 에이전트가 다음을 하도록 확인하세요.
|
||||
|
||||
- 기존 프로젝트 문서를 찾고 분석합니다
|
||||
- 현재 시스템에 대한 적절한 컨텍스트를 읽습니다
|
||||
|
||||
에이전트를 명시적으로 안내할 수 있지만 목표는 새 기능이 기존 시스템과 잘 통합되게 하는 것입니다.
|
||||
|
||||
### UX 고려 사항
|
||||
|
||||
UX 작업은 선택 사항입니다. 결정 기준은 프로젝트에 UX가 있는지가 아니라 다음입니다.
|
||||
|
||||
- UX 변경을 작업할 예정인지
|
||||
- 의미 있는 새 UX 디자인이나 패턴이 필요한지
|
||||
|
||||
만족스러운 기존 화면을 단순히 업데이트하는 정도라면 전체 UX 과정은 필요하지 않습니다.
|
||||
|
||||
### 아키텍처 고려 사항
|
||||
|
||||
아키텍처를 진행할 때 아키텍트가 다음을 하도록 확인하세요.
|
||||
|
||||
- 적절한 문서 파일을 사용합니다
|
||||
- 기존 코드베이스를 스캔합니다
|
||||
|
||||
여기서는 특히 주의하세요. 이미 있는 것을 다시 만들거나 기존 아키텍처와 어긋나는 결정을 방지해야 합니다.
|
||||
|
||||
## 더 보기
|
||||
|
||||
- **[빠른 수정](./quick-fixes.md)** - 버그 수정과 임시 변경
|
||||
- **[기존 프로젝트 FAQ](../explanation/established-projects-faq.md)** - 기존 프로젝트 작업에 대한 일반 질문
|
||||
|
|
@ -0,0 +1,332 @@
|
|||
---
|
||||
title: '조직을 위해 BMad 확장하기'
|
||||
description: 포크 없이 BMad를 재구성하는 여섯 가지 커스터마이징 패턴 - 에이전트 전반 규칙, 워크플로 관례, 외부 게시, 템플릿 교체, 에이전트 명단 변경, 고급 통합 패턴
|
||||
sidebar:
|
||||
order: 9
|
||||
---
|
||||
|
||||
BMad의 커스터마이징 영역을 사용하면 설치된 파일을 수정하거나 스킬을 포크하지 않고도 조직에 맞게 동작을 바꿀 수 있습니다. 이 가이드는 대부분의 엔터프라이즈 요구를 다루는 여섯 가지 레시피를 소개합니다.
|
||||
|
||||
:::note[필수 조건]
|
||||
|
||||
- 프로젝트에 BMad 설치([BMad 설치 방법](./install-bmad.md) 참고)
|
||||
- 커스터마이징 모델 이해([BMad 커스터마이징 방법](./customize-bmad.md) 참고)
|
||||
- PATH의 Python 3.11+(병합 스크립트용, stdlib만 사용하며 `pip install` 불필요)
|
||||
:::
|
||||
|
||||
:::tip[이 레시피 적용하기]
|
||||
아래 **스킬별 레시피**(레시피 1-4)는 `bmad-customize` 스킬을 실행하고 의도를 설명해 적용할 수 있습니다. 스킬이 적절한 영역을 고르고 오버라이드 파일을 작성하고 병합을 검증합니다. 레시피 5(에이전트 명단에 대한 중앙 설정 오버라이드)는 v1 스킬 범위 밖이라 직접 작성해야 합니다. 이 문서의 레시피는 *무엇을* 오버라이드할지의 참고 기준이고, `bmad-customize`는 에이전트/워크플로 영역의 *방법*을 처리합니다.
|
||||
:::
|
||||
|
||||
## 3계층 모델
|
||||
|
||||
레시피를 고르기 전에 오버라이드가 어디에 들어가는지 알아두세요.
|
||||
|
||||
| 계층 | 오버라이드 위치 | 범위 |
|
||||
| --- | --- | --- |
|
||||
| **에이전트**(예: Amelia, Mary, John) | `_bmad/custom/bmad-agent-{role}.toml`의 `[agent]` 섹션 | 에이전트를 통해 실행되는 **모든 워크플로**에 페르소나와 함께 이동 |
|
||||
| **워크플로**(예: 제품 개요, PRD 생성) | `_bmad/custom/{workflow-name}.toml`의 `[workflow]` 섹션 | 해당 워크플로 실행에만 적용 |
|
||||
| **중앙 설정** | `_bmad/custom/config.toml`의 `[agents.*]`, `[core]`, `[modules.*]` | 에이전트 명단(파티 모드, 회고, 도출에서 누가 가능한지), 조직 전체로 고정된 설치 시 설정 |
|
||||
|
||||
경험칙: 규칙이 엔지니어의 모든 개발 작업에 적용되어야 한다면 **개발자 에이전트**를 커스터마이즈하세요. 제품 개요를 쓸 때만 적용된다면 **제품 개요 워크플로**를 커스터마이즈하세요. *방에 누가 있는지*를 바꾸는 일(에이전트 이름 변경, 커스텀 목소리 추가, 공유 산출물 경로 강제)은 **중앙 설정**을 편집하세요.
|
||||
|
||||
## 레시피 1: 에이전트가 실행하는 모든 워크플로에 규칙 적용
|
||||
|
||||
**사용 사례:** 에이전트를 통해 실행되는 모든 워크플로가 같은 도구 사용과 외부 시스템 통합 규칙을 상속하도록 표준화합니다. 가장 영향력이 큰 패턴입니다.
|
||||
|
||||
**예시: Amelia 개발자 에이전트가 라이브러리 문서는 항상 Context7을 사용하고, 에픽 목록에 스토리가 없으면 Linear를 대체 경로로 사용합니다.**
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-agent-dev.toml
|
||||
|
||||
[agent]
|
||||
|
||||
# 모든 활성화에 적용됩니다. Amelia가 실행하는 모든 스킬
|
||||
# 스토리 구현, 빠른 개발, 스토리 생성, 코드 리뷰, QA 생성으로 이어집니다.
|
||||
persistent_facts = [
|
||||
"라이브러리 문서(React, TypeScript, Zod, Prisma 등)를 찾을 때는 학습 데이터 지식에 의존하기 전에 context7 MCP 도구(`mcp__context7__resolve_library_id`, 이후 `mcp__context7__get_library_docs`)를 호출하세요. 최신 문서가 기억된 API보다 우선합니다.",
|
||||
"스토리 참조를 {planning_artifacts}/epics-and-stories.md에서 찾을 수 없으면 사용자에게 확인을 요청하기 전에 스토리 ID나 제목으로 Linear의 `mcp__linear__search_issues`를 검색하세요. Linear가 일치 항목을 반환하면 권위 있는 스토리 소스로 취급하세요.",
|
||||
]
|
||||
```
|
||||
|
||||
**왜 동작하나요:** 두 문장이 조직의 모든 개발 워크플로를 재구성합니다. 워크플로마다 반복하지 않아도 되고 소스 변경도 없습니다. 저장소를 가져오는 모든 새 엔지니어가 자동으로 관례를 상속합니다.
|
||||
|
||||
**팀 파일 vs 개인 파일:**
|
||||
|
||||
- `bmad-agent-dev.toml`: git에 커밋하고 팀 전체에 적용합니다
|
||||
- `bmad-agent-dev.user.toml`: git에서 무시되며 개인 선호를 위에 덧씌웁니다
|
||||
|
||||
## 레시피 2: 특정 워크플로 안에서 조직 관례 강제
|
||||
|
||||
**사용 사례:** 워크플로 출력의 *내용*이 컴플라이언스, 감사, 후속 사용자의 요구를 만족하도록 만듭니다.
|
||||
|
||||
**예시: 모든 제품 개요에 컴플라이언스 필드가 포함되고 에이전트가 조직의 게시 관례를 압니다.**
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-product-brief.toml
|
||||
|
||||
[workflow]
|
||||
|
||||
persistent_facts = [
|
||||
"모든 개요에는 '소유자', '대상 릴리스', '보안 리뷰 상태' 필드가 포함되어야 합니다.",
|
||||
"비상업용 개요(내부 도구, 리서치 프로젝트)도 사용자 가치 섹션은 포함해야 하지만 시장 차별화는 생략할 수 있습니다.",
|
||||
"file:{project-root}/docs/enterprise/brief-publishing-conventions.md",
|
||||
]
|
||||
```
|
||||
|
||||
**일어나는 일:** 사실 목록은 워크플로 활성화 3단계에서 로드됩니다. 에이전트가 제품 개요를 작성할 때 필수 필드와 엔터프라이즈 관례 문서를 알고 있습니다. 기본값(`file:{project-root}/**/project-context.md`)도 추가 방식이므로 계속 로드됩니다.
|
||||
|
||||
## 레시피 3: 완료된 출력을 외부 시스템에 게시
|
||||
|
||||
**사용 사례:** 워크플로가 출력을 만든 뒤 엔터프라이즈 기록 시스템(Confluence, Notion, SharePoint)에 자동 게시하고 후속 작업(Jira, Linear, Asana)을 엽니다.
|
||||
|
||||
**예시: 제품 개요를 Confluence에 자동 게시하고 선택적으로 Jira 에픽 생성을 제안합니다.**
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-product-brief.toml
|
||||
|
||||
[workflow]
|
||||
|
||||
# 종료 후크입니다. 스칼라 값 오버라이드는 빈 기본값 전체를 교체합니다.
|
||||
on_complete = """
|
||||
게시하고 후속 작업을 제안하세요:
|
||||
|
||||
1. 이전 단계에서 확정된 개요 파일 경로를 읽습니다.
|
||||
2. 다음 인자로 `mcp__atlassian__confluence_create_page`를 호출합니다:
|
||||
- space: "PRODUCT"
|
||||
- parent: "Product Briefs"
|
||||
- title: 개요 제목
|
||||
- body: 개요의 Markdown 내용
|
||||
반환된 페이지 URL을 기록합니다.
|
||||
3. 사용자에게 "개요가 Confluence에 게시되었습니다: <url>"이라고 알립니다.
|
||||
4. "이 개요에 대한 Jira 에픽을 지금 만들까요?"라고 묻습니다.
|
||||
5. 사용자가 동의하면 다음 인자로 `mcp__atlassian__jira_create_issue`를 호출합니다:
|
||||
- type: "Epic"
|
||||
- project: "PROD"
|
||||
- summary: 개요 제목
|
||||
- description: 짧은 요약과 Confluence 페이지 링크
|
||||
에픽 키와 URL을 보고합니다.
|
||||
6. 동의하지 않으면 깔끔하게 종료합니다.
|
||||
|
||||
어느 MCP 도구든 실패하면 실패를 보고하고 개요 경로를 출력한 뒤
|
||||
사용자에게 수동 게시를 요청하세요.
|
||||
"""
|
||||
```
|
||||
|
||||
**왜 `activation_steps_append`가 아니라 `on_complete`인가요:** `on_complete`는 워크플로의 주 출력이 작성된 뒤 마지막 단계에서 정확히 한 번 실행됩니다. 산출물 게시에는 이 시점이 맞습니다. `activation_steps_append`는 워크플로가 일을 시작하기 전에 매 활성화마다 실행됩니다.
|
||||
|
||||
**절충점:**
|
||||
|
||||
- **Confluence 게시 작업은 비파괴적**이며 완료 시 항상 실행됩니다
|
||||
- **Jira 에픽 생성은 팀 전체에 보이고 스프린트 계획 신호를 만들기 때문에** 사용자 확인으로 통제합니다
|
||||
- **안전한 대체 경로:** MCP 도구가 실패하면 조용히 출력을 버리지 말고 사용자에게 맡깁니다
|
||||
|
||||
## 레시피 4: 자체 출력 템플릿으로 교체
|
||||
|
||||
**사용 사례:** 기본 출력 구조가 조직의 예상 형식과 맞지 않거나, 같은 저장소의 서로 다른 조직이 다른 템플릿을 필요로 합니다.
|
||||
|
||||
**예시: product-brief 워크플로가 엔터프라이즈 소유 템플릿을 보게 합니다.**
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-product-brief.toml
|
||||
|
||||
[workflow]
|
||||
brief_template = "{project-root}/docs/enterprise/brief-template.md"
|
||||
```
|
||||
|
||||
**작동 방식:** 워크플로의 `customize.toml`은 `brief_template = "resources/brief-template.md"`(스킬 루트 기준 경로)를 제공합니다. 오버라이드는 `{project-root}` 아래 파일을 가리키므로 에이전트가 제공된 템플릿 대신 당신의 템플릿을 4단계에서 읽습니다.
|
||||
|
||||
**템플릿 작성 팁:**
|
||||
|
||||
- 템플릿은 `{project-root}/docs/` 또는 `{project-root}/_bmad/custom/templates/`에 두어 오버라이드 파일과 함께 버전 관리합니다
|
||||
- 제공된 템플릿과 같은 구조 관례(섹션 헤딩, 프런트매터)를 사용하세요. 에이전트는 그 구조에 적응합니다
|
||||
- 다중 조직 저장소에서는 `.user.toml`로 개별 팀이 커밋된 팀 파일을 건드리지 않고 자체 템플릿을 가리키게 할 수 있습니다
|
||||
|
||||
## 레시피 5: 에이전트 명단 커스터마이즈
|
||||
|
||||
**사용 사례:** 소스를 수정하거나 포크하지 않고 `bmad-party-mode`, `bmad-retrospective`, `bmad-advanced-elicitation` 같은 명단 기반 스킬에서 *방에 누가 있는지* 바꿉니다. 세 가지 흔한 변형은 다음과 같습니다.
|
||||
|
||||
### 5a. BMad 에이전트를 조직 전체에서 리브랜딩
|
||||
|
||||
실제 에이전트마다 설치 프로그램이 `module.yaml`에서 합성한 설명자가 있습니다. 이를 오버라이드하면 명단을 사용하는 모든 스킬에서 목소리와 표현 방식을 바꿀 수 있습니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/config.toml (커밋됨 - 모든 개발자에게 적용)
|
||||
|
||||
[agents.bmad-agent-analyst]
|
||||
description = "규제를 의식하는 비즈니스 분석가 Mary - Porter와 Minto의 사고법을 따르지만 FDA 감사 추적을 중시합니다. 사건 파일을 제시하는 포렌식 조사관처럼 말합니다."
|
||||
```
|
||||
|
||||
파티 모드는 새 설명으로 Mary를 생성합니다. 분석가 활성화 자체는 Mary의 동작이 스킬별 `customize.toml`에 있으므로 정상 동작합니다. 이 오버라이드는 **외부 스킬이 Mary를 어떻게 인식하고 소개하는지**를 바꾸며, 내부 작업 방식은 바꾸지 않습니다.
|
||||
|
||||
### 5b. 가상 또는 커스텀 에이전트 추가
|
||||
|
||||
스킬 폴더 없이 전체 설명자만으로 명단 기반 기능에 충분합니다. 파티 모드나 브레인스토밍 세션에서 페르소나 다양성을 줄 때 유용합니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/config.user.toml (개인용 - git에서 무시)
|
||||
|
||||
[agents.spock]
|
||||
team = "startrek"
|
||||
name = "스팍 사령관"
|
||||
title = "과학 장교"
|
||||
icon = "🖖"
|
||||
description = "논리를 우선하고 감정을 억제합니다. 관찰을 '흥미롭군요.'로 시작합니다. 절대 올림하지 않습니다. 직감에 의존하는 주장에 반대 관점을 제공합니다."
|
||||
|
||||
[agents.mccoy]
|
||||
team = "startrek"
|
||||
name = "레너드 맥코이 박사"
|
||||
title = "수석 의무관"
|
||||
icon = "⚕️"
|
||||
description = "시골 의사의 따뜻함과 짧은 인내심을 지녔습니다. '제기랄 짐, 난 ___가 아니라 의사라고.' 윤리 중심으로 스팍의 균형을 잡습니다."
|
||||
```
|
||||
|
||||
파티 모드에 "엔터프라이즈 승무원을 초대해 줘"라고 요청하면 `team = "startrek"`으로 필터링하고 스팍과 맥코이를 생성합니다. 요청하면 실제 BMad 에이전트(Mary, Amelia)도 같은 테이블에 앉을 수 있습니다.
|
||||
|
||||
### 5c. 팀 설치 설정 고정
|
||||
|
||||
설치 프로그램은 각 개발자에게 `planning_artifacts` 경로 같은 값을 묻습니다. 조직이 팀 전체에 하나의 답을 강제해야 한다면 중앙 설정에 고정하세요. 각 개발자의 로컬 프롬프트 답변은 해석 시점에 오버라이드됩니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/config.toml
|
||||
|
||||
[modules.bmm]
|
||||
planning_artifacts = "{project-root}/shared/planning"
|
||||
implementation_artifacts = "{project-root}/shared/implementation"
|
||||
|
||||
[core]
|
||||
document_output_language = "English"
|
||||
```
|
||||
|
||||
`user_name`, `communication_language`, `user_skill_level` 같은 개인 설정은 각 개발자의 `_bmad/config.user.toml` 아래에 둡니다. 팀 파일은 이를 건드리지 않는 것이 좋습니다.
|
||||
|
||||
**왜 중앙 설정인가요:** 에이전트별 파일은 *하나의* 에이전트가 활성화될 때 동작을 조정합니다. 중앙 설정은 명단을 사용하는 스킬이 명단을 조회할 때 *무엇을 보게 되는지*를 조정합니다. 어떤 에이전트가 존재하는지, 무엇이라고 불리는지, 어떤 팀에 속하는지, 저장소가 합의한 공유 설치 설정이 무엇인지입니다.
|
||||
|
||||
## IDE 세션 파일에 전역 규칙 보강
|
||||
|
||||
BMad 커스터마이징은 스킬이 활성화될 때 로드됩니다. 많은 IDE 도구는 스킬이 실행되기 전 **모든 세션 시작 시** 전역 지침 파일도 로드합니다(`CLAUDE.md`, `AGENTS.md`, `.cursor/rules/`, `.github/copilot-instructions.md` 등). BMad 스킬 밖에서도 지켜져야 하는 규칙은 거기에도 핵심만 반복하세요.
|
||||
|
||||
**중복해 둘 때:**
|
||||
|
||||
- 일반 채팅 대화(활성 스킬 없음)에서도 지켜야 할 만큼 중요한 규칙입니다
|
||||
- 학습 데이터 기반 기본값이 모델을 다른 방향으로 끌 수 있어 이중 안전장치가 필요합니다
|
||||
- 세션 파일을 부풀리지 않을 만큼 간결한 규칙입니다
|
||||
|
||||
**예시: 레시피 1의 dev 에이전트 규칙을 저장소의 `CLAUDE.md`에 한 줄로 보강.**
|
||||
|
||||
```markdown
|
||||
<!-- 라이브러리 문서를 읽을 때는 학습 데이터 지식에 의존하기 전에
|
||||
context7 MCP 도구(`mcp__context7__resolve_library_id` 이후
|
||||
`mcp__context7__get_library_docs`)를 거칩니다. -->
|
||||
```
|
||||
|
||||
한 문장이 매 세션에 로드됩니다. `bmad-agent-dev.toml` 커스터마이징과 짝을 이뤄 Amelia의 워크플로 안과 어시스턴트와의 임시 채팅 모두에 규칙을 적용합니다.
|
||||
|
||||
| 계층 | 범위 | 사용처 |
|
||||
| --- | --- | --- |
|
||||
| IDE 세션 파일(`CLAUDE.md` / `AGENTS.md`) | 모든 세션, 스킬 활성화 전 | BMad 밖에서도 살아야 하는 짧은 보편 규칙 |
|
||||
| BMad 에이전트 커스터마이징 | 에이전트가 실행하는 모든 워크플로 | 에이전트 페르소나별 동작 |
|
||||
| BMad 워크플로 커스터마이징 | 하나의 워크플로 실행 | 워크플로별 출력 형태, 게시 후크, 템플릿 |
|
||||
| BMad 중앙 설정 | 에이전트 명단 + 공유 설치 설정 | 방에 누가 있고 팀이 어떤 공유 경로를 쓰는지 |
|
||||
|
||||
IDE 파일은 **간결하게** 유지하세요. 잘 고른 열두 줄이 긴 목록보다 효과적입니다. 모델은 이를 매 턴 읽고, 노이즈는 신호를 밀어냅니다.
|
||||
|
||||
## 레시피 6: 고급 통합 패턴
|
||||
|
||||
몇몇 BMad 워크플로는 레시피 1-5에서 다룬 기본을 넘어 더 풍부한 설정 영역을 노출합니다. 온디맨드 지식 소스, 자동 출력 게시, 완료 시점 문서 표준, 교체 가능한 템플릿 같은 패턴은 여러 워크플로에 걸쳐 나타납니다. 어떤 필드를 노출하는지는 워크플로의 `customize.toml`을 확인하세요. 아래 예시는 모든 필드를 노출하는 `bmad-prd`를 사용하지만, 같은 패턴은 해당 필드가 있는 어디서나 적용됩니다.
|
||||
|
||||
### 온디맨드 지식 소스(`external_sources`)
|
||||
|
||||
워크플로를 내부 지식 베이스, 경쟁사 데이터베이스, 컴플라이언스 참조에 연결합니다. 에이전트는 대화에서 일치하는 필요가 나타날 때만 온디맨드로 참조하고 선제적으로 호출하지 않습니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-prd.toml (external_sources를 노출하는 모든 워크플로에서 같은 패턴 사용)
|
||||
|
||||
[workflow]
|
||||
external_sources = [
|
||||
"사용자가 경쟁사나 시장 세그먼트를 언급하면 차별화 섹션 초안을 작성하기 전에 corp:competitive_db(category={project_name})를 조회하세요.",
|
||||
"규제 도메인(헬스케어, 핀테크, 교육)에서는 도메인별 섹션 초안을 작성하기 전에 corp:compliance_reference를 참고하세요.",
|
||||
]
|
||||
```
|
||||
|
||||
각 항목은 MCP 도구 이름, 트리거 조건, 도구에 필요한 필드를 자연어로 지정합니다. 런타임에 도구가 없으면 워크플로는 표준 동작으로 돌아가고 공백을 알립니다.
|
||||
|
||||
### 자동 출력 게시(`external_handoffs`)
|
||||
|
||||
워크플로가 완료된 뒤 완성된 산출물을 외부 기록 시스템으로 보냅니다. 레시피 3의 `on_complete`와 달리 `external_handoffs`는 전용 추가 배열입니다. 팀 항목이 쌓이고 각 전달 작업은 도구가 없을 때 점진적 기능 저하와 함께 독립 실행됩니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-prd.toml (external_handoffs를 노출하는 모든 워크플로에서 같은 패턴 사용)
|
||||
|
||||
[workflow]
|
||||
external_handoffs = [
|
||||
"완료 후 corp:confluence_upload(space_key='PROD', parent_page='PRDs', label='prd', author={user_name})로 prd.md와 addendum.md를 Confluence에 업로드하세요. 반환된 페이지 URL을 기록하고 보여 주세요.",
|
||||
"notion:create_page(database_id='abc123', title='PRD: ' + {project_name})로 Notion에도 복제하세요.",
|
||||
]
|
||||
```
|
||||
|
||||
지정된 도구가 없으면 전달 작업은 건너뛰고 표시됩니다. 로컬 파일은 항상 존재합니다.
|
||||
|
||||
### 완료 시점 문서 표준(`doc_standards`)
|
||||
|
||||
사람이 읽을 문서에 조직 작성 표준을 완료 시점에 적용합니다. 내용이 완료된 후, 사용자가 출력을 보기 전입니다. 각 항목은 `skill:`, `file:`, 일반 텍스트 지시문일 수 있으며 각 검토 단계는 병렬 서브에이전트로 실행됩니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-prd.toml (doc_standards를 노출하는 모든 워크플로에서 같은 패턴 사용)
|
||||
|
||||
[workflow]
|
||||
doc_standards = [
|
||||
"file:{project-root}/docs/enterprise/voice-and-tone.md",
|
||||
"모든 날짜는 ISO 8601 형식(YYYY-MM-DD)을 사용해야 합니다.",
|
||||
"'활용'을 사용한 곳은 모두 '사용'으로 바꾸세요.",
|
||||
]
|
||||
```
|
||||
|
||||
`doc_standards`는 추가 배열입니다. 팀 항목은 워크플로가 제공하는 기본값 위에 쌓입니다. 넓은 구조 검토가 좁은 문장 검토보다 먼저 와야 합니다.
|
||||
|
||||
### 교체 가능한 템플릿과 체크리스트
|
||||
|
||||
구조화된 문서를 만드는 워크플로는 일반적으로 템플릿과 체크리스트 경로를 오버라이드 가능한 스칼라 값으로 노출합니다. `{project-root}` 아래 조직 소유 파일을 가리키면 소스를 수정하지 않고 다른 구조를 강제할 수 있습니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-prd.toml
|
||||
|
||||
[workflow]
|
||||
# 규제 산업용 PRD 구조
|
||||
prd_template = "{project-root}/docs/enterprise/prd-template-hipaa.md"
|
||||
|
||||
# 조직별 검증 기준
|
||||
validation_checklist = "{project-root}/docs/enterprise/prd-checklist-regulated.md"
|
||||
```
|
||||
|
||||
에이전트는 템플릿이 정의한 구조에 적응합니다. 템플릿은 `{project-root}/docs/` 또는 `{project-root}/_bmad/custom/templates/` 아래에 두어 오버라이드 파일과 함께 버전 관리하세요. 다중 조직 저장소에서는 `.user.toml`로 개별 팀이 커밋된 팀 파일을 건드리지 않고 자체 템플릿을 가리키게 할 수 있습니다.
|
||||
|
||||
## 레시피 조합
|
||||
|
||||
여섯 레시피는 모두 조합됩니다. 현실적인 엔터프라이즈용 `bmad-product-brief` 오버라이드는 한 파일에서 `persistent_facts`(레시피 2), `on_complete`(레시피 3), `brief_template`(레시피 4)을 설정할 수 있습니다. 에이전트 수준 규칙(레시피 1)은 에이전트 이름의 별도 파일에 있고, 중앙 설정(레시피 5)은 공유 명단과 팀 설정을 고정하며, 고급 통합 패턴(레시피 6)은 외부 소스와 전달 작업을 설정합니다. 모든 계층은 나란히 적용됩니다.
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-product-brief.toml (워크플로 수준)
|
||||
|
||||
[workflow]
|
||||
persistent_facts = ["..."]
|
||||
brief_template = "{project-root}/docs/enterprise/brief-template.md"
|
||||
on_complete = """ ... """
|
||||
```
|
||||
|
||||
```toml
|
||||
# _bmad/custom/bmad-agent-analyst.toml (에이전트 수준 - Mary가 product-brief를 실행)
|
||||
|
||||
[agent]
|
||||
persistent_facts = ["도메인이 헬스케어, 금융, 아동 데이터와 관련되면 항상 '규제 검토' 섹션을 포함하세요."]
|
||||
```
|
||||
|
||||
결과: Mary는 페르소나 활성화에서 규제 리뷰 규칙을 로드합니다. 사용자가 제품 개요 메뉴 항목을 선택하면 워크플로는 자체 관례를 그 위에 로드하고 엔터프라이즈 템플릿에 작성한 뒤 완료 시 Confluence에 게시합니다. 모든 계층이 함께 작동하며 BMad 소스는 수정하지 않습니다.
|
||||
|
||||
## 문제 해결
|
||||
|
||||
**오버라이드가 적용되지 않나요?** 파일이 `_bmad/custom/` 아래 정확한 스킬 디렉터리 이름으로 있는지 확인하세요(예: `bmad-agent-dev.toml`, `bmad-dev.toml` 아님). [BMad 커스터마이징 방법](./customize-bmad.md)을 참고하세요.
|
||||
|
||||
**MCP 도구 이름을 모르겠나요?** 현재 세션에서 MCP 서버가 노출하는 정확한 이름을 사용하세요. 확실하지 않다면 Claude Code에 사용 가능한 MCP 도구 목록을 보여달라고 요청하세요. `persistent_facts`나 `on_complete`에 하드코딩한 이름은 MCP 서버가 연결되어 있지 않으면 동작하지 않습니다.
|
||||
|
||||
**패턴이 내 설정에 맞지 않나요?** 위 레시피는 예시입니다. 기반 메커니즘(3계층 병합, 구조 규칙, 에이전트가 여러 워크플로에 걸쳐 동작하는 방식)은 훨씬 많은 패턴을 지원합니다. 필요에 맞게 조합하세요.
|
||||
|
|
@ -0,0 +1,81 @@
|
|||
---
|
||||
title: 'BMad에 대한 답을 얻는 방법'
|
||||
description: LLM을 사용해 BMad 관련 질문에 빠르게 답하기
|
||||
sidebar:
|
||||
order: 5
|
||||
---
|
||||
|
||||
BMad의 내장 도움말, 소스 문서, 커뮤니티를 사용해 답을 얻으세요. 가장 빠른 방법부터 가장 꼼꼼한 방법까지 순서대로 소개합니다.
|
||||
|
||||
## 1. BMad 도움말에게 묻기
|
||||
|
||||
답을 얻는 가장 빠른 방법입니다. `bmad-help` 스킬은 AI 세션에서 바로 사용할 수 있으며 질문의 80% 이상을 처리합니다. 프로젝트를 검사하고 완료한 작업을 확인한 뒤 다음에 무엇을 해야 할지 알려줍니다.
|
||||
|
||||
```
|
||||
bmad-help SaaS 아이디어가 있고 기능도 모두 알고 있습니다. 어디서 시작하나요?
|
||||
bmad-help UX 설계에는 어떤 선택지가 있나요?
|
||||
bmad-help PRD 워크플로에서 막혔어요
|
||||
```
|
||||
|
||||
:::tip
|
||||
플랫폼에 따라 `/bmad-help` 또는 `$bmad-help`도 사용할 수 있지만, 대부분은 `bmad-help`만으로 동작합니다.
|
||||
:::
|
||||
|
||||
## 2. 소스로 더 깊게 들어가기
|
||||
|
||||
BMad 도움말은 설치된 설정을 바탕으로 답합니다. BMad의 내부 구조, 역사, 아키텍처에 대한 질문이 있거나 설치 전에 BMad를 조사하고 있다면 AI가 소스를 직접 보게 하세요.
|
||||
|
||||
[BMAD-METHOD 저장소](https://github.com/bmad-code-org/BMAD-METHOD)를 복제하거나 열고 AI에게 질문하세요. 에이전트 기능이 있는 도구(Claude Code, Cursor, Windsurf 등)는 소스를 읽고 직접 답할 수 있습니다.
|
||||
|
||||
:::note[예시]
|
||||
**Q:** "BMad로 무언가를 가장 빠르게 만드는 방법을 알려줘"
|
||||
|
||||
**A:** 빠른 흐름을 사용하세요. `bmad-quick-dev`를 실행하면 의도를 명확히 하고, 계획하고, 구현하고, 리뷰하고, 결과를 하나의 워크플로에서 제시합니다. 전체 계획 단계를 건너뜁니다.
|
||||
:::
|
||||
|
||||
**더 좋은 답을 위한 팁:**
|
||||
|
||||
- **구체적으로 묻기** - "PRD 워크플로 3단계가 무엇을 하나요?"가 "PRD는 어떻게 작동하나요?"보다 좋습니다
|
||||
- **놀라운 주장은 확인하기** - LLM은 가끔 틀립니다. 소스 파일을 확인하거나 Discord에서 물어보세요
|
||||
|
||||
### 에이전트를 쓰지 않는다면 문서 사이트 사용
|
||||
|
||||
AI가 로컬 파일을 읽을 수 없다면(ChatGPT, Claude.ai 등), 세션에 [llms-full.txt](https://bmad-code-org.github.io/BMAD-METHOD/llms-full.txt)를 가져오세요. BMad 문서의 단일 파일 스냅샷입니다.
|
||||
|
||||
## 3. 사람에게 묻기
|
||||
|
||||
BMad 도움말이나 소스로도 답을 얻지 못했다면, 이제 훨씬 더 좋은 질문을 갖게 된 것입니다.
|
||||
|
||||
| 채널 | 사용처 |
|
||||
| --- | --- |
|
||||
| `help-requests` 포럼 | 질문 |
|
||||
| `#suggestions-feedback` | 아이디어와 기능 요청 |
|
||||
|
||||
**Discord:** [discord.gg/gk8jAdXWmj](https://discord.gg/gk8jAdXWmj)
|
||||
|
||||
**GitHub Issues:** [github.com/bmad-code-org/BMAD-METHOD/issues](https://github.com/bmad-code-org/BMAD-METHOD/issues)
|
||||
|
||||
_당신이_
|
||||
_막힌 채_
|
||||
_줄 서서_
|
||||
_기다린다면_
|
||||
_누구를 기다리나요?_
|
||||
|
||||
_소스는_
|
||||
_이미 거기_
|
||||
_눈앞에 있습니다._
|
||||
|
||||
_당신의_
|
||||
_기계를 가리키고._
|
||||
_풀어 주세요._
|
||||
|
||||
_읽고._
|
||||
_말합니다._
|
||||
_물어보세요._
|
||||
|
||||
_내일을_
|
||||
_기다릴 이유가 있나요_
|
||||
_오늘 이미_
|
||||
_할 수 있는데?_
|
||||
|
||||
_—Claude_
|
||||
|
|
@ -0,0 +1,266 @@
|
|||
---
|
||||
title: 'BMad 설치 방법'
|
||||
description: 로컬 개발, 팀, CI를 위해 BMad를 설치, 업데이트, 고정합니다
|
||||
sidebar:
|
||||
order: 1
|
||||
---
|
||||
|
||||
프로젝트에 BMad를 설정하려면 `npx bmad-method install`을 사용하세요. 하나의 명령으로 최초 설치, 업그레이드, 채널 전환, 스크립트 기반 CI 실행을 처리합니다. 이 페이지에서 그 전체를 다룹니다.
|
||||
|
||||
## 사용 시점
|
||||
|
||||
- BMad로 새 프로젝트를 시작합니다
|
||||
- 기존 설치에 모듈을 추가하거나 제거합니다
|
||||
- 모듈을 main 브랜치 최신 커밋으로 전환하거나 특정 릴리스에 고정합니다
|
||||
- CI 파이프라인, Dockerfile, 엔터프라이즈 배포를 위해 설치를 스크립트화합니다
|
||||
|
||||
:::note[필수 조건]
|
||||
|
||||
- **Node.js** 20+ (설치 프로그램에 필요)
|
||||
- **Git** (외부 모듈 복제용)
|
||||
- Claude Code 또는 Cursor 같은 **AI 도구**(지원 도구 목록은 `npx bmad-method install --list-tools`로 확인)
|
||||
|
||||
:::
|
||||
|
||||
## 최초 설치(빠른 경로)
|
||||
|
||||
```bash
|
||||
npx bmad-method install
|
||||
```
|
||||
|
||||
대화형 흐름은 다섯 가지를 묻습니다.
|
||||
|
||||
1. 설치 디렉터리(기본값은 현재 작업 디렉터리)
|
||||
2. 설치할 모듈(core, bmm, bmb, cis, gds, tea 체크박스)
|
||||
3. **"Ready to install (all stable)?"** - **Yes**를 선택하면 모든 외부 모듈의 최신 릴리스 태그를 사용합니다
|
||||
4. 연동할 AI 도구/IDE(`claude-code`, `cursor` 등)
|
||||
5. 모듈별 설정(이름, 언어, 출력 폴더)
|
||||
|
||||
기본값을 받아들이면 선택한 도구에 맞게 설정된 각 모듈의 최신 안정 릴리스가 설치됩니다.
|
||||
|
||||
:::tip[최신 사전 릴리스만 원하나요?]
|
||||
|
||||
```bash
|
||||
npx bmad-method@next install
|
||||
```
|
||||
|
||||
core와 bmm의 더 새로운 스냅샷이 포함된 사전 릴리스 설치 프로그램을 실행합니다. 변화는 더 잦지만 개발과 릴리스 사이의 지연이 줄어듭니다.
|
||||
:::
|
||||
|
||||
## 특정 버전 선택
|
||||
|
||||
디스크에 무엇이 설치되는지는 두 개의 독립 축으로 제어됩니다.
|
||||
|
||||
### 축 1: 외부 모듈 채널
|
||||
|
||||
bmb, cis, gds, tea, 커뮤니티 모듈 등 모든 외부 모듈은 세 채널 중 하나로 설치됩니다.
|
||||
|
||||
| 채널 | 설치되는 것 | 누가 선택하나 |
|
||||
| --- | --- | --- |
|
||||
| `stable`(기본값) | 가장 높은 시맨틱 버전 릴리스 태그. `v2.0.0-alpha.1` 같은 사전 릴리스는 제외됩니다. | 대부분의 사용자 |
|
||||
| `next` | 설치 시점의 main 브랜치 최신 커밋 | 기여자, 초기 채택자 |
|
||||
| `pinned` | 지정한 특정 태그 | 엔터프라이즈 설치, CI 재현성 |
|
||||
|
||||
채널은 모듈마다 정할 수 있습니다. bmb는 `next`로 두고 cis는 `stable`로 둘 수 있습니다. 아래 플래그로 자유롭게 섞을 수 있습니다.
|
||||
|
||||
### 축 2: 설치 프로그램 바이너리 버전
|
||||
|
||||
`bmad-method` npm 패키지 자체에는 두 npm 배포 태그(dist-tag)가 있습니다.
|
||||
|
||||
| 명령 | 받는 것 |
|
||||
| --- | --- |
|
||||
| `npx bmad-method install`(`@latest`) | 최신 안정 설치 프로그램 릴리스 |
|
||||
| `npx bmad-method@next install` | main에 푸시될 때마다 자동 배포되는 최신 사전 릴리스 설치 프로그램 |
|
||||
|
||||
**설치 프로그램 바이너리가 core와 bmm 버전을 결정합니다.** 이 두 모듈은 별도 저장소에서 복제되지 않고 설치 프로그램 패키지 안에 번들됩니다.
|
||||
|
||||
### core와 bmm에 자체 채널이 없는 이유
|
||||
|
||||
두 모듈은 실행한 설치 프로그램 바이너리에 묶여 있습니다.
|
||||
|
||||
- `npx bmad-method install` → 최신 안정 core 및 bmm
|
||||
- `npx bmad-method@next install` → 사전 릴리스 core 및 bmm
|
||||
- `node /path/to/local-checkout/tools/installer/bmad-cli.js install` → 로컬 체크아웃의 내용
|
||||
|
||||
`--pin bmm=v6.3.0`과 `--next=bmm`은 번들 모듈에는 효과가 없고, 시도하면 설치 프로그램이 경고합니다. 향후 릴리스에서 bmm가 설치 프로그램 패키지에서 분리되면 bmb처럼 적절한 채널 선택기를 갖게 됩니다.
|
||||
|
||||
## 기존 설치 업데이트
|
||||
|
||||
이미 `_bmad/`가 있는 디렉터리에서 `npx bmad-method install`을 실행하면 메뉴가 나타납니다.
|
||||
|
||||
| 실제 메뉴 선택 | 하는 일 |
|
||||
| --- | --- |
|
||||
| **Quick Update** | 기존 설정으로 설치를 다시 실행합니다. 파일을 새로 고치고, 안정 채널의 패치와 마이너 업그레이드를 적용하며, 메이저 업그레이드는 거부합니다. 빠르고 비대화형입니다. |
|
||||
| **Modify Install** | 전체 대화형 흐름입니다. 모듈을 추가/제거하고, 설정을 다시 구성하고, 기존 모듈 채널을 검토하고 전환할 수 있습니다. |
|
||||
|
||||
### 업그레이드 프롬프트
|
||||
|
||||
`Modify`가 `stable`에 설치된 모듈의 새 안정 태그를 감지하면 변경 폭을 분류하고 그에 맞게 묻습니다.
|
||||
|
||||
| 업그레이드 유형 | 예시 | 기본값 |
|
||||
| --- | --- | --- |
|
||||
| 패치 | v1.7.0 → v1.7.1 | `Y` |
|
||||
| 마이너 | v1.7.0 → v1.8.0 | `Y` |
|
||||
| 메이저 | v1.7.0 → v2.0.0 | **`N`** |
|
||||
|
||||
메이저 업그레이드는 호환성 깨짐이 예상치 못한 "불안정"으로 나타나는 경우가 많기 때문에 기본값이 `N`입니다. 프롬프트에는 변경 내용을 읽을 수 있는 GitHub 릴리스 노트 URL이 포함됩니다.
|
||||
|
||||
`--yes`에서는 패치와 마이너 업그레이드가 자동 적용됩니다. 메이저 업그레이드는 고정된 채로 유지됩니다. 비대화형으로 수락하려면 `--pin <code>=<new-tag>`를 전달하세요.
|
||||
|
||||
### 모듈 채널 전환
|
||||
|
||||
**대화형:** **Modify**를 선택하고 `"Review channel assignments?"`에 **Yes**로 답한 뒤, 각 외부 모듈에서 Keep, Switch to stable, Switch to next, Pin to a tag 중 하나를 선택합니다.
|
||||
|
||||
**플래그로:** 다음 섹션의 레시피가 일반적인 경우를 다룹니다.
|
||||
|
||||
## Headless CI
|
||||
|
||||
### 플래그 참조
|
||||
|
||||
| 플래그 | 목적 |
|
||||
| --- | --- |
|
||||
| `--yes`, `-y` | 모든 프롬프트를 건너뛰고 플래그 값과 기본값을 수락합니다 |
|
||||
| `--directory <path>` | 이 디렉터리에 설치합니다(기본값: 현재 작업 디렉터리) |
|
||||
| `--modules <a,b,c>` | 정확한 모듈 집합입니다. core는 자동 추가됩니다. 증분 목록이 아니므로 유지하려는 모든 것을 나열하세요 |
|
||||
| `--tools <a,b>` | IDE/도구 선택입니다. 새 `--yes` 설치에는 필수입니다. 유효 ID는 `--list-tools`로 확인하세요 |
|
||||
| `--list-tools` | 지원되는 모든 도구/IDE ID와 대상 디렉터리를 출력하고 종료합니다 |
|
||||
| `--action <type>` | `install`, `update`, `quick-update`. 기본값은 기존 설치 상태에 따라 달라집니다 |
|
||||
| `--custom-source <urls>` | Git URL 또는 로컬 경로에서 커스텀 모듈을 설치합니다 |
|
||||
| `--channel <stable\|next>` | 모든 외부 모듈에 적용합니다(`--all-stable` / `--all-next` 별칭) |
|
||||
| `--all-stable` | `--channel=stable` 별칭 |
|
||||
| `--all-next` | `--channel=next` 별칭 |
|
||||
| `--next=<code>` | 한 모듈을 next 채널에 둡니다. 반복 가능합니다 |
|
||||
| `--pin <code>=<tag>` | 한 모듈을 특정 태그에 고정합니다. 반복 가능합니다 |
|
||||
| `--set <module>.<key>=<value>` | 모듈 설정 옵션을 비대화형으로 설정합니다(권장, [모듈 설정 오버라이드](#모듈-설정-오버라이드) 참고). 반복 가능합니다 |
|
||||
| `--list-options [module]` | 내장 및 로컬 캐시된 공식 모듈의 모든 `--set` 키를 출력하고 종료합니다. 모듈 코드를 전달하면 범위를 좁힙니다 |
|
||||
| `--user-name`, `--communication-language`, `--document-output-language`, `--output-folder` | `--set core.<key>=<value>`와 동등한 레거시 단축 플래그입니다(계속 지원) |
|
||||
|
||||
플래그가 겹칠 때 우선순위는 `--pin` > `--next=` > `--channel` / `--all-*` > 레지스트리 기본값(`stable`)입니다.
|
||||
|
||||
:::note[해결 예시]
|
||||
`--all-next --pin cis=v0.2.0`은 bmb, gds, tea를 next에 두고 cis를 v0.2.0에 고정합니다.
|
||||
:::
|
||||
|
||||
### 레시피
|
||||
|
||||
**기본 설치 - 모든 것을 최신 안정 버전으로:**
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes --modules bmm,bmb,cis --tools claude-code
|
||||
```
|
||||
|
||||
**엔터프라이즈 고정 - 바이트 단위로 재현 가능:**
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes \
|
||||
--modules bmm,bmb,cis \
|
||||
--pin bmb=v1.7.0 --pin cis=v0.2.0 \
|
||||
--tools claude-code
|
||||
```
|
||||
|
||||
**최신 개발판 - 외부 모듈을 main 브랜치 최신 커밋으로:**
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes --modules bmm,bmb --all-next --tools claude-code
|
||||
```
|
||||
|
||||
**기존 설치에 모듈 추가**(나머지는 유지):
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes --action update \
|
||||
--modules bmm,bmb,gds
|
||||
```
|
||||
|
||||
`--tools`는 의도적으로 생략했습니다. `--action update`는 최초 설치 때 설정한 도구를 재사용합니다.
|
||||
|
||||
**채널 혼합 - bmb는 next, gds는 stable:**
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes --action update \
|
||||
--modules bmm,bmb,cis,gds \
|
||||
--next=bmb
|
||||
```
|
||||
|
||||
### 모듈 설정 오버라이드
|
||||
|
||||
`--set <module>.<key>=<value>`는 모듈 설정 옵션을 비대화형으로 설정합니다. 반복 가능하고 앞으로 추가될 모듈에도 같은 방식으로 적용됩니다. 이 플래그는 설치 후 패치로 적용됩니다. 설치 프로그램이 정상 흐름을 먼저 실행한 뒤 `--set`이 각 값을 `_bmad/config.toml`(팀 범위) 또는 `_bmad/config.user.toml`(사용자 범위), 그리고 `_bmad/<module>/config.yaml`에 갱신 또는 삽입하여 선언된 값이 다음 설치로 이어지게 합니다.
|
||||
|
||||
**예시 - 명시적 프로젝트 지식과 스킬 수준으로 bmm 설치:**
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes \
|
||||
--modules bmm \
|
||||
--tools claude-code \
|
||||
--set bmm.project_knowledge=research \
|
||||
--set bmm.user_skill_level=expert
|
||||
```
|
||||
|
||||
**모듈에서 사용할 수 있는 키 찾기:**
|
||||
|
||||
```bash
|
||||
npx bmad-method install --list-options bmm
|
||||
```
|
||||
|
||||
`--list-options`(인자 없음)는 설치 프로그램이 로컬에서 찾을 수 있는 모든 키를 나열합니다. 내장 모듈(`core`, `bmm`)과 현재 캐시된 공식 모듈이 포함됩니다. 캐시는 머신별이고 지워질 수 있으므로, 이전에 설치한 공식 모듈도 새 체크아웃이나 임시 CI 작업자에서는 다시 설치되기 전까지 나타나지 않습니다. 커뮤니티 및 커스텀 모듈은 여기서 열거되지 않습니다. 모듈의 `module.yaml`을 직접 읽어 선언된 키를 확인하세요.
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
- **경로 선택.** 패치 단계는 먼저 `config.user.toml`에서 `[modules.<module>] <key>`(또는 `[core] <key>`)를 찾고, 있으면 그 파일을 업데이트합니다. 그렇지 않으면 팀 범위 `config.toml`에 씁니다. 그래서 `core.user_name`, `bmm.user_skill_level` 같은 사용자 범위 키는 `config.user.toml`에, 팀 범위 키는 `config.toml`에 들어갑니다.
|
||||
- **그대로 쓰는 값.** 값은 제공한 그대로 기록됩니다. `result:` 템플릿 렌더링은 없습니다. 렌더링된 형태(예: `{project-root}/research`)를 원하면 명시적으로 전달하세요: `--set bmm.project_knowledge='{project-root}/research'`.
|
||||
- **다음 설치로 이어지는 선언된 키.** `module.yaml`에 선언된 키 값은 `_bmad/<module>/config.yaml`에도 쓰이므로 다음 설치 때 프롬프트 기본값으로 살아남습니다.
|
||||
- **다음 설치로 이어지지 않는 미선언 키.** 모듈 스키마가 선언하지 않은 키 값은 현재 설치의 `config.toml`에 들어가지만 다음 설치 때 다시 생성되지 않습니다(매니페스트 작성기의 엄격한 스키마 분리 단계가 알 수 없는 키를 떨어뜨립니다). 계속 유지해야 한다면 `--set`을 다시 전달하거나 `_bmad/config.toml`을 직접 수정하세요.
|
||||
- **검증 없음.** `single-select` 값은 허용 선택지와 대조하지 않고, 알 수 없는 키도 거부하지 않습니다. 지정한 값이 그대로 쓰입니다.
|
||||
- **`--modules`에 없는 모듈.** 포함하지 않은 모듈에 값을 설정하면 경고를 출력하고 값은 버려집니다(설치되지 않은 모듈용 파일은 생성되지 않습니다).
|
||||
|
||||
레거시 core 단축 플래그(`--user-name`, `--output-folder` 등)은 하위 호환성을 위해 계속 동작하고 문서화되어 있지만, `--set core.user_name=...`과 동등합니다.
|
||||
|
||||
:::note[quick-update와 함께 동작]
|
||||
`--set`은 설치 후 패치이므로 작업 유형과 관계없이 동일하게 적용됩니다. `bmad install --action quick-update` 또는 기존 설치에서 `--yes`(기본이 quick-update)로 실행해도 일반 설치처럼 마지막에 중앙 설정 파일을 패치합니다.
|
||||
:::
|
||||
|
||||
:::caution[공유 IP의 요청 제한]
|
||||
익명 GitHub API 호출은 IP당 시간당 60회로 제한됩니다. 한 번의 설치는 안정 태그를 확인하기 위해 외부 모듈마다 API를 한 번 호출합니다. NAT 뒤의 사무실, CI 러너 풀, VPN은 함께 이 한도를 소진할 수 있습니다.
|
||||
|
||||
환경 변수에 `GITHUB_TOKEN=<personal access token>`을 설정하면 계정당 시간당 5000회로 한도가 올라갑니다. 공개 저장소 읽기용 개인 액세스 토큰(PAT)이면 충분하며 범위는 필요 없습니다.
|
||||
:::
|
||||
|
||||
## 설치된 내용
|
||||
|
||||
설치 후 `_bmad/_config/manifest.yaml`은 디스크에 있는 내용을 정확히 기록합니다.
|
||||
|
||||
```yaml
|
||||
modules:
|
||||
- name: bmb
|
||||
version: v1.7.0 # 태그 또는 next용 "main"
|
||||
channel: stable # stable | next | pinned
|
||||
sha: 86033fc9aeae2ca6d52c7cdb675c1f4bf17fc1c1
|
||||
source: external
|
||||
repoUrl: https://github.com/bmad-code-org/bmad-builder
|
||||
```
|
||||
|
||||
`sha` 필드는 git 기반 모듈(외부, 커뮤니티, URL 기반 커스텀)에 기록됩니다. 번들 모듈(core, bmm)과 로컬 경로 커스텀 모듈에는 없습니다. 그 코드는 복제 가능한 참조가 아니라 설치 프로그램 바이너리 또는 파일시스템 상태에 따라 달라집니다.
|
||||
|
||||
머신 간 재현성을 위해 같은 `--modules` 명령을 다시 실행하는 것에 의존하지 마세요. 안정 채널 설치는 **설치 시점**의 가장 높은 릴리스 태그로 해석되므로 나중에 다시 실행하면 그 사이 릴리스된 버전으로 설치됩니다. `manifest.yaml`의 기록된 태그를 대상 머신에서 명시적 `--pin` 플래그로 바꾸세요. 예:
|
||||
|
||||
```bash
|
||||
npx bmad-method install --yes --modules bmb,cis \
|
||||
--pin bmb=v1.7.0 --pin cis=v0.4.2 --tools claude-code
|
||||
```
|
||||
|
||||
## 문제 해결
|
||||
|
||||
### "Could not resolve stable tag" 또는 "API rate limit exceeded"
|
||||
|
||||
GitHub의 익명 시간당 60회 한도에 도달했습니다. `GITHUB_TOKEN`을 설정하고 다시 시도하세요. 이미 토큰이 있다면 만료되었거나 해당 토큰 자체의 한도에 걸렸을 수 있습니다. 다른 토큰을 시도하거나 시간당 한도가 초기화될 때까지 기다리세요.
|
||||
|
||||
### "Tag 'vX.Y.Z' not found"
|
||||
|
||||
`--pin`에 전달한 태그가 모듈 저장소에 없습니다. GitHub의 저장소 릴리스 페이지에서 유효한 태그를 확인하세요.
|
||||
|
||||
### 고정 설치가 계속 업그레이드됨
|
||||
|
||||
고정 설치는 업그레이드되지 않습니다. `Quick Update`는 안정 채널의 패치와 마이너만 적용하며 `pinned`나 `next`는 건드리지 않습니다. 고정 설치가 바뀌었다면 `_bmad/_config/manifest.yaml`을 여세요. 명시적으로 플래그로 오버라이드하지 않는 한 `channel: pinned`와 고정된 `version`, `sha`가 실행 간 유지되어야 합니다.
|
||||
|
||||
### `--pin bmm=X`가 아무 것도 하지 않음
|
||||
|
||||
bmm은 번들 모듈입니다. `--pin`과 `--next=`가 적용되지 않습니다. 사전 릴리스 core/bmm을 원하면 `npx bmad-method@next install`을 사용하거나 bmad-bmm 저장소를 체크아웃하고 설치 프로그램을 로컬에서 실행해 아직 릴리스되지 않은 변경을 받으세요.
|
||||
|
|
@ -0,0 +1,181 @@
|
|||
---
|
||||
title: '커스텀 및 커뮤니티 모듈 설치'
|
||||
description: 커뮤니티 레지스트리, Git 저장소, 로컬 경로에서 서드파티 모듈을 설치합니다
|
||||
sidebar:
|
||||
order: 3
|
||||
---
|
||||
|
||||
BMad 설치 프로그램을 사용해 커뮤니티 레지스트리, 서드파티 Git 저장소, 로컬 파일 경로에서 모듈을 추가하세요.
|
||||
|
||||
## 사용 시점
|
||||
|
||||
- BMad 레지스트리에서 커뮤니티 기여 모듈을 설치합니다
|
||||
- 서드파티 Git 저장소(GitHub, GitLab, Bitbucket, 자체 호스팅)에서 모듈을 설치합니다
|
||||
- BMad 빌더로 로컬에서 개발 중인 모듈을 테스트합니다
|
||||
- 비공개 또는 자체 호스팅 Git 서버에서 모듈을 설치합니다
|
||||
|
||||
:::note[필수 조건]
|
||||
[Node.js](https://nodejs.org) v20+와 `npx`(npm에 포함)가 필요합니다. 커스텀 및 커뮤니티 모듈은 새 설치 중 선택하거나 기존 설치에 추가할 수 있습니다.
|
||||
:::
|
||||
|
||||
## 커뮤니티 모듈
|
||||
|
||||
커뮤니티 모듈은 [BMad 플러그인 마켓플레이스](https://github.com/bmad-code-org/bmad-plugins-marketplace)에서 선별됩니다. 카테고리별로 구성되고 안전을 위해 승인된 커밋에 고정됩니다.
|
||||
|
||||
### 1. 설치 프로그램 실행
|
||||
|
||||
```bash
|
||||
npx bmad-method install
|
||||
```
|
||||
|
||||
### 2. 커뮤니티 카탈로그 둘러보기
|
||||
|
||||
공식 모듈을 선택한 뒤 설치 프로그램이 묻습니다.
|
||||
|
||||
```
|
||||
Would you like to browse community modules?
|
||||
```
|
||||
|
||||
카탈로그 브라우저로 들어가려면 **Yes**를 선택하세요. 할 수 있는 일은 다음과 같습니다.
|
||||
|
||||
- 카테고리별 탐색
|
||||
- 추천 모듈 보기
|
||||
- 사용 가능한 모든 모듈 보기
|
||||
- 키워드로 검색
|
||||
|
||||
### 3. 모듈 선택
|
||||
|
||||
어떤 카테고리에서든 모듈을 선택하세요. 설치 프로그램은 설명, 버전, 신뢰 등급을 보여줍니다. 이미 설치된 모듈은 업데이트 대상으로 미리 체크됩니다.
|
||||
|
||||
### 4. 설치 계속
|
||||
|
||||
커뮤니티 모듈을 선택하면 설치 프로그램은 커스텀 소스, 도구/IDE 설정, 나머지 설치 흐름으로 이어집니다.
|
||||
|
||||
## 커스텀 소스(Git URL과 로컬 경로)
|
||||
|
||||
커스텀 모듈은 어떤 Git 저장소나 로컬 디렉터리에서든 올 수 있습니다. 설치 프로그램은 소스를 해석하고 모듈 구조를 분석한 뒤 다른 모듈 옆에 설치합니다.
|
||||
|
||||
### 대화형 설치
|
||||
|
||||
설치 중 커뮤니티 모듈 단계 이후 설치 프로그램이 묻습니다.
|
||||
|
||||
```
|
||||
Would you like to install from a custom source (Git URL or local path)?
|
||||
```
|
||||
|
||||
**Yes**를 선택한 뒤 소스를 제공합니다.
|
||||
|
||||
| 입력 유형 | 예시 |
|
||||
| --- | --- |
|
||||
| HTTPS URL(모든 호스트) | `https://github.com/org/repo` |
|
||||
| HTTP URL(모든 호스트) | `http://host/org/repo` |
|
||||
| 하위 디렉터리가 있는 HTTPS URL | `https://github.com/org/repo/tree/main/my-module` |
|
||||
| SSH URL | `git@github.com:org/repo.git` |
|
||||
| 로컬 경로 | `/Users/me/projects/my-module` |
|
||||
| 틸드가 있는 로컬 경로 | `~/projects/my-module` |
|
||||
|
||||
설치 프로그램은 저장소를 복제(URL인 경우)하거나 디스크에서 직접 읽은 뒤(로컬 경로인 경우), 발견된 모듈을 선택할 수 있게 보여줍니다.
|
||||
|
||||
### 비대화형 설치
|
||||
|
||||
명령줄에서 커스텀 모듈을 설치하려면 `--custom-source` 플래그를 사용하세요.
|
||||
|
||||
```bash
|
||||
npx bmad-method install \
|
||||
--directory . \
|
||||
--custom-source /path/to/my-module \
|
||||
--tools claude-code \
|
||||
--yes
|
||||
```
|
||||
|
||||
`--modules` 없이 `--custom-source`를 제공하면 core와 커스텀 모듈만 설치됩니다. 공식 모듈도 포함하려면 `--modules`를 추가하세요.
|
||||
|
||||
```bash
|
||||
npx bmad-method install \
|
||||
--directory . \
|
||||
--modules bmm \
|
||||
--custom-source https://gitlab.com/myorg/my-module \
|
||||
--tools claude-code \
|
||||
--yes
|
||||
```
|
||||
|
||||
여러 소스는 쉼표로 구분할 수 있습니다.
|
||||
|
||||
```bash
|
||||
--custom-source /path/one,https://github.com/org/repo,/path/two
|
||||
```
|
||||
|
||||
## 모듈 발견 방식
|
||||
|
||||
설치 프로그램은 소스에서 설치 가능한 모듈을 찾기 위해 두 모드를 사용합니다.
|
||||
|
||||
| 모드 | 트리거 | 동작 |
|
||||
| --- | --- | --- |
|
||||
| `Discovery` | 소스에 `.claude-plugin/marketplace.json`이 있습니다 | 매니페스트의 모든 플러그인을 나열하고 설치할 항목을 선택하게 합니다 |
|
||||
| `Direct` | marketplace.json이 없습니다 | 디렉터리에서 스킬(`SKILL.md`가 있는 하위 디렉터리)을 스캔하고 단일 모듈로 해석합니다 |
|
||||
|
||||
`Discovery` 모드는 게시된 모듈에 일반적입니다. `Direct` 모드는 로컬 개발 중 스킬 디렉터리를 가리킬 때 편리합니다.
|
||||
|
||||
:::note[`.claude-plugin/`에 대해]
|
||||
`.claude-plugin/marketplace.json` 경로는 여러 AI 도구 설치 프로그램에서 플러그인 발견을 위해 채택한 표준 관례입니다. Claude가 필요하지 않고 Claude API를 사용하지 않으며 어떤 AI 도구를 쓰는지에 영향을 주지 않습니다. 이 파일이 있는 모듈은 관례를 따르는 모든 설치 프로그램에서 발견될 수 있습니다.
|
||||
:::
|
||||
|
||||
## 로컬 개발 워크플로
|
||||
|
||||
[BMad 빌더](https://github.com/bmad-code-org/bmad-builder)로 모듈을 만들고 있다면 작업 디렉터리에서 직접 설치할 수 있습니다.
|
||||
|
||||
```bash
|
||||
npx bmad-method install \
|
||||
--directory ~/my-project \
|
||||
--custom-source ~/my-module-repo/skills \
|
||||
--tools claude-code \
|
||||
--yes
|
||||
```
|
||||
|
||||
로컬 소스는 캐시에 복사되지 않고 경로로 참조됩니다. 모듈 소스를 업데이트하고 다시 설치하면 설치 프로그램이 최신 변경을 가져옵니다.
|
||||
|
||||
:::caution[소스 제거]
|
||||
설치 후 로컬 소스 디렉터리를 삭제해도 `_bmad/`에 설치된 모듈 파일은 보존됩니다. 소스 경로가 복원될 때까지 업데이트 중 해당 모듈은 건너뜁니다.
|
||||
:::
|
||||
|
||||
## 얻는 결과
|
||||
|
||||
설치 후 커스텀 모듈은 공식 모듈과 함께 `_bmad/`에 나타납니다.
|
||||
|
||||
```
|
||||
your-project/
|
||||
├── _bmad/
|
||||
│ ├── core/ # 내장 core 모듈
|
||||
│ ├── bmm/ # 공식 모듈(선택한 경우)
|
||||
│ ├── my-module/ # 커스텀 모듈
|
||||
│ │ ├── my-skill/
|
||||
│ │ │ └── SKILL.md
|
||||
│ │ └── module-help.csv
|
||||
│ └── _config/
|
||||
│ └── manifest.yaml # 모든 모듈, 버전, 소스를 추적
|
||||
└── ...
|
||||
```
|
||||
|
||||
매니페스트는 각 커스텀 모듈의 소스(Git 소스는 `repoUrl`, 로컬 소스는 `localPath`)를 기록하여 `Quick Update`가 소스를 다시 찾을 수 있게 합니다.
|
||||
|
||||
## 커스텀 모듈 업데이트
|
||||
|
||||
커스텀 모듈도 일반 업데이트 흐름에 참여합니다.
|
||||
|
||||
- **Quick Update**(`--action quick-update`): 모든 모듈을 원래 소스에서 새로 고칩니다. Git 기반 모듈은 다시 가져오고 로컬 모듈은 소스 경로에서 다시 읽힙니다.
|
||||
- **전체 업데이트**: 모듈 선택을 다시 실행해 커스텀 모듈을 추가하거나 제거할 수 있습니다.
|
||||
|
||||
## 직접 모듈 만들기
|
||||
|
||||
다른 사람이 설치할 수 있는 모듈을 만들려면 [BMad 빌더](https://github.com/bmad-code-org/bmad-builder)를 사용하세요.
|
||||
|
||||
1. `bmad-module-builder`를 실행해 모듈 초기 구조를 생성합니다
|
||||
2. 여러 BMad 빌더 도구로 스킬, 에이전트, 워크플로를 추가합니다
|
||||
3. Git 저장소에 게시하거나 폴더 컬렉션을 공유합니다
|
||||
4. 다른 사용자는 `--custom-source <your-repo-url>`로 설치합니다
|
||||
|
||||
모듈이 발견 모드를 지원하려면 저장소 루트에 `.claude-plugin/marketplace.json`을 포함하세요(Claude 전용이 아닌 도구 간 관례입니다). marketplace.json 형식은 [BMad 빌더 문서](https://github.com/bmad-code-org/bmad-builder)를 참고하세요.
|
||||
|
||||
:::tip[먼저 로컬에서 테스트]
|
||||
개발 중에는 Git 저장소에 게시하기 전에 로컬 경로로 모듈을 설치해 빠르게 반복하세요.
|
||||
:::
|
||||
|
|
@ -0,0 +1,10 @@
|
|||
---
|
||||
title: 비대화형 설치
|
||||
description: 비대화형 / CI 설치 문서가 이동되었습니다
|
||||
sidebar:
|
||||
order: 2
|
||||
---
|
||||
|
||||
:::note[이 페이지는 이동되었습니다]
|
||||
비대화형 및 CI 설치 플래그, 채널 선택, 버전 고정은 통합된 [BMad 설치 방법](./install-bmad.md) 가이드로 이동했습니다. 플래그 참조와 바로 복사해 쓸 수 있는 예시는 [비대화형 CI](./install-bmad.md#headless-ci) 섹션에서 확인하세요.
|
||||
:::
|
||||
|
|
@ -0,0 +1,132 @@
|
|||
---
|
||||
title: '프로젝트 컨텍스트 관리'
|
||||
description: AI 에이전트를 안내하는 project-context.md를 만들고 유지합니다
|
||||
sidebar:
|
||||
order: 10
|
||||
---
|
||||
|
||||
`project-context.md` 파일을 사용해 모든 워크플로에서 AI 에이전트가 프로젝트의 기술 선호도와 구현 규칙을 따르게 하세요. 이 파일을 항상 참고하게 하려면 도구 컨텍스트나 항상 적용되는 규칙 파일(예: `AGENTS.md`)에 `중요한 프로젝트 컨텍스트와 관례는 [프로젝트 컨텍스트 경로]/project-context.md에 있습니다`라는 줄을 추가할 수도 있습니다.
|
||||
|
||||
:::note[필수 조건]
|
||||
|
||||
- BMad Method 설치
|
||||
- 프로젝트의 기술 스택과 규칙에 대한 이해
|
||||
:::
|
||||
|
||||
## 사용 시점
|
||||
|
||||
- 아키텍처를 시작하기 전에 강한 기술 선호도가 있습니다
|
||||
- 아키텍처를 완료했고 구현 결정을 포착하고 싶습니다
|
||||
- 이미 확립된 패턴이 있는 기존 코드베이스에서 작업합니다
|
||||
- 스토리마다 에이전트가 일관되지 않은 결정을 내리는 문제가 보입니다
|
||||
|
||||
## 1단계: 접근 방식 선택
|
||||
|
||||
**수동 작성** - 문서화할 규칙을 정확히 알고 있을 때 가장 좋습니다
|
||||
|
||||
**아키텍처 후 생성** - 솔루션 설계 중 내려진 결정을 포착할 때 가장 좋습니다
|
||||
|
||||
**기존 프로젝트용 생성** - 기존 코드베이스의 패턴을 발견할 때 가장 좋습니다
|
||||
|
||||
## 2단계: 파일 만들기
|
||||
|
||||
### 옵션 A: 수동 작성
|
||||
|
||||
`_bmad-output/project-context.md`에 파일을 만듭니다.
|
||||
|
||||
```bash
|
||||
mkdir -p _bmad-output
|
||||
touch _bmad-output/project-context.md
|
||||
```
|
||||
|
||||
기술 스택과 구현 규칙을 추가합니다.
|
||||
|
||||
```markdown
|
||||
---
|
||||
project_name: '내프로젝트'
|
||||
user_name: '사용자이름'
|
||||
date: '2026-02-15'
|
||||
sections_completed: ['technology_stack', 'critical_rules']
|
||||
---
|
||||
|
||||
# AI 에이전트용 프로젝트 컨텍스트
|
||||
|
||||
## 기술 스택과 버전
|
||||
|
||||
- Node.js 20.x, TypeScript 5.3, React 18.2
|
||||
- 상태 관리: Zustand
|
||||
- 테스트: Vitest, Playwright
|
||||
- 스타일링: Tailwind CSS
|
||||
|
||||
## 중요한 구현 규칙
|
||||
|
||||
**TypeScript:**
|
||||
|
||||
- 엄격 모드 사용, `any` 타입 금지
|
||||
- 공개 API에는 `interface`, 유니언에는 `type` 사용
|
||||
|
||||
**코드 구성:**
|
||||
|
||||
- 컴포넌트는 `/src/components/`에 두고 테스트를 함께 배치
|
||||
- API 호출은 `apiClient` 싱글턴 사용 - 직접 fetch 금지
|
||||
|
||||
**테스트:**
|
||||
|
||||
- 단위 테스트는 비즈니스 로직에 집중
|
||||
- 통합 테스트는 MSW로 API를 모킹
|
||||
```
|
||||
|
||||
### 옵션 B: 아키텍처 후 생성
|
||||
|
||||
새 채팅에서 워크플로를 실행합니다.
|
||||
|
||||
```bash
|
||||
bmad-generate-project-context
|
||||
```
|
||||
|
||||
워크플로는 아키텍처 문서와 프로젝트 파일을 스캔해 내려진 결정을 담은 컨텍스트 파일을 생성합니다.
|
||||
|
||||
### 옵션 C: 기존 프로젝트용 생성
|
||||
|
||||
기존 프로젝트에서는 다음을 실행합니다.
|
||||
|
||||
```bash
|
||||
bmad-generate-project-context
|
||||
```
|
||||
|
||||
워크플로가 코드베이스를 분석해 규칙을 식별한 뒤 검토하고 다듬을 수 있는 컨텍스트 파일을 생성합니다.
|
||||
|
||||
## 3단계: 내용 확인
|
||||
|
||||
생성된 파일을 검토하고 다음이 담겨 있는지 확인하세요.
|
||||
|
||||
- 올바른 기술 버전
|
||||
- 실제 관례(일반적인 모범 사례가 아님)
|
||||
- 흔한 실수를 예방하는 규칙
|
||||
- 프레임워크별 패턴
|
||||
|
||||
누락된 내용은 수동으로 추가하고 부정확한 내용은 제거하세요.
|
||||
|
||||
## 얻는 결과
|
||||
|
||||
`project-context.md` 파일은 다음을 제공합니다.
|
||||
|
||||
- 모든 에이전트가 같은 규칙을 따르게 합니다
|
||||
- 스토리 간 일관되지 않은 결정을 방지합니다
|
||||
- 구현을 위한 아키텍처 결정을 포착합니다
|
||||
- 프로젝트 패턴과 규칙의 참조 자료가 됩니다
|
||||
|
||||
## 팁
|
||||
|
||||
:::tip[모범 사례]
|
||||
|
||||
- **겉으로 잘 드러나지 않는 것에 집중하세요** - "의미 있는 변수명을 사용하라" 같은 보편 규칙보다 "모든 공개 클래스에는 JSDoc을 사용하라"처럼 에이전트가 놓칠 수 있는 패턴을 문서화합니다.
|
||||
- **간결하게 유지하세요** - 이 파일은 모든 구현 워크플로에서 로드됩니다. 긴 파일은 컨텍스트를 낭비합니다. 좁은 범위나 특정 스토리에만 적용되는 내용은 제외하세요.
|
||||
- **필요할 때 업데이트하세요** - 패턴이 바뀌면 수동으로 수정하거나 큰 아키텍처 변경 후 다시 생성하세요.
|
||||
- 빠른 흐름과 전체 BMad Method 프로젝트 모두에 사용할 수 있습니다.
|
||||
:::
|
||||
|
||||
## 다음 단계
|
||||
|
||||
- [**프로젝트 컨텍스트 설명**](../explanation/project-context.md) - 작동 방식을 더 알아보기
|
||||
- [**워크플로 맵**](../reference/workflow-map.md) - 어떤 워크플로가 프로젝트 컨텍스트를 로드하는지 보기
|
||||
|
|
@ -0,0 +1,96 @@
|
|||
---
|
||||
title: '빠른 수정'
|
||||
description: 빠른 수정과 임시 변경을 수행하는 방법
|
||||
sidebar:
|
||||
order: 6
|
||||
---
|
||||
|
||||
전체 BMad Method가 필요하지 않은 버그 수정, 리팩터링, 작은 목표 변경에는 **빠른 개발**을 사용하세요.
|
||||
|
||||
## 사용 시점
|
||||
|
||||
- 원인이 명확하고 알려진 버그 수정
|
||||
- 몇 개 파일 안에 제한된 작은 리팩터링(이름 변경, 추출, 구조 변경)
|
||||
- 작은 기능 조정이나 설정 변경
|
||||
- 의존성 업데이트
|
||||
|
||||
:::note[필수 조건]
|
||||
|
||||
- BMad Method 설치(`npx bmad-method install`)
|
||||
- AI 기반 IDE(Claude Code, Cursor 또는 유사 도구)
|
||||
:::
|
||||
|
||||
## 단계
|
||||
|
||||
### 1. 새 채팅 시작
|
||||
|
||||
AI IDE에서 **새 채팅 세션**을 엽니다. 이전 워크플로 세션을 재사용하면 컨텍스트 충돌이 생길 수 있습니다.
|
||||
|
||||
### 2. 의도 전달
|
||||
|
||||
빠른 개발은 호출 전, 호출과 함께, 또는 호출 후에 자유 형식 의도를 받을 수 있습니다. 예를 들면 다음과 같습니다.
|
||||
|
||||
```text
|
||||
run quick-dev - 빈 비밀번호를 허용하는 로그인 검증 버그를 수정해 줘.
|
||||
```
|
||||
|
||||
```text
|
||||
run quick-dev - https://github.com/org/repo/issues/42 를 수정해 줘
|
||||
```
|
||||
|
||||
```text
|
||||
run quick-dev - _bmad-output/implementation-artifacts/my-intent.md의 의도를 구현해 줘
|
||||
```
|
||||
|
||||
```text
|
||||
문제는 인증 미들웨어에 있는 것 같아요. 토큰 만료를 확인하지 않습니다.
|
||||
확인해 보니 src/auth/middleware.ts 47번째 줄에서 exp 확인을 완전히 건너뜁니다.
|
||||
run quick-dev
|
||||
```
|
||||
|
||||
```text
|
||||
run quick-dev
|
||||
> 무엇을 하고 싶나요?
|
||||
UserService가 콜백 대신 async/await를 사용하도록 리팩터링해 줘.
|
||||
```
|
||||
|
||||
일반 텍스트, 파일 경로, GitHub 이슈 URL, 버그 트래커 링크 등 LLM이 구체적 의도로 해석할 수 있는 것이면 됩니다.
|
||||
|
||||
### 3. 질문에 답하고 승인
|
||||
|
||||
빠른 개발은 구현 전에 명확화 질문을 하거나 짧은 사양을 제시해 승인을 요청할 수 있습니다. 질문에 답하고 계획이 만족스러우면 승인하세요.
|
||||
|
||||
### 4. 리뷰하고 푸시
|
||||
|
||||
빠른 개발이 변경을 구현하고, 자체 리뷰하고, 문제를 패치하고, 로컬에 커밋합니다. 완료되면 영향을 받은 파일을 에디터에서 엽니다.
|
||||
|
||||
- diff를 훑어 변경이 의도와 맞는지 확인합니다
|
||||
- 이상한 점이 있으면 에이전트에게 수정할 내용을 말하세요. 같은 세션에서 반복할 수 있습니다
|
||||
|
||||
만족하면 커밋을 푸시하세요. 빠른 개발이 푸시와 PR 생성을 제안합니다.
|
||||
|
||||
:::caution[문제가 생기면]
|
||||
푸시한 변경이 예상치 못한 문제를 일으키면 `git revert HEAD`로 마지막 커밋을 깔끔하게 되돌리세요. 그런 다음 새 채팅을 시작하고 빠른 개발을 다시 실행해 다른 접근을 시도합니다.
|
||||
:::
|
||||
|
||||
## 얻는 결과
|
||||
|
||||
- 수정 또는 리팩터링이 적용된 소스 파일
|
||||
- 테스트 스위트가 있다면 통과하는 테스트
|
||||
- Conventional Commit 형식의 푸시 준비 완료 커밋
|
||||
|
||||
## 보류 작업
|
||||
|
||||
빠른 개발은 각 실행을 하나의 목표에 집중하게 합니다. 요청에 여러 독립 목표가 있거나 리뷰에서 변경과 무관한 기존 문제가 드러나면, 모든 것을 한 번에 처리하지 않고 구현 산출물 디렉터리의 `deferred-work.md` 파일에 따로 보류합니다.
|
||||
|
||||
실행 후 이 파일을 확인하세요. 나중에 다시 볼 작업 백로그입니다. 각 보류 항목은 이후 새 빠른 개발 실행에 넣을 수 있습니다.
|
||||
|
||||
## 정식 계획으로 업그레이드할 때
|
||||
|
||||
다음과 같다면 전체 BMad Method 사용을 고려하세요.
|
||||
|
||||
- 변경이 여러 시스템에 영향을 주거나 많은 파일의 조율된 업데이트가 필요합니다
|
||||
- 범위를 확신하지 못해 먼저 요구사항 발견이 필요합니다
|
||||
- 팀을 위해 문서나 아키텍처 결정을 기록해야 합니다
|
||||
|
||||
빠른 개발이 BMad Method와 어떻게 맞물리는지는 [빠른 개발](../explanation/quick-dev.md)을 참고하세요.
|
||||
|
|
@ -0,0 +1,78 @@
|
|||
---
|
||||
title: '문서 샤딩 가이드'
|
||||
description: 큰 Markdown 파일을 더 작고 정리된 파일로 나눠 컨텍스트 관리를 개선합니다
|
||||
sidebar:
|
||||
order: 11
|
||||
---
|
||||
|
||||
큰 Markdown 파일을 더 작고 정리된 파일로 나눠 컨텍스트 관리를 개선해야 한다면 `bmad-shard-doc` 도구를 사용하세요.
|
||||
|
||||
:::caution[지원 중단]
|
||||
이 방식은 더 이상 권장되지 않습니다. 업데이트된 워크플로와 대부분의 주요 LLM 및 도구가 하위 프로세스를 지원하게 되면 곧 필요 없어질 것입니다.
|
||||
:::
|
||||
|
||||
## 사용 시점
|
||||
|
||||
선택한 도구/모델 조합이 필요한 모든 문서를 입력으로 로드하고 읽지 못한다는 것을 확인한 경우에만 사용하세요.
|
||||
|
||||
## 문서 샤딩이란?
|
||||
|
||||
문서 샤딩은 큰 Markdown 파일을 2단계 제목(`## 제목`)을 기준으로 더 작고 정리된 파일로 나눕니다.
|
||||
|
||||
### 아키텍처
|
||||
|
||||
```text
|
||||
샤딩 전:
|
||||
_bmad-output/planning-artifacts/
|
||||
└── PRD.md (큰 50k 토큰 파일)
|
||||
|
||||
샤딩 후:
|
||||
_bmad-output/planning-artifacts/
|
||||
└── prd/
|
||||
├── index.md # 설명이 있는 목차
|
||||
├── overview.md # 섹션 1
|
||||
├── user-requirements.md # 섹션 2
|
||||
├── technical-requirements.md # 섹션 3
|
||||
└── ... # 추가 섹션
|
||||
```
|
||||
|
||||
## 단계
|
||||
|
||||
### 1. 문서 샤딩 도구 실행
|
||||
|
||||
```bash
|
||||
/bmad-shard-doc
|
||||
```
|
||||
|
||||
### 2. 대화형 과정 따르기
|
||||
|
||||
```text
|
||||
에이전트: 어떤 문서를 샤딩할까요?
|
||||
사용자: docs/PRD.md
|
||||
|
||||
에이전트: 기본 대상: docs/prd/
|
||||
기본값을 사용할까요? [y/n]
|
||||
사용자: y
|
||||
|
||||
에이전트: PRD.md를 샤딩하는 중...
|
||||
✓ 섹션 파일 12개 생성
|
||||
✓ index.md 생성
|
||||
✓ 완료!
|
||||
```
|
||||
|
||||
## 워크플로 발견 방식
|
||||
|
||||
BMad 워크플로는 **이중 발견 시스템**을 사용합니다.
|
||||
|
||||
1. **먼저 전체 문서 시도** - `document-name.md`를 찾습니다
|
||||
2. **샤딩된 버전 확인** - `document-name/index.md`를 찾습니다
|
||||
3. **우선순위 규칙** - 둘 다 있으면 전체 문서가 우선합니다. 샤딩된 버전을 사용하려면 전체 문서를 제거하세요
|
||||
|
||||
## 워크플로 지원
|
||||
|
||||
모든 BMM 워크플로는 두 형식을 모두 지원합니다.
|
||||
|
||||
- 전체 문서
|
||||
- 샤딩된 문서
|
||||
- 자동 감지
|
||||
- 사용자에게 투명하게 동작
|
||||
|
|
@ -0,0 +1,101 @@
|
|||
---
|
||||
title: 'v6로 업그레이드하는 방법'
|
||||
description: BMad v4에서 v6로 마이그레이션합니다
|
||||
sidebar:
|
||||
order: 4
|
||||
---
|
||||
|
||||
BMad 설치 프로그램을 사용해 v4에서 v6로 업그레이드하세요. 레거시 설치 자동 감지와 마이그레이션 지원이 포함되어 있습니다.
|
||||
|
||||
## 사용 시점
|
||||
|
||||
- BMad v4가 설치되어 있습니다(`.bmad-method` 폴더)
|
||||
- 새 v6 아키텍처로 마이그레이션하고 싶습니다
|
||||
- 보존해야 할 기존 계획 산출물이 있습니다
|
||||
|
||||
:::note[필수 조건]
|
||||
|
||||
- Node.js 20+
|
||||
- 기존 BMad v4 설치
|
||||
:::
|
||||
|
||||
## 단계
|
||||
|
||||
### 1. 설치 프로그램 실행
|
||||
|
||||
[설치 프로그램 안내](./install-bmad.md)를 따르세요.
|
||||
|
||||
### 2. 레거시 설치 처리
|
||||
|
||||
v4가 감지되면 다음 중 선택할 수 있습니다.
|
||||
|
||||
- 설치 프로그램이 `.bmad-method`를 백업하고 제거하게 합니다
|
||||
- 종료한 뒤 수동으로 정리합니다
|
||||
|
||||
BMad Method 폴더 이름을 다르게 지정했다면 직접 폴더를 제거해야 합니다.
|
||||
|
||||
### 3. IDE 스킬 정리
|
||||
|
||||
레거시 v4 IDE 명령/스킬을 수동으로 제거하세요. 예를 들어 Claude Code를 사용한다면 bmad로 시작하는 중첩 폴더를 찾아 제거합니다.
|
||||
|
||||
- `.claude/commands/`
|
||||
|
||||
새 v6 스킬은 다음 위치에 설치됩니다.
|
||||
|
||||
- `.claude/skills/`
|
||||
|
||||
### 4. 계획 산출물 마이그레이션
|
||||
|
||||
**계획 문서(제품 개요/PRD/UX/아키텍처)가 있다면:**
|
||||
|
||||
설명적인 이름으로 `_bmad-output/planning-artifacts/`에 옮기세요.
|
||||
|
||||
- PRD 문서는 파일명에 `PRD`를 포함합니다
|
||||
- 파일 유형에 맞게 `brief`, `architecture`, `ux-design`을 포함합니다
|
||||
- 샤딩된 문서는 이름 있는 하위 폴더에 둘 수 있습니다
|
||||
|
||||
**계획 도중이라면:** v6 워크플로로 다시 시작하는 것을 고려하세요. 기존 문서를 입력으로 사용할 수 있습니다. 웹 검색과 IDE 계획 모드를 활용하는 새 점진적 발견 워크플로가 더 좋은 결과를 만듭니다.
|
||||
|
||||
### 5. 진행 중인 개발 마이그레이션
|
||||
|
||||
이미 생성 또는 구현된 스토리가 있다면:
|
||||
|
||||
1. v6 설치를 완료합니다
|
||||
2. `epics.md` 또는 `epics/epic*.md`를 `_bmad-output/planning-artifacts/`에 둡니다
|
||||
3. 개발자의 `bmad-sprint-planning` 워크플로를 실행합니다
|
||||
4. 이미 완료된 에픽/스토리를 에이전트에게 알려줍니다
|
||||
|
||||
## 얻는 결과
|
||||
|
||||
**v6 통합 구조:**
|
||||
|
||||
```text
|
||||
your-project/
|
||||
├── _bmad/ # 단일 설치 폴더
|
||||
│ ├── _config/ # 커스터마이징
|
||||
│ │ └── agents/ # 에이전트 커스터마이징 파일
|
||||
│ ├── core/ # 범용 core 프레임워크
|
||||
│ ├── bmm/ # BMad Method 모듈
|
||||
│ ├── bmb/ # BMad 빌더
|
||||
│ └── cis/ # 창의적 지능 제품군
|
||||
└── _bmad-output/ # 출력 폴더(v4의 문서 폴더)
|
||||
```
|
||||
|
||||
## 모듈 마이그레이션
|
||||
|
||||
| v4 모듈 | v6 상태 |
|
||||
| --- | --- |
|
||||
| `.bmad-2d-phaser-game-dev` | BMGD 모듈에 통합 |
|
||||
| `.bmad-2d-unity-game-dev` | BMGD 모듈에 통합 |
|
||||
| `.bmad-godot-game-dev` | BMGD 모듈에 통합 |
|
||||
| `.bmad-infrastructure-devops` | 지원 중단 - 새 DevOps 에이전트 예정 |
|
||||
| `.bmad-creative-writing` | 아직 적용되지 않음 - 새 v6 모듈 예정 |
|
||||
|
||||
## 주요 변경 사항
|
||||
|
||||
| 개념 | v4 | v6 |
|
||||
| --- | --- | --- |
|
||||
| **코어** | `_bmad-core`는 실제로 BMad Method였습니다 | `_bmad/core/`는 범용 프레임워크입니다 |
|
||||
| **메서드** | `_bmad-method` | `_bmad/bmm/` |
|
||||
| **설정** | 파일을 직접 수정 | 모듈별 `config.yaml` |
|
||||
| **문서** | 샤딩 또는 비샤딩 필수 설정 | 완전히 유연하며 자동 스캔 |
|
||||
|
|
@ -0,0 +1,60 @@
|
|||
---
|
||||
title: BMad Method에 오신 것을 환영합니다
|
||||
description: 전문 에이전트, 안내형 워크플로, 지능형 계획을 제공하는 AI 기반 개발 프레임워크
|
||||
---
|
||||
|
||||
BMad Method(**B**uild **M**ore **A**rchitect **D**reams)는 BMad Method 생태계에 속한 AI 기반 개발 프레임워크입니다. 아이디어 구상과 계획부터 에이전트 기반 구현까지 소프트웨어 개발 전 과정을 돕습니다. 버그 수정부터 엔터프라이즈 플랫폼 구축까지, 프로젝트 복잡도에 맞춰 전문 AI 에이전트, 안내형 워크플로, 지능형 계획을 제공합니다.
|
||||
|
||||
Claude, Cursor, GitHub Copilot 같은 AI 코딩 어시스턴트로 작업하는 데 익숙하다면 바로 시작할 준비가 된 것입니다.
|
||||
|
||||
:::note[V6가 출시되었습니다. 이제 시작입니다.]
|
||||
스킬 아키텍처, BMad Builder v1, Dev Loop Automation 등 훨씬 많은 기능이 준비 중입니다. [**로드맵 보기**](/ko-kr/roadmap/)
|
||||
:::
|
||||
|
||||
## 처음이라면 튜토리얼부터 시작하세요
|
||||
|
||||
BMad를 가장 빠르게 이해하는 방법은 직접 써보는 것입니다.
|
||||
|
||||
- **[BMad 시작하기](./tutorials/getting-started.md)** - BMad를 설치하고 작동 방식을 이해합니다
|
||||
- **[워크플로 맵](./reference/workflow-map.md)** - BMM 단계, 워크플로, 컨텍스트 관리를 한눈에 보여줍니다
|
||||
|
||||
:::tip[바로 시작하고 싶나요?]
|
||||
BMad를 설치하고 `bmad-help` 스킬을 사용하세요. 프로젝트와 설치된 모듈에 맞춰 모든 과정을 안내합니다.
|
||||
:::
|
||||
|
||||
## 이 문서를 사용하는 방법
|
||||
|
||||
이 문서는 하려는 일에 따라 네 가지 섹션으로 구성되어 있습니다.
|
||||
|
||||
| 섹션 | 목적 |
|
||||
| --- | --- |
|
||||
| **튜토리얼** | 학습 중심입니다. 무언가를 만들어 보며 따라가는 단계별 가이드입니다. 처음이라면 여기서 시작하세요. |
|
||||
| **사용 가이드** | 작업 중심입니다. 특정 문제를 해결하기 위한 실용 가이드입니다. "에이전트를 어떻게 커스터마이즈하지?" 같은 질문을 여기서 다룹니다. |
|
||||
| **개념 설명** | 이해 중심입니다. 개념과 아키텍처를 깊게 설명합니다. *왜* 그런지 알고 싶을 때 읽으세요. |
|
||||
| **참조** | 정보 중심입니다. 에이전트, 워크플로, 설정에 대한 기술 사양입니다. |
|
||||
|
||||
## 확장과 커스터마이징
|
||||
|
||||
직접 만든 에이전트, 워크플로, 모듈로 BMad를 확장하고 싶나요? [**BMad Builder**](https://bmad-builder-docs.bmad-method.org/)는 BMad에 새 기능을 더하거나 완전히 새로운 모듈을 만들 수 있는 프레임워크와 도구를 제공합니다.
|
||||
|
||||
## 필요한 것
|
||||
|
||||
BMad는 커스텀 시스템 프롬프트나 프로젝트 컨텍스트를 지원하는 AI 코딩 어시스턴트라면 무엇이든 함께 사용할 수 있습니다. 널리 쓰이는 선택지는 다음과 같습니다.
|
||||
|
||||
- **[Claude Code](https://code.claude.com)** - Anthropic의 CLI 도구(권장)
|
||||
- **[Cursor](https://cursor.sh)** - AI 우선 코드 에디터
|
||||
- **[Codex CLI](https://github.com/openai/codex)** - OpenAI의 터미널 코딩 에이전트
|
||||
|
||||
버전 관리, 프로젝트 구조, 애자일 워크플로 같은 기본 소프트웨어 개발 개념에 익숙하면 좋습니다. BMad 스타일의 에이전트 시스템 경험은 없어도 됩니다. 이 문서가 그 시작점이 되어 줍니다.
|
||||
|
||||
## 커뮤니티 참여
|
||||
|
||||
도움을 받고, 만들고 있는 것을 공유하고, BMad에 기여하세요.
|
||||
|
||||
- **[Discord](https://discord.gg/gk8jAdXWmj)** - 다른 BMad 사용자와 대화하고 질문하고 아이디어를 공유합니다
|
||||
- **[GitHub](https://github.com/bmad-code-org/BMAD-METHOD)** - 소스 코드, 이슈, 기여
|
||||
- **[YouTube](https://www.youtube.com/@BMadCode)** - 영상 튜토리얼과 워크스루
|
||||
|
||||
## 다음 단계
|
||||
|
||||
시작할 준비가 되었나요? [**BMad 시작하기**](./tutorials/getting-started.md)를 열고 첫 프로젝트를 만들어 보세요.
|
||||
|
|
@ -0,0 +1,55 @@
|
|||
---
|
||||
title: 에이전트
|
||||
description: 기본 BMM 에이전트와 스킬 ID, 메뉴 트리거, 주요 워크플로
|
||||
sidebar:
|
||||
order: 2
|
||||
---
|
||||
|
||||
## 기본 에이전트
|
||||
|
||||
이 페이지는 BMad Method와 함께 설치되는 기본 BMM(애자일 제품군) 에이전트를 스킬 ID, 메뉴 트리거, 주요 워크플로와 함께 나열합니다. 각 에이전트는 스킬로 호출됩니다.
|
||||
|
||||
## 참고
|
||||
|
||||
- 각 에이전트는 설치 프로그램이 생성하는 스킬로 제공됩니다. 스킬 ID(예: `bmad-dev`)를 사용해 에이전트를 호출합니다.
|
||||
- 트리거는 각 에이전트 메뉴에 표시되는 짧은 메뉴 코드(예: `CP`)와 유사 매칭 항목입니다.
|
||||
- QA 테스트 생성은 개발자 에이전트를 통해 사용할 수 있는 `bmad-qa-generate-e2e-tests` 워크플로 스킬이 처리합니다. 전체 테스트 설계자(TEA)는 별도 모듈에 있습니다.
|
||||
|
||||
| 에이전트 | 스킬 ID | 트리거 | 주요 워크플로 |
|
||||
| --- | --- | --- | --- |
|
||||
| 분석가(Mary) | `bmad-analyst` | `BP`, `MR`, `DR`, `TR`, `CB`, `WB`, `DP` | 브레인스토밍, 시장 리서치, 도메인 리서치, 기술 리서치, 개요 작성, PRFAQ 챌린지, 프로젝트 문서화 |
|
||||
| 제품 관리자(John) | `bmad-pm` | `CP`, `VP`, `EP`, `CE`, `IR`, `CC` | PRD 생성/검증/편집, 에픽과 스토리 생성, 구현 준비 상태, 경로 수정 |
|
||||
| 아키텍트(Winston) | `bmad-architect` | `CA`, `IR` | 아키텍처 생성, 구현 준비 상태 |
|
||||
| 개발자(Amelia) | `bmad-agent-dev` | `DS`, `QD`, `QA`, `CR`, `SP`, `CS`, `ER` | 스토리 구현, 빠른 개발, QA 테스트 생성, 코드 리뷰, 스프린트 계획, 스토리 생성, 에픽 회고 |
|
||||
| UX 디자이너(Sally) | `bmad-ux-designer` | `CU` | UX 설계 생성 |
|
||||
| 기술 작성자(Paige) | `bmad-tech-writer` | `DP`, `WD`, `US`, `MG`, `VD`, `EC` | 프로젝트 문서화, 문서 작성, 표준 업데이트, Mermaid 생성, 문서 검증, 개념 설명 |
|
||||
|
||||
## 트리거 유형
|
||||
|
||||
에이전트 메뉴 트리거는 두 가지 호출 방식을 사용합니다. 어떤 유형인지 알면 올바른 입력을 제공하기 쉽습니다.
|
||||
|
||||
### 워크플로 트리거(인수 불필요)
|
||||
|
||||
대부분의 트리거는 구조화된 워크플로 파일을 로드합니다. 트리거 코드를 입력하면 에이전트가 워크플로를 시작하고 각 단계에서 입력을 요청합니다.
|
||||
|
||||
예: `CP`(PRD 생성), `DS`(스토리 구현), `CA`(아키텍처 생성), `QD`(빠른 개발)
|
||||
|
||||
### 대화형 트리거(인수 필요)
|
||||
|
||||
일부 트리거는 구조화된 워크플로 대신 자유 형식 대화를 시작합니다. 트리거 코드와 함께 필요한 내용을 설명해야 합니다.
|
||||
|
||||
| 에이전트 | 트리거 | 제공할 내용 |
|
||||
| --- | --- | --- |
|
||||
| 기술 작성자(Paige) | `WD` | 작성할 문서 설명 |
|
||||
| 기술 작성자(Paige) | `US` | 표준에 추가할 선호 사항 또는 관례 |
|
||||
| 기술 작성자(Paige) | `MG` | 다이어그램 설명과 유형(시퀀스, 플로차트 등) |
|
||||
| 기술 작성자(Paige) | `VD` | 검증할 문서와 집중 영역 |
|
||||
| 기술 작성자(Paige) | `EC` | 설명할 개념 이름 |
|
||||
|
||||
**예시:**
|
||||
|
||||
```text
|
||||
WD 우리 Docker 설정에 대한 배포 가이드를 작성해 줘
|
||||
MG 인증 흐름을 보여 주는 시퀀스 다이어그램을 만들어 줘
|
||||
EC 모듈 시스템이 어떻게 작동하는지 설명해 줘
|
||||
```
|
||||
|
|
@ -0,0 +1,135 @@
|
|||
---
|
||||
title: 스킬
|
||||
description: BMad 스킬의 정의, 작동 방식, 위치에 대한 참조
|
||||
sidebar:
|
||||
order: 4
|
||||
---
|
||||
|
||||
스킬은 IDE 안에서 에이전트를 로드하거나 워크플로를 실행하거나 작업을 처리하는 미리 작성된 프롬프트입니다. BMad 설치 프로그램은 설치 시 선택한 모듈에서 스킬을 생성합니다. 나중에 모듈을 추가, 제거, 변경했다면 설치 프로그램을 다시 실행해 스킬을 동기화하세요([문제 해결](#문제-해결) 참고).
|
||||
|
||||
## 스킬 vs 에이전트 메뉴 트리거
|
||||
|
||||
BMad는 작업을 시작하는 두 가지 방법을 제공하며 목적이 다릅니다.
|
||||
|
||||
| 방식 | 호출 방법 | 일어나는 일 |
|
||||
| --- | --- | --- |
|
||||
| **스킬** | IDE에서 스킬 이름(예: `bmad-help`)을 입력 | 에이전트를 직접 로드하거나 워크플로를 실행하거나 작업을 처리 |
|
||||
| **에이전트 메뉴 트리거** | 에이전트를 먼저 로드한 뒤 짧은 코드(예: `DS`) 입력 | 에이전트가 페르소나를 유지한 채 코드를 해석하고 일치하는 워크플로를 시작 |
|
||||
|
||||
에이전트 메뉴 트리거는 활성 에이전트 세션이 필요합니다. 어떤 워크플로를 원하는지 알고 있다면 스킬을 사용하세요. 이미 에이전트와 작업 중이고 대화를 떠나지 않고 작업을 바꾸고 싶다면 트리거를 사용하세요.
|
||||
|
||||
## 스킬 생성 방식
|
||||
|
||||
`npx bmad-method install`을 실행하면 설치 프로그램은 선택된 모든 모듈의 매니페스트를 읽고 에이전트, 워크플로, 작업, 도구마다 하나의 스킬을 작성합니다. 각 스킬은 AI에게 해당 소스 파일을 로드하고 지시를 따르라고 안내하는 `SKILL.md` 파일이 있는 폴더입니다.
|
||||
|
||||
설치 프로그램은 스킬 유형별 템플릿을 사용합니다.
|
||||
|
||||
| 스킬 유형 | 생성 파일의 역할 |
|
||||
| --- | --- |
|
||||
| **에이전트 실행기** | 에이전트 페르소나 파일을 로드하고 메뉴를 활성화하며 페르소나를 유지 |
|
||||
| **워크플로 스킬** | 워크플로 설정을 로드하고 단계를 따름 |
|
||||
| **작업 스킬** | 단독 실행 작업 파일을 로드하고 지시를 따름 |
|
||||
| **도구 스킬** | 단독 실행 도구 파일을 로드하고 지시를 따름 |
|
||||
|
||||
:::note[설치 프로그램 다시 실행]
|
||||
모듈을 추가하거나 제거했다면 설치 프로그램을 다시 실행하세요. 현재 모듈 선택에 맞춰 모든 스킬 파일을 다시 생성합니다.
|
||||
:::
|
||||
|
||||
## 스킬 파일 위치
|
||||
|
||||
설치 프로그램은 프로젝트 안의 IDE별 디렉터리에 스킬 파일을 씁니다. 정확한 경로는 설치 중 선택한 IDE에 따라 달라집니다.
|
||||
|
||||
| IDE / CLI | Skills 디렉터리 |
|
||||
| --- | --- |
|
||||
| Claude Code | `.claude/skills/` |
|
||||
| Cursor | `.cursor/skills/` |
|
||||
| Windsurf | `.windsurf/skills/` |
|
||||
| 기타 IDE | 대상 경로는 설치 프로그램 출력 참고 |
|
||||
|
||||
각 스킬은 `SKILL.md` 파일을 포함하는 폴더입니다. Claude Code 설치 예시는 다음과 같습니다.
|
||||
|
||||
```text
|
||||
.claude/skills/
|
||||
├── bmad-help/
|
||||
│ └── SKILL.md
|
||||
├── bmad-prd/
|
||||
│ └── SKILL.md
|
||||
├── bmad-agent-dev/
|
||||
│ └── SKILL.md
|
||||
└── ...
|
||||
```
|
||||
|
||||
디렉터리 이름이 IDE에서의 스킬 이름을 결정합니다. 예를 들어 `bmad-agent-dev/` 디렉터리는 `bmad-agent-dev` 스킬을 등록합니다.
|
||||
|
||||
## 스킬 찾기
|
||||
|
||||
IDE에서 스킬 이름을 입력해 호출합니다. 일부 플랫폼은 스킬이 나타나기 전에 설정에서 활성화해야 합니다.
|
||||
|
||||
다음 단계를 상황에 맞게 안내받으려면 `bmad-help`를 실행하세요.
|
||||
|
||||
:::tip[빠른 탐색]
|
||||
프로젝트에 생성된 스킬 디렉터리가 기준 목록입니다. 파일 탐색기에서 열면 설명이 있는 모든 스킬을 볼 수 있습니다.
|
||||
:::
|
||||
|
||||
## 스킬 범주
|
||||
|
||||
### 에이전트 스킬
|
||||
|
||||
에이전트 스킬은 정의된 역할, 커뮤니케이션 스타일, 워크플로 메뉴를 가진 전문 AI 페르소나를 로드합니다. 로드되면 에이전트는 페르소나를 유지하고 메뉴 트리거에 응답합니다.
|
||||
|
||||
| 예시 스킬 | 에이전트 | 역할 |
|
||||
| --- | --- | --- |
|
||||
| `bmad-agent-dev` | Amelia(개발자) | 사양을 엄격히 준수해 스토리 구현 |
|
||||
| `bmad-pm` | John(제품 관리자) | PRD 생성 및 검증 |
|
||||
| `bmad-architect` | Winston(아키텍트) | 시스템 아키텍처 설계 |
|
||||
|
||||
기본 에이전트와 트리거 전체 목록은 [에이전트](./agents.md)를 참고하세요.
|
||||
|
||||
### 워크플로 스킬
|
||||
|
||||
워크플로 스킬은 에이전트 페르소나를 먼저 로드하지 않고 구조화된 다단계 프로세스를 실행합니다. 워크플로 설정을 로드하고 단계를 따릅니다.
|
||||
|
||||
| 예시 스킬 | 목적 |
|
||||
| --- | --- |
|
||||
| `bmad-product-brief` | 제품 개요 생성 또는 업데이트 - 개념이 명확할 때 안내형 발견 |
|
||||
| `bmad-prfaq` | 제품 개념을 스트레스 테스트하는 [워킹 백워드 PRFAQ](../explanation/analysis-phase.md#prfaq-working-backwards) 챌린지 |
|
||||
| `bmad-prd` | 제품 요구사항 문서(PRD) 생성, 업데이트, 검증 |
|
||||
| `bmad-create-architecture` | 시스템 아키텍처 설계 |
|
||||
| `bmad-create-epics-and-stories` | 에픽과 스토리 생성 |
|
||||
| `bmad-dev-story` | 스토리 구현 |
|
||||
| `bmad-code-review` | 코드 리뷰 실행 |
|
||||
| `bmad-quick-dev` | 통합 빠른 흐름 - 의도 정리, 계획, 구현, 리뷰, 발표 |
|
||||
|
||||
단계별 전체 워크플로 참조는 [워크플로 맵](./workflow-map.md)을 참고하세요.
|
||||
|
||||
### 작업과 도구 스킬
|
||||
|
||||
작업과 도구는 에이전트나 워크플로 컨텍스트 없이 실행되는 단독 작업입니다.
|
||||
|
||||
**BMad 도움말: 지능형 안내자**
|
||||
|
||||
`bmad-help`는 다음에 무엇을 해야 할지 찾는 기본 인터페이스입니다. 프로젝트를 검사하고, 자연어 쿼리를 이해하며, 설치된 모듈을 기준으로 다음 필수 또는 선택 단계를 추천합니다.
|
||||
|
||||
:::note[예시]
|
||||
```
|
||||
bmad-help
|
||||
bmad-help SaaS 아이디어가 있고 기능도 모두 알고 있습니다. 어디서 시작하나요?
|
||||
bmad-help UX 설계에는 어떤 선택지가 있나요?
|
||||
```
|
||||
:::
|
||||
|
||||
**기타 핵심 작업과 도구**
|
||||
|
||||
핵심 모듈에는 리뷰, 압축, 브레인스토밍, 문서 관리 등 11개의 내장 도구가 포함됩니다. 전체 참조는 [핵심 도구](./core-tools.md)를 참고하세요.
|
||||
|
||||
## 이름 규칙
|
||||
|
||||
모든 스킬은 `bmad-` 접두사 뒤에 설명적인 이름을 붙입니다(예: `bmad-agent-dev`, `bmad-prd`, `bmad-help`). 사용 가능한 모듈은 [모듈](./modules.md)을 참고하세요.
|
||||
|
||||
## 문제 해결
|
||||
|
||||
**설치 후 스킬이 보이지 않음.** 일부 플랫폼은 설정에서 스킬을 명시적으로 활성화해야 합니다. IDE 문서를 확인하거나 AI 어시스턴트에게 스킬 활성화 방법을 물어보세요. IDE 재시작 또는 창 새로고침이 필요할 수도 있습니다.
|
||||
|
||||
**예상한 스킬이 없음.** 설치 프로그램은 선택한 모듈의 스킬만 생성합니다. `npx bmad-method install`을 다시 실행하고 모듈 선택을 확인하세요. 예상 디렉터리에 스킬 파일이 있는지 확인하세요.
|
||||
|
||||
**제거한 모듈의 스킬이 계속 보임.** 설치 프로그램은 오래된 스킬 파일을 자동으로 삭제하지 않습니다. IDE 스킬 디렉터리에서 오래된 디렉터리를 제거하거나 전체 스킬 디렉터리를 삭제한 뒤 설치 프로그램을 다시 실행해 깨끗한 스킬 세트를 만드세요.
|
||||
|
|
@ -0,0 +1,293 @@
|
|||
---
|
||||
title: 핵심 도구
|
||||
description: 추가 모듈 없이 모든 BMad 설치에서 사용할 수 있는 내장 작업과 워크플로 참조
|
||||
sidebar:
|
||||
order: 3
|
||||
---
|
||||
|
||||
모든 BMad 설치에는 어떤 작업을 하든 함께 사용할 수 있는 핵심 스킬 모음이 포함됩니다. 모든 프로젝트, 모든 모듈, 모든 단계에서 단독으로 실행할 수 있는 작업과 워크플로입니다. 어떤 선택 모듈을 설치했든 항상 사용할 수 있습니다.
|
||||
|
||||
:::tip[빠른 경로]
|
||||
IDE에서 스킬 이름(예: `bmad-help`)을 입력해 어떤 핵심 도구든 실행하세요. 에이전트 세션은 필요 없습니다.
|
||||
:::
|
||||
|
||||
## 개요
|
||||
|
||||
| 도구 | 유형 | 목적 |
|
||||
| --- | --- | --- |
|
||||
| [`bmad-help`](#bmad-help) | 작업 | 다음에 무엇을 해야 할지 상황에 맞게 안내 |
|
||||
| [`bmad-brainstorming`](#bmad-brainstorming) | 워크플로 | 대화형 브레인스토밍 세션 진행 |
|
||||
| [`bmad-party-mode`](#bmad-party-mode) | 워크플로 | 다중 에이전트 그룹 토론 조율 |
|
||||
| [`bmad-distillator`](#bmad-distillator) | 작업 | 문서의 무손실 LLM 최적화 압축 |
|
||||
| [`bmad-advanced-elicitation`](#bmad-advanced-elicitation) | 작업 | LLM 출력을 반복 개선 방식으로 끌어올림 |
|
||||
| [`bmad-review-adversarial-general`](#bmad-review-adversarial-general) | 작업 | 빠진 것과 틀린 것을 찾는 비판적 리뷰 |
|
||||
| [`bmad-review-edge-case-hunter`](#bmad-review-edge-case-hunter) | 작업 | 처리되지 않은 엣지 케이스를 찾기 위한 철저한 분기 경로 분석 |
|
||||
| [`bmad-editorial-review-prose`](#bmad-editorial-review-prose) | 작업 | 전달 명확성을 위한 엄격한 문장 교정 |
|
||||
| [`bmad-editorial-review-structure`](#bmad-editorial-review-structure) | 작업 | 구조 편집 - 삭제, 병합, 재구성 |
|
||||
| [`bmad-shard-doc`](#bmad-shard-doc) | 작업 | 큰 Markdown 파일을 정리된 섹션으로 분할 |
|
||||
| [`bmad-index-docs`](#bmad-index-docs) | 작업 | 폴더 내 모든 문서 색인 생성 또는 업데이트 |
|
||||
|
||||
## bmad-help
|
||||
|
||||
**다음에 무엇을 해야 할지 알려주는 지능형 안내자입니다.** 프로젝트 상태를 검사하고, 완료된 것을 감지하며, 다음 필수 또는 선택 단계를 추천합니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 워크플로를 끝냈고 다음 단계를 알고 싶습니다
|
||||
- BMad가 처음이라 방향 안내가 필요합니다
|
||||
- 막혀서 상황에 맞는 조언이 필요합니다
|
||||
- 새 모듈을 설치했고 사용할 수 있는 것을 보고 싶습니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 프로젝트에서 기존 산출물(PRD, 아키텍처, 스토리 등)를 스캔합니다
|
||||
2. 설치된 모듈과 사용 가능한 워크플로를 감지합니다
|
||||
3. 우선순위 순서로 다음 단계를 추천합니다. 필수 단계를 먼저, 선택 단계를 나중에 제시합니다
|
||||
4. 각 추천을 스킬 명령과 짧은 설명으로 보여줍니다
|
||||
|
||||
**입력:** 자연어 선택 쿼리(예: `bmad-help SaaS 아이디어가 있는데 어디서 시작하나요?`)
|
||||
|
||||
**출력:** 스킬 명령이 포함된 권장 다음 단계의 우선순위 목록
|
||||
|
||||
## bmad-brainstorming
|
||||
|
||||
**대화형 창의 기법으로 다양한 아이디어를 생성합니다.** 기법 라이브러리에서 검증된 아이디어 발상법을 로드하고 100개 이상의 아이디어를 향해 안내한 뒤 정리하는 브레인스토밍 세션입니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 새 프로젝트를 시작하고 문제 영역을 탐색해야 합니다
|
||||
- 아이디어 생성이 막혀 구조화된 창의 기법이 필요합니다
|
||||
- SCAMPER, 역브레인스토밍 같은 검증된 아이디어 발상 프레임워크를 사용하고 싶습니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 주제로 브레인스토밍 세션을 설정합니다
|
||||
2. 기법 라이브러리에서 창의 기법을 로드합니다
|
||||
3. 기법을 하나씩 진행하며 아이디어를 생성합니다
|
||||
4. 편향 방지 프로토콜을 적용합니다. 10개 아이디어마다 창의 영역을 바꿔 군집화를 방지합니다
|
||||
5. 모든 아이디어를 기법별로 정리한 추가 전용 세션 문서를 만듭니다
|
||||
|
||||
**입력:** 브레인스토밍 주제 또는 문제 설명, 선택 사항 컨텍스트 파일
|
||||
|
||||
**출력:** 생성된 모든 아이디어가 담긴 `brainstorming-session-{date}.md`
|
||||
|
||||
:::note[수량 목표]
|
||||
핵심은 아이디어 50-100개 지점에서 나옵니다. 이 워크플로는 정리 전에 100개 이상의 아이디어 생성을 권장합니다.
|
||||
:::
|
||||
|
||||
## bmad-party-mode
|
||||
|
||||
**다중 에이전트 그룹 토론을 조율합니다.** 설치된 모든 BMad 에이전트를 로드하고 각 에이전트가 고유한 전문성과 페르소나로 기여하는 자연스러운 대화를 진행합니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 결정에 여러 전문가 관점이 필요합니다
|
||||
- 에이전트들이 서로의 가정에 도전하길 원합니다
|
||||
- 여러 도메인에 걸친 복잡한 주제를 탐색합니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 설치된 모든 에이전트 페르소나가 있는 에이전트 매니페스트를 로드합니다
|
||||
2. 주제를 분석해 가장 관련 있는 에이전트 2-3개를 선택합니다
|
||||
3. 에이전트들이 턴을 나눠 기여하고 자연스러운 상호 대화와 의견 차이를 만듭니다
|
||||
4. 시간이 지나며 참여 에이전트를 순환해 다양한 관점을 보장합니다
|
||||
5. `goodbye`, `end party`, `quit`로 종료합니다
|
||||
|
||||
**입력:** 토론 주제 또는 질문, 참여시키고 싶은 페르소나 지정(선택 사항)
|
||||
|
||||
**출력:** 에이전트 페르소나가 유지되는 실시간 다중 에이전트 대화
|
||||
|
||||
## bmad-distillator
|
||||
|
||||
**소스 문서의 무손실 LLM 최적화 압축입니다.** 후속 LLM 사용을 위해 모든 정보를 보존하는 조밀하고 토큰 효율적인 요약본을 생성합니다. 왕복 재구성으로 검증할 수 있습니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 문서가 LLM 컨텍스트 창에 너무 큽니다
|
||||
- 리서치, 사양, 계획 산출물의 토큰 효율적인 버전이 필요합니다
|
||||
- 압축 중 정보 손실이 없는지 검증하고 싶습니다
|
||||
- 에이전트가 자주 참조하고 정보를 찾아야 합니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. **분석** - 소스 문서를 읽고 정보 밀도와 구조를 식별합니다
|
||||
2. **압축** - 문장을 조밀한 글머리표 형식으로 바꾸고 장식적 서식을 제거합니다
|
||||
3. **확인** - 원래 정보가 모두 보존되었는지 완전성을 확인합니다
|
||||
4. **검증(선택 사항)** - 왕복 재구성 테스트로 무손실 압축을 증명합니다
|
||||
|
||||
**입력:**
|
||||
|
||||
- `source_documents`(필수) - 파일 경로, 폴더 경로, glob 패턴
|
||||
- `downstream_consumer`(선택 사항) - 이 요약본을 사용할 대상(예: "PRD 작성")
|
||||
- `token_budget`(선택 사항) - 대략적 목표 크기
|
||||
- `--validate`(플래그) - 왕복 재구성 테스트 실행
|
||||
|
||||
**출력:** 압축률 보고서(예: "3.2:1")가 포함된 요약 Markdown 파일
|
||||
|
||||
## bmad-advanced-elicitation
|
||||
|
||||
**LLM 출력을 반복 개선 방식으로 개선합니다.** 도출 기법 라이브러리에서 선택해 여러 차례에 걸쳐 내용을 체계적으로 개선합니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- LLM 출력이 얕거나 일반적으로 느껴집니다
|
||||
- 여러 분석 관점에서 주제를 탐색하고 싶습니다
|
||||
- 중요한 문서를 다듬고 더 깊은 사고가 필요합니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 5개 이상의 도출 기법이 있는 기법 레지스트리를 로드합니다
|
||||
2. 내용 유형과 복잡도에 가장 잘 맞는 기법 5개를 선택합니다
|
||||
3. 대화형 메뉴를 제시합니다. 기법 선택, 다시 섞기, 전체 목록 보기가 가능합니다
|
||||
4. 선택한 기법을 적용해 내용을 강화합니다
|
||||
5. "진행"을 선택할 때까지 반복 개선 옵션을 다시 제시합니다
|
||||
|
||||
**입력:** 강화할 내용 섹션
|
||||
|
||||
**출력:** 개선이 적용된 버전
|
||||
|
||||
## bmad-review-adversarial-general
|
||||
|
||||
**문제가 있다고 가정하고 찾는 비판적 리뷰입니다.** 허술한 작업을 용납하지 않는 회의적인 리뷰어의 관점을 취합니다. 틀린 것뿐 아니라 빠진 것을 찾습니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 산출물 확정 전 품질 보증이 필요합니다
|
||||
- 사양, 스토리, 문서를 스트레스 테스트하고 싶습니다
|
||||
- 낙관적인 리뷰가 놓치는 검토 공백을 찾고 싶습니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 냉정하고 비판적인 관점으로 내용을 읽습니다
|
||||
2. 완전성, 정확성, 품질 전반의 이슈를 식별합니다
|
||||
3. 존재하지만 잘못된 것만이 아니라 빠진 것을 특히 찾습니다
|
||||
4. 최소 10개 이슈를 찾아야 하며, 부족하면 더 깊게 재분석합니다
|
||||
|
||||
**입력:**
|
||||
|
||||
- `content`(필수) - diff, 사양, 스토리, 문서 또는 모든 산출물
|
||||
- `also_consider`(선택 사항) - 추가로 염두에 둘 영역
|
||||
|
||||
**출력:** 설명이 있는 10개 이상의 발견 사항 Markdown 목록
|
||||
|
||||
## bmad-review-edge-case-hunter
|
||||
|
||||
**모든 분기 경로와 경계 조건을 따라가며 처리되지 않은 사례만 보고합니다.** 엣지 케이스 유형을 기계적으로 도출하는 순수 경로 추적 기법입니다. 적대적 리뷰와 상호 보완적이며, 태도 기반이 아니라 기법 기반입니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 코드나 로직에 대한 철저한 엣지 케이스 검토가 필요합니다
|
||||
- 적대적 리뷰를 보완하고 싶습니다(다른 기법, 다른 발견 사항)
|
||||
- 경계 조건을 확인하기 위해 diff나 함수를 리뷰합니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 내용의 모든 분기 경로를 열거합니다
|
||||
2. 누락된 else/기본값, 보호되지 않은 입력, off-by-one, 산술 오버플로, 암시적 타입 강제 변환, 경쟁 상태, 타임아웃 공백 같은 엣지 케이스 유형을 기계적으로 도출합니다
|
||||
3. 각 경로를 기존 방어 로직과 대조합니다
|
||||
4. 처리되지 않은 경로만 보고합니다. 이미 처리된 경로는 조용히 버립니다
|
||||
|
||||
**입력:**
|
||||
|
||||
- `content`(필수) - diff, 전체 파일, 함수
|
||||
- `also_consider`(선택 사항) - 추가로 염두에 둘 영역
|
||||
|
||||
**출력:** 각 발견 사항이 `location`, `trigger_condition`, `guard_snippet`, `potential_consequence`를 포함하는 JSON 배열
|
||||
|
||||
:::note[상호 보완 리뷰]
|
||||
상호 보완적 검토를 위해 `bmad-review-adversarial-general`과 `bmad-review-edge-case-hunter`를 함께 실행하세요. 적대적 리뷰는 품질과 완전성 이슈를 잡고, 엣지 케이스 헌터는 처리되지 않은 경로를 잡습니다.
|
||||
:::
|
||||
|
||||
## bmad-editorial-review-prose
|
||||
|
||||
**전달 명확성에 집중한 엄격한 문장 교정입니다.** 이해를 방해하는 문장 문제를 리뷰합니다. Microsoft Writing Style Guide 기준을 적용하고 작성자 목소리를 보존합니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 문서를 초안으로 작성했고 문장을 다듬고 싶습니다
|
||||
- 특정 독자를 위한 명확성을 보장해야 합니다
|
||||
- 취향 기반 수정 없이 전달만 개선하고 싶습니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 코드 블록과 프런트매터를 건너뛰고 내용을 읽습니다
|
||||
2. 스타일 선호가 아닌 전달 이슈를 식별합니다
|
||||
3. 여러 위치의 같은 이슈를 중복 제거합니다
|
||||
4. 세 열 수정 테이블을 생성합니다
|
||||
|
||||
**입력:**
|
||||
|
||||
- `content`(필수) - Markdown, 일반 텍스트, XML
|
||||
- `style_guide`(선택 사항) - 프로젝트별 스타일 가이드
|
||||
- `reader_type`(선택 사항) - 명확성/흐름용 `humans`(기본값) 또는 정밀도/일관성용 `llm`
|
||||
|
||||
**출력:** 세 열 Markdown 테이블: `Original Text | Revised Text | Changes`
|
||||
|
||||
## bmad-editorial-review-structure
|
||||
|
||||
**구조 편집입니다. 삭제, 병합, 이동, 압축을 제안합니다.** 문장 교정 전에 문서 구성을 리뷰하고 명확성과 흐름을 개선하는 실질적 변경을 제안합니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 여러 하위 프로세스에서 생성된 문서에 구조적 일관성이 필요합니다
|
||||
- 이해도를 유지하면서 문서 길이를 줄이고 싶습니다
|
||||
- 범위 위반이나 묻힌 핵심 정보를 식별해야 합니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 5개 구조 모델(튜토리얼, 참조, 설명, 프롬프트, 전략)에 대해 문서를 분석합니다
|
||||
2. 중복, 범위 위반, 묻힌 정보를 식별합니다
|
||||
3. 우선순위 권장 사항을 생성합니다: `CUT`, `MERGE`, `MOVE`, `CONDENSE`, `QUESTION`, `PRESERVE`
|
||||
4. 총 단어 감소량과 감소율을 추정합니다
|
||||
|
||||
**입력:**
|
||||
|
||||
- `content`(필수) - 리뷰할 문서
|
||||
- `purpose`(선택 사항) - 의도한 목적(예: "빠른 시작 튜토리얼")
|
||||
- `target_audience`(선택 사항) - 독자
|
||||
- `reader_type`(선택 사항) - `humans` 또는 `llm`
|
||||
- `length_target`(선택 사항) - 목표 감소량(예: "30% 줄이기")
|
||||
|
||||
**출력:** 문서 요약, 우선순위 권장 사항 목록, 예상 감소량
|
||||
|
||||
## bmad-shard-doc
|
||||
|
||||
**큰 Markdown 파일을 정리된 섹션 파일로 나눕니다.** 2단계 헤더를 분할 지점으로 사용해 독립적인 섹션 파일과 색인이 있는 폴더를 만듭니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- Markdown 문서가 너무 커져 효과적으로 관리하기 어렵습니다(500줄 이상)
|
||||
- 단일 문서를 탐색 가능한 섹션으로 나누고 싶습니다
|
||||
- 병렬 편집 또는 LLM 컨텍스트 관리를 위해 별도 파일이 필요합니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 소스 파일이 존재하고 Markdown인지 검증합니다
|
||||
2. 2단계(`##`) 헤더 기준으로 번호가 붙은 섹션 파일로 나눕니다
|
||||
3. 섹션 매니페스트와 링크가 있는 `index.md`를 만듭니다
|
||||
4. 원본을 삭제, 보관, 유지할지 묻습니다
|
||||
|
||||
**입력:** 소스 Markdown 파일 경로, 선택 사항 대상 폴더
|
||||
|
||||
**출력:** `index.md`와 `01-{section}.md`, `02-{section}.md` 등이 있는 폴더
|
||||
|
||||
## bmad-index-docs
|
||||
|
||||
**폴더의 모든 문서 색인을 생성하거나 업데이트합니다.** 디렉터리를 스캔하고 각 파일을 읽어 목적을 이해한 뒤 링크와 설명이 있는 정리된 `index.md`를 만듭니다.
|
||||
|
||||
**사용 시점:**
|
||||
|
||||
- 사용 가능한 문서를 LLM이 빠르게 스캔할 수 있는 가벼운 색인이 필요합니다
|
||||
- 문서 폴더가 커져 정리된 목차가 필요합니다
|
||||
- 최신 상태를 유지하는 자동 생성 개요를 원합니다
|
||||
|
||||
**작동 방식:**
|
||||
|
||||
1. 대상 디렉터리에서 숨김이 아닌 파일을 모두 스캔합니다
|
||||
2. 각 파일을 읽어 실제 목적을 이해합니다
|
||||
3. 유형, 목적, 하위 디렉터리 기준으로 파일을 그룹화합니다
|
||||
4. 간결한 설명(각 3-10단어)을 생성합니다
|
||||
|
||||
**입력:** 대상 폴더 경로
|
||||
|
||||
**출력:** 정리된 파일 목록, 상대 링크, 짧은 설명이 있는 `index.md`
|
||||
|
|
@ -0,0 +1,76 @@
|
|||
---
|
||||
title: 공식 모듈
|
||||
description: 커스텀 에이전트, 창의적 지능, 게임 개발, 테스트를 위한 추가 모듈
|
||||
sidebar:
|
||||
order: 5
|
||||
---
|
||||
|
||||
BMad는 설치 중 선택하는 공식 모듈로 확장됩니다. 이러한 추가 모듈은 내장 핵심 기능과 BMM(애자일 제품군)을 넘어 특정 도메인을 위한 전문 에이전트, 워크플로, 작업을 제공합니다.
|
||||
|
||||
:::tip[모듈 설치]
|
||||
`npx bmad-method install`을 실행하고 원하는 모듈을 선택하세요. 설치 프로그램이 다운로드, 설정, IDE 통합을 자동으로 처리합니다.
|
||||
:::
|
||||
|
||||
## BMad 빌더(BMB)
|
||||
|
||||
안내형 도구를 사용해 커스텀 에이전트, 워크플로, 도메인 특화 모듈을 만듭니다. BMad 빌더는 프레임워크 자체를 확장하는 메타 모듈입니다.
|
||||
|
||||
- **코드:** `bmb`
|
||||
- **npm:** [`bmad-builder`](https://www.npmjs.com/package/bmad-builder)
|
||||
- **GitHub:** [bmad-code-org/bmad-builder](https://github.com/bmad-code-org/bmad-builder)
|
||||
|
||||
**제공:**
|
||||
|
||||
- 에이전트 빌더 - 커스텀 전문성과 도구 접근 권한이 있는 전문 AI 에이전트 생성
|
||||
- 워크플로 빌더 - 단계와 결정 지점이 있는 구조화된 프로세스 설계
|
||||
- 모듈 빌더 - 에이전트와 워크플로를 공유 및 게시 가능한 모듈로 패키징
|
||||
- YAML 설정과 npm 게시 지원이 있는 대화형 설정
|
||||
|
||||
## 창의적 지능 제품군(CIS)
|
||||
|
||||
초기 개발 단계의 구조화된 창의성, 아이디어 발상, 혁신을 위한 AI 기반 도구입니다. 이 제품군은 검증된 프레임워크를 사용해 브레인스토밍, 디자인 사고, 문제 해결을 진행하는 여러 에이전트를 제공합니다.
|
||||
|
||||
- **코드:** `cis`
|
||||
- **npm:** [`bmad-creative-intelligence-suite`](https://www.npmjs.com/package/bmad-creative-intelligence-suite)
|
||||
- **GitHub:** [bmad-code-org/bmad-module-creative-intelligence-suite](https://github.com/bmad-code-org/bmad-module-creative-intelligence-suite)
|
||||
|
||||
**제공:**
|
||||
|
||||
- 혁신 전략가, 디자인 사고 코치, 브레인스토밍 코치 에이전트
|
||||
- 체계적 사고와 수평적 사고를 위한 문제 해결자와 창의적 문제 해결자
|
||||
- 내러티브와 피치를 위한 스토리텔러와 발표 마스터
|
||||
- SCAMPER, 역브레인스토밍, 문제 재구성을 포함한 아이디어 발상 프레임워크
|
||||
|
||||
## 게임 개발 스튜디오(BMGD)
|
||||
|
||||
Unity, Unreal, Godot, 커스텀 엔진에 맞춘 구조화된 게임 개발 워크플로입니다. 빠른 흐름을 통한 신속한 프로토타이핑과 에픽 중심 스프린트를 통한 전체 규모 제작을 지원합니다.
|
||||
|
||||
- **코드:** `gds`
|
||||
- **npm:** [`bmad-game-dev-studio`](https://www.npmjs.com/package/bmad-game-dev-studio)
|
||||
- **GitHub:** [bmad-code-org/bmad-module-game-dev-studio](https://github.com/bmad-code-org/bmad-module-game-dev-studio)
|
||||
|
||||
**제공:**
|
||||
|
||||
- 게임 디자인 문서 생성 워크플로
|
||||
- 신속한 프로토타이핑을 위한 빠른 개발 모드
|
||||
- 캐릭터, 대화, 세계관 구축을 위한 내러티브 디자인 지원
|
||||
- 21개 이상 게임 유형과 엔진별 아키텍처 가이드 지원
|
||||
|
||||
## 테스트 설계자(TEA)
|
||||
|
||||
전문가 에이전트와 9개의 구조화된 워크플로를 통해 엔터프라이즈급 테스트 전략, 자동화 가이드, 릴리스 게이트 결정을 지원합니다. TEA는 위험 기반 우선순위와 요구사항 추적성으로 내장 QA 에이전트를 크게 넘어섭니다.
|
||||
|
||||
- **코드:** `tea`
|
||||
- **npm:** [`bmad-method-test-architecture-enterprise`](https://www.npmjs.com/package/bmad-method-test-architecture-enterprise)
|
||||
- **GitHub:** [bmad-code-org/bmad-method-test-architecture-enterprise](https://github.com/bmad-code-org/bmad-method-test-architecture-enterprise)
|
||||
|
||||
**제공:**
|
||||
|
||||
- Murat 에이전트(마스터 테스트 아키텍트 겸 품질 조언자)
|
||||
- 테스트 설계, ATDD, 자동화, 테스트 리뷰, 추적성 워크플로
|
||||
- NFR 평가, CI 설정, 프레임워크 초기 구조 생성
|
||||
- 선택적 Playwright 유틸리티 및 MCP 통합을 포함한 P0-P3 우선순위
|
||||
|
||||
## 커뮤니티 모듈
|
||||
|
||||
커뮤니티 모듈과 모듈 마켓플레이스가 준비 중입니다. 업데이트는 [BMad GitHub 조직](https://github.com/bmad-code-org)을 확인하세요.
|
||||
|
|
@ -0,0 +1,106 @@
|
|||
---
|
||||
title: 테스트 옵션
|
||||
description: 내장 QA 워크플로와 테스트 설계자(TEA) 모듈의 테스트 자동화 비교
|
||||
sidebar:
|
||||
order: 6
|
||||
---
|
||||
|
||||
BMad는 두 가지 테스트 경로를 제공합니다. 빠른 테스트 생성을 위한 내장 QA 워크플로와 엔터프라이즈급 테스트 전략을 위한 설치 가능한 테스트 설계자 모듈입니다.
|
||||
|
||||
## 무엇을 사용해야 하나요?
|
||||
|
||||
| 기준 | 내장 QA | TEA 모듈 |
|
||||
| --- | --- | --- |
|
||||
| **적합한 경우** | 중소형 프로젝트, 빠른 커버리지 | 대형 프로젝트, 규제 대상 또는 복잡한 도메인 |
|
||||
| **설정** | 설치할 것 없음 - BMM에 포함 | `npx bmad-method install`로 별도 설치 |
|
||||
| **접근 방식** | 테스트를 빠르게 생성하고 나중에 반복 개선 | 먼저 계획하고 추적 가능하게 생성 |
|
||||
| **테스트 유형** | API 및 E2E 테스트 | API, E2E, ATDD, NFR 등 |
|
||||
| **전략** | 정상 경로 + 중요한 엣지 케이스 | 위험 기반 우선순위(P0-P3) |
|
||||
| **워크플로 수** | 1(자동화) | 9개(설계, ATDD, 자동화, 리뷰, 추적 등) |
|
||||
|
||||
:::tip[내장 QA로 시작]
|
||||
대부분의 프로젝트는 내장 QA 워크플로로 시작하면 됩니다. 나중에 테스트 전략, 품질 게이트, 요구사항 추적성이 필요해지면 TEA를 함께 설치하세요.
|
||||
:::
|
||||
|
||||
## 내장 QA 워크플로
|
||||
|
||||
내장 QA 워크플로(`bmad-qa-generate-e2e-tests`)는 BMM(애자일 제품군) 모듈의 일부이며 개발자 에이전트를 통해 사용할 수 있습니다. 설정이나 추가 설치 없이 프로젝트의 기존 테스트 프레임워크를 사용해 실행 가능한 테스트를 빠르게 생성합니다.
|
||||
|
||||
**트리거:** `QA`(개발자 에이전트를 통해) 또는 `bmad-qa-generate-e2e-tests`
|
||||
|
||||
### 하는 일
|
||||
|
||||
QA 자동화 워크플로는 다섯 단계를 거칩니다.
|
||||
|
||||
1. **테스트 프레임워크 감지** - `package.json`과 기존 테스트 파일을 스캔해 프레임워크(Jest, Vitest, Playwright, Cypress 또는 표준 러너)를 찾습니다. 없으면 프로젝트 스택을 분석해 제안합니다.
|
||||
2. **기능 식별** - 무엇을 테스트할지 묻거나 코드베이스에서 기능을 자동으로 발견합니다.
|
||||
3. **API 테스트 생성** - 상태 코드, 응답 구조, 정상 경로, 오류 사례 1-2개를 다룹니다.
|
||||
4. **E2E 테스트 생성** - 의미 기반 로케이터와 사용자에게 보이는 결과 검증으로 사용자 워크플로를 다룹니다.
|
||||
5. **실행 및 검증** - 생성된 테스트를 실행하고 실패를 즉시 수정합니다.
|
||||
|
||||
워크플로는 프로젝트의 구현 산출물 폴더에 저장되는 테스트 요약을 생성합니다.
|
||||
|
||||
### 테스트 패턴
|
||||
|
||||
생성된 테스트는 "단순하고 유지보수하기 쉬운" 철학을 따릅니다.
|
||||
|
||||
- **표준 프레임워크 API만 사용** - 외부 유틸리티나 커스텀 추상화 없음
|
||||
- UI 테스트에는 CSS 선택자 대신 **의미 기반 로케이터** 사용(역할, 레이블, 텍스트)
|
||||
- 순서 의존성이 없는 **독립 테스트**
|
||||
- 하드코딩된 대기(`wait`/`sleep`) 없음
|
||||
- 기능 문서처럼 읽히는 명확한 설명
|
||||
|
||||
:::note[범위]
|
||||
QA 워크플로는 테스트만 생성합니다. 코드 리뷰와 스토리 검증에는 코드 리뷰 워크플로(`CR`)를 사용하세요.
|
||||
:::
|
||||
|
||||
### 내장 QA 사용 시점
|
||||
|
||||
- 새 기능 또는 기존 기능의 빠른 테스트 커버리지
|
||||
- 고급 설정 없는 초보자 친화적 테스트 자동화
|
||||
- 모든 개발자가 읽고 유지할 수 있는 표준 테스트 패턴
|
||||
- 포괄적인 테스트 전략이 불필요한 중소형 프로젝트
|
||||
|
||||
## 테스트 설계자(TEA) 모듈
|
||||
|
||||
TEA는 전문가 에이전트(Murat)와 엔터프라이즈급 테스트를 위한 9개 구조화된 워크플로를 제공하는 단독 실행 모듈입니다. 테스트 생성을 넘어 테스트 전략, 위험 기반 계획, 품질 게이트, 요구사항 추적성을 다룹니다.
|
||||
|
||||
- **문서:** [TEA 모듈 문서](https://bmad-code-org.github.io/bmad-method-test-architecture-enterprise/)
|
||||
- **설치:** `npx bmad-method install` 실행 후 TEA 모듈 선택
|
||||
- **npm:** [`bmad-method-test-architecture-enterprise`](https://www.npmjs.com/package/bmad-method-test-architecture-enterprise)
|
||||
|
||||
### TEA가 제공하는 것
|
||||
|
||||
| 워크플로 | 목적 |
|
||||
| --- | --- |
|
||||
| 테스트 설계 | 요구사항에 연결된 포괄적 테스트 전략 생성 |
|
||||
| ATDD | 이해관계자 기준을 활용한 인수 테스트 주도 개발 |
|
||||
| 자동화 | 고급 패턴과 유틸리티로 테스트 생성 |
|
||||
| 테스트 리뷰 | 전략 대비 테스트 품질과 커버리지 검증 |
|
||||
| 추적성 | 감사 및 컴플라이언스를 위해 테스트를 요구사항에 매핑 |
|
||||
| NFR 평가 | 성능, 보안 등 비기능 요구사항 평가 |
|
||||
| CI 설정 | 지속적 통합 파이프라인에서 테스트 실행 구성 |
|
||||
| 프레임워크 초기 구조 생성 | 테스트 인프라와 프로젝트 구조 설정 |
|
||||
| 릴리스 게이트 | 데이터 기반 출시 여부 결정 |
|
||||
|
||||
TEA는 P0-P3 위험 기반 우선순위와 선택적 Playwright 유틸리티 및 MCP 도구 통합도 지원합니다.
|
||||
|
||||
### TEA 사용 시점
|
||||
|
||||
- 요구사항 추적성 또는 컴플라이언스 문서화가 필요한 프로젝트
|
||||
- 많은 기능에 대해 위험 기반 테스트 우선순위가 필요한 팀
|
||||
- 릴리스 전 공식 품질 게이트가 있는 엔터프라이즈 환경
|
||||
- 테스트 작성 전에 테스트 전략이 계획되어야 하는 복잡한 도메인
|
||||
- 내장 QA의 단일 워크플로 접근 방식으로는 부족한 프로젝트
|
||||
|
||||
## 테스트가 워크플로와 맞물리는 방식
|
||||
|
||||
QA 자동화 워크플로는 BMad Method 워크플로 맵의 단계 4(구현)에 나타납니다. **전체 에픽이 완료된 후**, 즉 에픽의 모든 스토리가 구현되고 코드 리뷰된 뒤 실행하도록 설계되었습니다. 일반적인 순서는 다음과 같습니다.
|
||||
|
||||
1. 에픽의 각 스토리마다 개발자(`DS`)로 구현하고 코드 리뷰(`CR`)로 검증합니다
|
||||
2. 에픽 완료 후 `QA`(개발자 에이전트를 통해) 또는 TEA의 자동화 워크플로로 테스트를 생성합니다
|
||||
3. `bmad-retrospective`를 실행해 배운 점을 기록합니다
|
||||
|
||||
내장 QA 워크플로는 계획 문서(PRD, 아키텍처)를 로드하지 않고 소스 코드에서 직접 작업합니다. TEA 워크플로는 추적성을 위해 상위 계획 산출물과 통합할 수 있습니다.
|
||||
|
||||
전체 프로세스에서 테스트가 어디에 맞물리는지는 [워크플로 맵](./workflow-map.md)을 참고하세요.
|
||||
|
|
@ -0,0 +1,102 @@
|
|||
---
|
||||
title: "워크플로 맵"
|
||||
description: BMad Method 워크플로 단계와 출력의 시각적 참조
|
||||
sidebar:
|
||||
order: 1
|
||||
---
|
||||
|
||||
BMad Method(BMM)는 BMad 생태계의 모듈이며 컨텍스트 엔지니어링과 계획 모범 사례를 따르는 데 초점을 둡니다. AI 에이전트는 명확하고 구조화된 컨텍스트가 있을 때 가장 잘 작동합니다. BMM 시스템은 4개의 구분된 단계에 걸쳐 그 컨텍스트를 점진적으로 만듭니다. 각 단계와 단계 안의 여러 선택 워크플로는 다음 단계에 필요한 정보를 담은 문서를 만들고, 에이전트는 항상 무엇을 왜 만들어야 하는지 알게 됩니다.
|
||||
|
||||
그 근거와 개념은 업계 전반에서 성공적으로 사용되어 온 애자일 방법론에서 온 사고 프레임워크입니다.
|
||||
|
||||
언제든 무엇을 해야 할지 확실하지 않다면 `bmad-help` 스킬이 흐름을 잡아 주고 다음 단계를 알려줍니다. 이 문서를 참조로 사용할 수도 있지만, 이미 BMad Method를 설치했다면 `bmad-help`가 더 대화형이고 훨씬 빠릅니다. 또한 BMad Method를 확장한 다른 모듈이나 함께 쓰는 보완 모듈을 사용한다면 `bmad-help`도 사용 가능한 항목을 모두 파악해 현재 상황에 가장 적절한 조언을 제공합니다.
|
||||
|
||||
마지막으로 중요한 점: 아래 모든 워크플로는 스킬로 직접 실행하거나, 먼저 에이전트를 로드한 뒤 에이전트 메뉴 항목을 사용해 원하는 도구에서 실행할 수 있습니다.
|
||||
|
||||
<iframe src="/workflow-map-diagram-ko-kr.html" title="BMad Method 워크플로 맵 다이어그램" width="100%" height="100%" style="border-radius: 8px; border: 1px solid #334155; min-height: 900px;"></iframe>
|
||||
|
||||
<p style="font-size: 0.8rem; text-align: right; margin-top: -0.5rem; margin-bottom: 1rem;">
|
||||
<a href="/workflow-map-diagram-ko-kr.html" target="_blank" rel="noopener noreferrer">다이어그램 새 탭에서 열기 ↗</a>
|
||||
</p>
|
||||
|
||||
## 단계 1: 분석(선택)
|
||||
|
||||
계획을 확정하기 전에 문제 영역을 탐색하고 아이디어를 검증합니다. [**각 도구가 무엇을 하고 언제 쓰는지 알아보기**](../explanation/analysis-phase.md).
|
||||
|
||||
| 워크플로 | 목적 | 산출물 |
|
||||
| --- | --- | --- |
|
||||
| `bmad-brainstorming` | 브레인스토밍 코치의 안내를 받아 프로젝트 아이디어를 발산합니다 | `brainstorming-report.md` |
|
||||
| `bmad-domain-research`, `bmad-market-research`, `bmad-technical-research` | 시장, 기술, 도메인 가정을 검증합니다 | 연구 발견 사항 |
|
||||
| `bmad-product-brief` | 전략적 비전을 포착합니다. 개념이 명확할 때 가장 좋습니다 | `product-brief.md` |
|
||||
| `bmad-prfaq` | 워킹 백워드 방식으로 제품 개념을 스트레스 테스트하고 다듬습니다 | `prfaq-{project}.md` |
|
||||
|
||||
## 단계 2: 계획
|
||||
|
||||
무엇을 누구를 위해 만들지 정의합니다.
|
||||
|
||||
| 워크플로 | 목적 | 산출물 |
|
||||
| --- | --- | --- |
|
||||
| `bmad-prd` | PRD를 생성, 업데이트, 검증합니다. 안내형 발견 과정과 세 가지 의도를 하나의 스킬에 담았습니다 | 생성/업데이트: `prd.md`, `addendum.md`, `decision-log.md`; 검증: `validation-report.html` + `.md` |
|
||||
| `bmad-create-ux-design` | UX가 중요할 때 사용자 경험을 설계합니다 | `ux-spec.md` |
|
||||
|
||||
:::tip[하나의 스킬 안에 세 의도]
|
||||
`bmad-prd`는 전체 PRD 수명주기를 처리합니다. 호출할 때 의도를 말하거나 스킬이 물어보게 하세요.
|
||||
|
||||
- **생성** - 안내형 발견 과정을 통해 처음부터 새 PRD를 만듭니다. `prd.md`, `addendum.md`, `decision-log.md`를 생성합니다
|
||||
- **업데이트** - 기존 PRD와 변경 신호를 조정하고, 변경을 적용하기 전에 충돌을 식별합니다
|
||||
- **검증** - 설정 가능한 체크리스트로 PRD를 비판적으로 검토하고 구조화된 HTML 발견 사항 보고서를 생성합니다
|
||||
:::
|
||||
|
||||
:::tip[상위 입력: `bmad-product-brief`]
|
||||
`bmad-product-brief`(단계 1)는 `bmad-prd`가 발견 과정에서 입력으로 사용할 수 있는 `product-brief.md`를 생성합니다. 재설명을 줄이고 두 문서를 서로 맞춰 유지합니다. 두 스킬이 서로 필수는 아닙니다. 무엇을 만들지 이미 안다면 `bmad-prd`로 바로 시작하세요.
|
||||
:::
|
||||
|
||||
## 단계 3: 솔루션 설계
|
||||
|
||||
어떻게 만들지 결정하고 작업을 스토리로 나눕니다.
|
||||
|
||||
| 워크플로 | 목적 | 산출물 |
|
||||
| --- | --- | --- |
|
||||
| `bmad-create-architecture` | 기술적 결정을 명시적으로 만듭니다 | ADR이 있는 `architecture.md` |
|
||||
| `bmad-create-epics-and-stories` | 요구사항을 구현 가능한 작업으로 나눕니다 | 스토리가 있는 에픽 파일 |
|
||||
| `bmad-check-implementation-readiness` | 구현 전 관문 점검 | 통과/우려/실패 결정 |
|
||||
|
||||
## 단계 4: 구현
|
||||
|
||||
스토리 하나씩 구현합니다. 전체 4단계 자동화는 곧 제공됩니다.
|
||||
|
||||
| 워크플로 | 목적 | 산출물 |
|
||||
| --- | --- | --- |
|
||||
| `bmad-sprint-planning` | 추적 상태 초기화(프로젝트당 한 번, 개발 주기 순서화) | `sprint-status.yaml` |
|
||||
| `bmad-create-story` | 구현을 위한 다음 스토리 준비 | `story-[slug].md` |
|
||||
| `bmad-dev-story` | 스토리 구현 | 작동하는 코드 + 테스트 |
|
||||
| `bmad-code-review` | 구현 품질 검증 | 승인 또는 변경 요청 |
|
||||
| `bmad-correct-course` | 스프린트 중 의미 있는 변경 처리 | 업데이트된 계획 또는 경로 재조정 |
|
||||
| `bmad-sprint-status` | 스프린트 진행 상황과 스토리 상태 추적 | 스프린트 상태 업데이트 |
|
||||
| `bmad-retrospective` | 에픽 완료 후 회고 | 배운 점 |
|
||||
| `bmad-investigate` | 입력에 맞게 보정된 증거 등급 발견 사항 기반 포렌식 사례 조사 | `{slug}-investigation.md` |
|
||||
|
||||
## 빠른 흐름(병렬 트랙)
|
||||
|
||||
작고 잘 이해된 작업에서는 단계 1-3을 건너뜁니다.
|
||||
|
||||
| 워크플로 | 목적 | 산출물 |
|
||||
| --- | --- | --- |
|
||||
| `bmad-quick-dev` | 통합 빠른 흐름 - 의도 정리, 계획, 구현, 리뷰, 발표 | `spec-*.md` + 코드 |
|
||||
|
||||
## 컨텍스트 관리
|
||||
|
||||
각 문서는 다음 단계의 컨텍스트가 됩니다. PRD는 아키텍트에게 어떤 제약이 중요한지 알려줍니다. 아키텍처는 개발 에이전트에게 어떤 패턴을 따라야 하는지 알려줍니다. 스토리 파일은 구현을 위한 집중적이고 완결된 컨텍스트를 제공합니다. 이 구조가 없으면 에이전트는 일관되지 않은 결정을 내립니다.
|
||||
|
||||
### 프로젝트 컨텍스트
|
||||
|
||||
:::tip[권장]
|
||||
AI 에이전트가 프로젝트의 규칙과 선호 사항을 따르도록 `project-context.md`를 만드세요. 이 파일은 프로젝트의 헌장처럼 작동해 모든 워크플로에서 구현 결정을 안내합니다. 이 선택 파일은 아키텍처 작성이 끝날 때 생성할 수 있고, 기존 프로젝트에서도 현재 관례와 맞춰야 할 중요한 내용을 포착하기 위해 생성할 수 있습니다.
|
||||
:::
|
||||
|
||||
**만드는 방법:**
|
||||
|
||||
- **수동으로** - `_bmad-output/project-context.md`를 만들고 기술 스택과 구현 규칙을 작성합니다
|
||||
- **생성하기** - `bmad-generate-project-context`를 실행해 아키텍처 또는 코드베이스에서 자동 생성합니다
|
||||
|
||||
[**project-context.md 더 알아보기**](../explanation/project-context.md)
|
||||
|
|
@ -0,0 +1,136 @@
|
|||
---
|
||||
title: 로드맵
|
||||
description: BMad의 다음 단계 - 기능, 개선 사항, 커뮤니티 기여
|
||||
---
|
||||
|
||||
# BMad Method: 공개 로드맵
|
||||
|
||||
BMad Method, BMad Method 모듈(BMM), BMad 빌더(BMB)는 계속 발전하고 있습니다. 현재 진행 중인 작업과 앞으로 예정된 항목을 소개합니다.
|
||||
|
||||
<div class="roadmap-container">
|
||||
|
||||
<h2 class="roadmap-section-title">진행 중</h2>
|
||||
|
||||
<div class="roadmap-future">
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🧩</span>
|
||||
<h4>범용 스킬 아키텍처</h4>
|
||||
<p>스킬 하나를 어떤 플랫폼에서든 사용할 수 있게 합니다. 한 번 작성하고 어디서나 실행합니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🏗️</span>
|
||||
<h4>BMad 빌더 v1</h4>
|
||||
<p>평가, 팀 구성, 점진적 기능 저하를 내장한 프로덕션 준비 AI 에이전트와 워크플로를 만듭니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🧠</span>
|
||||
<h4>프로젝트 컨텍스트 시스템</h4>
|
||||
<p>AI가 실제로 프로젝트를 이해합니다. 코드베이스와 함께 진화하는, 프레임워크를 이해하는 컨텍스트입니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">📦</span>
|
||||
<h4>중앙화된 스킬</h4>
|
||||
<p>한 번 설치하고 어디서나 사용합니다. 파일이 어지럽게 늘어나지 않게 프로젝트 간 스킬을 공유합니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🔄</span>
|
||||
<h4>적응형 스킬</h4>
|
||||
<p>도구를 이해하는 스킬입니다. Claude, Codex, Kimi, OpenCode 등 다양한 도구에 맞춘 변형을 제공합니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">📝</span>
|
||||
<h4>BMad 팀 전문가 블로그</h4>
|
||||
<p>팀이 전하는 가이드, 글, 인사이트입니다. 곧 공개됩니다.</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<h2 class="roadmap-section-title">시작 단계</h2>
|
||||
|
||||
<div class="roadmap-future">
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🏪</span>
|
||||
<h4>스킬 마켓플레이스</h4>
|
||||
<p>커뮤니티가 만든 스킬을 발견하고 설치하고 업데이트합니다. curl 명령 하나로 기능을 확장합니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🎨</span>
|
||||
<h4>워크플로 커스터마이징</h4>
|
||||
<p>내 방식에 맞게 조정합니다. Jira, Linear, 커스텀 출력까지, 당신의 워크플로와 규칙에 맞춥니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🚀</span>
|
||||
<h4>1-3단계 최적화</h4>
|
||||
<p>서브 에이전트 컨텍스트 수집으로 빠른 계획을 지원합니다. YOLO 모드의 속도와 안내형 워크플로의 품질을 함께 가져갑니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🌐</span>
|
||||
<h4>엔터프라이즈 준비</h4>
|
||||
<p>SSO, 감사 로그, 팀 워크스페이스. 기업 도입에 필요한 기반 기능입니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">💎</span>
|
||||
<h4>커뮤니티 모듈 확대</h4>
|
||||
<p>엔터테인먼트, 보안, 테라피, 롤플레이 등 훨씬 더 많은 영역으로 BMad Method 플랫폼을 확장합니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">⚡</span>
|
||||
<h4>개발 루프 자동화</h4>
|
||||
<p>개발을 위한 선택형 자동 조종 기능입니다. 품질을 높게 유지하면서 AI가 흐름을 처리하게 합니다.</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<h2 class="roadmap-section-title">커뮤니티와 팀</h2>
|
||||
|
||||
<div class="roadmap-future">
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🎙️</span>
|
||||
<h4>BMad Method 팟캐스트</h4>
|
||||
<p>AI 네이티브 개발에 관한 대화입니다. 2026년 3월 1일 공개 예정입니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🎓</span>
|
||||
<h4>BMad Method 마스터 클래스</h4>
|
||||
<p>사용자에서 전문가로 나아갑니다. 모든 단계와 워크플로를 깊게 다룹니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🏗️</span>
|
||||
<h4>BMad 빌더 마스터 클래스</h4>
|
||||
<p>직접 에이전트를 만듭니다. 단순한 사용을 넘어 직접 만들 준비가 되었을 때 필요한 고급 기법입니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">⚡</span>
|
||||
<h4>BMad Prototype First</h4>
|
||||
<p>아이디어에서 작동하는 프로토타입까지 한 세션에 이어 갑니다. 구상하던 앱을 빠르게 실체로 만듭니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🌴</span>
|
||||
<h4>BMad BALM!</h4>
|
||||
<p>AI 네이티브 시대의 생활 관리입니다. 작업, 습관, 목표까지 아우르는 AI 코파일럿입니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🖥️</span>
|
||||
<h4>공식 UI</h4>
|
||||
<p>전체 BMad 생태계를 위한 세련된 인터페이스입니다. CLI의 힘과 GUI의 편의성을 함께 제공합니다.</p>
|
||||
</div>
|
||||
<div class="roadmap-future-card">
|
||||
<span class="roadmap-emoji">🔒</span>
|
||||
<h4>BMad in a Box</h4>
|
||||
<p>셀프 호스팅, 망 분리, 엔터프라이즈급 배포를 지원합니다. 당신의 AI 어시스턴트를 당신의 인프라에서 직접 통제합니다.</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div style="text-align: center; margin-top: 3rem; padding: 2rem; background: var(--color-bg-card); border-radius: 12px; border: 1px solid var(--color-border);">
|
||||
<h3 style="margin: 0 0 1rem;">기여하고 싶나요?</h3>
|
||||
<p style="color: var(--slate-color-400); margin: 0;">
|
||||
이것은 계획된 항목의 일부일 뿐입니다. BMad 오픈 소스 팀은 기여자를 환영합니다!{" "}<br />
|
||||
<a href="https://github.com/bmad-code-org/BMAD-METHOD" style="color: var(--color-in-progress);">GitHub에서 함께</a> AI 기반 개발의 미래를 만들어 주세요.
|
||||
</p>
|
||||
<p style="color: var(--slate-color-400); margin: 1.5rem 0 0;">
|
||||
우리가 만드는 것을 좋아하시나요? 일회성 및 월간{" "}<a href="https://buymeacoffee.com/bmad" style="color: var(--color-in-progress);">후원</a> 모두 감사히 받습니다.
|
||||
</p>
|
||||
<p style="color: var(--slate-color-400); margin: 1rem 0 0;">
|
||||
기업 후원, 파트너십 문의, 발표 요청, 교육, 미디어 문의는{" "}
|
||||
<a href="mailto:contact@bmadcode.com" style="color: var(--color-in-progress);">contact@bmadcode.com</a>으로 연락하세요.
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
|
|
@ -0,0 +1,289 @@
|
|||
---
|
||||
title: "시작하기"
|
||||
description: BMad를 설치하고 첫 프로젝트를 만듭니다
|
||||
---
|
||||
|
||||
계획, 아키텍처, 구현을 안내하는 전문 에이전트 기반 AI 워크플로로 소프트웨어를 더 빠르게 만드세요.
|
||||
|
||||
## 배울 내용
|
||||
|
||||
- 새 프로젝트에 BMad Method를 설치하고 초기화합니다
|
||||
- 다음에 무엇을 해야 할지 아는 지능형 안내자 **BMad 도움말**을 사용합니다
|
||||
- 프로젝트 규모에 맞는 계획 트랙을 선택합니다
|
||||
- 요구사항부터 작동하는 코드까지 단계별로 진행합니다
|
||||
- 에이전트와 워크플로를 효과적으로 사용합니다
|
||||
|
||||
:::note[필수 조건]
|
||||
- **Node.js 20+** - 설치 프로그램에 필요합니다
|
||||
- **Git** - 버전 관리를 위해 권장합니다
|
||||
- **AI 기반 IDE** - Claude Code, Cursor 또는 유사 도구
|
||||
- **프로젝트 아이디어** - 학습용이라면 단순한 아이디어도 충분합니다
|
||||
:::
|
||||
|
||||
:::tip[가장 쉬운 경로]
|
||||
**설치** → `npx bmad-method install`
|
||||
**질문** → `bmad-help 먼저 무엇을 해야 하나요?`
|
||||
**빌드** → BMad 도움말의 안내에 따라 워크플로를 진행하세요
|
||||
:::
|
||||
|
||||
## BMad 도움말 만나기: 지능형 안내자
|
||||
|
||||
**BMad 도움말은 BMad를 시작하는 가장 빠른 방법입니다.** 워크플로나 단계를 외울 필요가 없습니다. 그냥 물어보면 BMad 도움말이 다음을 수행합니다.
|
||||
|
||||
- **프로젝트를 검사**해 이미 완료된 작업을 확인합니다
|
||||
- 설치된 모듈을 기준으로 **선택지를 보여줍니다**
|
||||
- 첫 필수 작업을 포함해 **다음 단계를 추천합니다**
|
||||
- "SaaS 아이디어가 있는데 어디서 시작하지?" 같은 **질문에 답합니다**
|
||||
|
||||
### BMad 도움말 사용 방법
|
||||
|
||||
AI IDE에서 스킬을 호출해 실행합니다.
|
||||
|
||||
```
|
||||
bmad-help
|
||||
```
|
||||
|
||||
컨텍스트가 있는 안내를 받으려면 질문과 함께 사용할 수도 있습니다.
|
||||
|
||||
```
|
||||
bmad-help SaaS 제품 아이디어가 있고 원하는 기능도 모두 알고 있습니다. 어디서 시작하면 좋나요?
|
||||
```
|
||||
|
||||
BMad 도움말은 다음을 답합니다.
|
||||
|
||||
- 현재 상황에 권장되는 선택지
|
||||
- 첫 번째 필수 작업
|
||||
- 나머지 과정의 모습
|
||||
|
||||
### 워크플로 끝에서도 동작합니다
|
||||
|
||||
BMad 도움말은 질문에 답하기만 하지 않습니다. **모든 워크플로 끝에서 자동으로 실행되어** 다음에 무엇을 해야 할지 알려줍니다. 추측하거나 문서를 뒤질 필요 없이 다음 필수 워크플로에 대한 명확한 안내를 받습니다.
|
||||
|
||||
:::tip[여기서 시작하세요]
|
||||
BMad를 설치한 뒤 바로 `bmad-help` 스킬을 호출하세요. 설치된 모듈을 감지하고 프로젝트에 맞는 시작점으로 안내합니다.
|
||||
:::
|
||||
|
||||
## BMad 이해하기
|
||||
|
||||
BMad는 전문 AI 에이전트가 있는 안내형 워크플로를 통해 소프트웨어를 만들도록 돕습니다. 과정은 네 단계로 진행됩니다.
|
||||
|
||||
| 단계 | 이름 | 일어나는 일 |
|
||||
| --- | --- | --- |
|
||||
| 1 | 분석 | 브레인스토밍, 리서치, 제품 개요 또는 PRFAQ *(선택)* |
|
||||
| 2 | 계획 | 요구사항 작성(PRD 또는 사양) |
|
||||
| 3 | 솔루션 설계 | 아키텍처 설계 *(BMad Method/엔터프라이즈 전용)* |
|
||||
| 4 | 구현 | 에픽별, 스토리별 구현 |
|
||||
|
||||
단계, 워크플로, 컨텍스트 관리를 살펴보려면 **[워크플로 맵 열기](../reference/workflow-map.md)**를 확인하세요.
|
||||
|
||||
프로젝트 복잡도에 따라 BMad는 세 가지 계획 트랙을 제공합니다.
|
||||
|
||||
| 트랙 | 적합한 경우 | 생성되는 문서 |
|
||||
| --- | --- | --- |
|
||||
| **빠른 흐름** | 버그 수정, 단순 기능, 명확한 범위(1-15개 스토리) | 기술 사양만 |
|
||||
| **BMad Method** | 제품, 플랫폼, 복잡한 기능(10-50개 이상 스토리) | PRD + 아키텍처 + UX |
|
||||
| **엔터프라이즈** | 컴플라이언스, 멀티테넌트 시스템(30개 이상 스토리) | PRD + 아키텍처 + 보안 + DevOps |
|
||||
|
||||
:::note
|
||||
스토리 수는 기준이 아니라 안내입니다. 스토리 수 계산보다 계획 필요성에 따라 트랙을 선택하세요.
|
||||
:::
|
||||
|
||||
## 설치
|
||||
|
||||
프로젝트 디렉터리에서 터미널을 열고 실행합니다.
|
||||
|
||||
```bash
|
||||
npx bmad-method install
|
||||
```
|
||||
|
||||
기본 릴리스 채널 대신 최신 사전 릴리스 빌드를 원한다면 `npx bmad-method@next install`을 사용하세요.
|
||||
|
||||
모듈 선택 프롬프트가 나오면 **BMad Method**를 선택합니다.
|
||||
|
||||
설치 프로그램은 두 폴더를 만듭니다.
|
||||
|
||||
- `_bmad/` - 에이전트, 워크플로, 작업, 설정
|
||||
- `_bmad-output/` - 지금은 비어 있지만 산출물이 저장될 위치입니다
|
||||
|
||||
:::tip[다음 단계]
|
||||
프로젝트 폴더에서 AI IDE를 열고 다음을 실행하세요.
|
||||
|
||||
```
|
||||
bmad-help
|
||||
```
|
||||
|
||||
BMad 도움말이 완료된 작업을 감지하고 정확한 다음 단계를 추천합니다. "내 선택지는 무엇인가요?" 또는 "SaaS 아이디어가 있는데 어디서 시작해야 하나요?"처럼 물어볼 수도 있습니다.
|
||||
:::
|
||||
|
||||
:::note[에이전트를 로드하고 워크플로를 실행하는 방법]
|
||||
각 워크플로에는 IDE에서 이름으로 호출하는 **스킬**이 있습니다(예: `bmad-prd`). AI 도구가 `bmad-*` 이름을 인식하고 실행하므로 에이전트를 따로 로드할 필요가 없습니다. 일반 대화를 위해 에이전트 스킬을 직접 호출할 수도 있습니다(예: PM 에이전트용 `bmad-agent-pm`).
|
||||
:::
|
||||
|
||||
:::caution[새 채팅]
|
||||
각 워크플로는 항상 새 채팅에서 시작하세요. 이렇게 하면 컨텍스트 제한으로 인한 문제를 예방할 수 있습니다.
|
||||
:::
|
||||
|
||||
## 1단계: 계획 만들기
|
||||
|
||||
1-3단계를 진행합니다. **각 워크플로는 새 채팅에서 실행하세요.**
|
||||
|
||||
:::tip[프로젝트 컨텍스트(선택)]
|
||||
시작하기 전에 `project-context.md`를 만들어 기술 선호도와 구현 규칙을 문서화하는 것을 고려하세요. 이렇게 하면 모든 AI 에이전트가 프로젝트 전반에서 당신의 규칙을 따릅니다.
|
||||
|
||||
`_bmad-output/project-context.md`에 직접 만들거나 아키텍처 이후 `bmad-generate-project-context`로 생성할 수 있습니다. [자세히 알아보기](../explanation/project-context.md).
|
||||
:::
|
||||
|
||||
### 1단계: 분석(선택)
|
||||
|
||||
이 단계의 모든 워크플로는 선택 사항입니다. [**무엇을 써야 할지 모르겠나요?**](../explanation/analysis-phase.md)
|
||||
|
||||
- **브레인스토밍**(`bmad-brainstorming`) - 안내형 아이디어 발산
|
||||
- **리서치**(`bmad-market-research` / `bmad-domain-research` / `bmad-technical-research`) - 시장, 도메인, 기술 리서치
|
||||
- **제품 개요**(`bmad-product-brief`) - 개념이 명확할 때 권장되는 기초 문서
|
||||
- **PRFAQ**(`bmad-prfaq`) - 제품 개념을 압박하고 다듬는 워킹 백워드 챌린지
|
||||
|
||||
### 2단계: 계획(필수)
|
||||
|
||||
**BMad Method 및 엔터프라이즈 트랙:**
|
||||
|
||||
1. 새 채팅에서 `bmad-prd`를 실행합니다. 의도(생성, 업데이트, 검증)를 직접 말하거나 스킬이 묻게 둡니다
|
||||
2. 출력: `prd.md`, `addendum.md`, `decision-log.md`
|
||||
|
||||
:::note[`bmad-prd` 의도]
|
||||
- **생성** - 처음부터 코칭형 발견 과정을 진행합니다. 스킬이 워크스페이스 폴더 이름을 정하고 만족할 만한 PRD까지 안내합니다
|
||||
- **업데이트** - 기존 PRD와 변경 신호를 지정합니다. 변경을 적용하기 전에 충돌을 드러냅니다
|
||||
- **검증** - 완료된 PRD를 체크리스트로 비평하고 HTML 발견 사항 보고서를 생성합니다
|
||||
:::
|
||||
|
||||
**빠른 흐름 트랙:**
|
||||
|
||||
- `bmad-quick-dev`를 실행합니다. 계획과 구현을 하나의 워크플로에서 처리하므로 구현 단계로 바로 넘어갑니다
|
||||
|
||||
:::note[UX 설계(선택)]
|
||||
프로젝트에 사용자 인터페이스가 있다면 PRD를 만든 뒤 **UX 디자이너 에이전트**(`bmad-agent-ux-designer`)를 호출하고 UX 설계 워크플로(`bmad-create-ux-design`)를 실행하세요.
|
||||
:::
|
||||
|
||||
### 3단계: 솔루션 설계(BMad Method/엔터프라이즈)
|
||||
|
||||
**아키텍처 만들기**
|
||||
|
||||
1. 새 채팅에서 **아키텍트 에이전트**(`bmad-agent-architect`)를 호출합니다
|
||||
2. `bmad-create-architecture`(`bmad-create-architecture`)를 실행합니다
|
||||
3. 출력: 기술 결정이 담긴 아키텍처 문서
|
||||
|
||||
**에픽과 스토리 만들기**
|
||||
|
||||
:::tip[V6 개선]
|
||||
이제 에픽과 스토리는 아키텍처 *이후* 생성됩니다. 데이터베이스, API 패턴, 기술 스택 같은 아키텍처 결정이 작업 분해 방식에 직접 영향을 주므로 스토리 품질이 좋아집니다.
|
||||
:::
|
||||
|
||||
1. 새 채팅에서 **PM 에이전트**(`bmad-agent-pm`)를 호출합니다
|
||||
2. `bmad-create-epics-and-stories`(`bmad-create-epics-and-stories`)를 실행합니다
|
||||
3. 워크플로는 PRD와 아키텍처를 모두 사용해 기술적 맥락이 반영된 스토리를 만듭니다
|
||||
|
||||
**구현 준비도 점검** *(강력 권장)*
|
||||
|
||||
1. 새 채팅에서 **아키텍트 에이전트**(`bmad-agent-architect`)를 호출합니다
|
||||
2. `bmad-check-implementation-readiness`(`bmad-check-implementation-readiness`)를 실행합니다
|
||||
3. 모든 계획 문서 간 응집성을 검증합니다
|
||||
|
||||
## 2단계: 프로젝트 만들기
|
||||
|
||||
계획이 완료되면 구현으로 이동합니다. **각 워크플로는 새 채팅에서 실행해야 합니다.**
|
||||
|
||||
### 스프린트 계획 초기화
|
||||
|
||||
**개발자 에이전트**(`bmad-agent-dev`)를 호출하고 `bmad-sprint-planning`(`bmad-sprint-planning`)을 실행합니다. 모든 에픽과 스토리를 추적하는 `sprint-status.yaml`이 생성됩니다.
|
||||
|
||||
### 빌드 사이클
|
||||
|
||||
각 스토리마다 새 채팅으로 이 사이클을 반복합니다.
|
||||
|
||||
| 단계 | 에이전트 | 워크플로 | 명령 | 목적 |
|
||||
| --- | --- | --- | --- | --- |
|
||||
| 1 | DEV | `bmad-create-story` | `bmad-create-story` | 에픽에서 스토리 파일 생성 |
|
||||
| 2 | DEV | `bmad-dev-story` | `bmad-dev-story` | 스토리 구현 |
|
||||
| 3 | DEV | `bmad-code-review` | `bmad-code-review` | 품질 검증 *(권장)* |
|
||||
|
||||
에픽의 모든 스토리를 완료한 뒤 **개발자 에이전트**(`bmad-agent-dev`)를 호출하고 `bmad-retrospective`(`bmad-retrospective`)를 실행합니다.
|
||||
|
||||
## 달성한 것
|
||||
|
||||
BMad로 빌드하는 기초를 배웠습니다.
|
||||
|
||||
- BMad를 설치하고 IDE에 맞게 설정했습니다
|
||||
- 선택한 계획 트랙으로 프로젝트를 초기화했습니다
|
||||
- 계획 문서(PRD, 아키텍처, 에픽과 스토리)를 만들었습니다
|
||||
- 구현을 위한 빌드 사이클을 이해했습니다
|
||||
|
||||
이제 프로젝트에는 다음이 있습니다.
|
||||
|
||||
```text
|
||||
your-project/
|
||||
├── _bmad/ # BMad 설정
|
||||
├── _bmad-output/
|
||||
│ ├── planning-artifacts/
|
||||
│ │ ├── PRD.md # 요구사항 문서
|
||||
│ │ ├── architecture.md # 기술 결정
|
||||
│ │ └── epics/ # 에픽과 스토리 파일
|
||||
│ ├── implementation-artifacts/
|
||||
│ │ └── sprint-status.yaml # 스프린트 추적
|
||||
│ └── project-context.md # 구현 규칙(선택)
|
||||
└── ...
|
||||
```
|
||||
|
||||
## 빠른 참조
|
||||
|
||||
| 워크플로 | 명령 | 에이전트 | 목적 |
|
||||
| --- | --- | --- | --- |
|
||||
| **`bmad-help`** | `bmad-help` | 무관 | **무엇이든 물어볼 수 있는 지능형 안내자** |
|
||||
| `bmad-prd` | `bmad-prd` | 무관 | PRD 생성, 업데이트 또는 검증 |
|
||||
| `bmad-create-architecture` | `bmad-create-architecture` | 아키텍트 | 아키텍처 문서 생성 |
|
||||
| `bmad-generate-project-context` | `bmad-generate-project-context` | 분석가 | 프로젝트 컨텍스트 파일 생성 |
|
||||
| `bmad-create-epics-and-stories` | `bmad-create-epics-and-stories` | PM | PRD를 에픽으로 분해 |
|
||||
| `bmad-check-implementation-readiness` | `bmad-check-implementation-readiness` | 아키텍트 | 계획 응집성 검증 |
|
||||
| `bmad-sprint-planning` | `bmad-sprint-planning` | DEV | 스프린트 추적 초기화 |
|
||||
| `bmad-create-story` | `bmad-create-story` | DEV | 스토리 파일 생성 |
|
||||
| `bmad-dev-story` | `bmad-dev-story` | DEV | 스토리 구현 |
|
||||
| `bmad-code-review` | `bmad-code-review` | DEV | 구현된 코드 리뷰 |
|
||||
|
||||
## 자주 묻는 질문
|
||||
|
||||
**항상 아키텍처가 필요한가요?**
|
||||
오직 BMad Method와 엔터프라이즈 트랙에서만 필요합니다. 빠른 흐름은 사양에서 구현으로 바로 넘어갑니다.
|
||||
|
||||
**나중에 계획을 바꿀 수 있나요?**
|
||||
네. `bmad-correct-course` 워크플로가 구현 중 범위 변경을 처리합니다.
|
||||
|
||||
**먼저 브레인스토밍하고 싶다면요?**
|
||||
PRD를 시작하기 전에 분석가 에이전트(`bmad-agent-analyst`)를 호출하고 `bmad-brainstorming`(`bmad-brainstorming`)을 실행하세요.
|
||||
|
||||
**엄격한 순서를 따라야 하나요?**
|
||||
반드시 그렇지는 않습니다. 흐름에 익숙해지면 위의 빠른 참조를 사용해 워크플로를 직접 실행할 수 있습니다.
|
||||
|
||||
## 도움 받기
|
||||
|
||||
:::tip[첫 번째 목적지: BMad 도움말]
|
||||
**언제든 `bmad-help`를 호출하세요.** 막혔을 때 가장 빠른 방법입니다. 무엇이든 물어보세요.
|
||||
|
||||
- "설치 후 무엇을 해야 하나요?"
|
||||
- "워크플로 X에서 막혔어요"
|
||||
- "Y에 대한 선택지는 무엇인가요?"
|
||||
- "지금까지 완료된 것을 보여 주세요"
|
||||
|
||||
BMad 도움말은 프로젝트를 검사하고 완료한 작업을 감지한 뒤 다음에 무엇을 해야 할지 정확히 알려줍니다.
|
||||
:::
|
||||
|
||||
- **워크플로 중** - 에이전트가 질문과 설명으로 안내합니다
|
||||
- **커뮤니티** - [Discord](https://discord.gg/gk8jAdXWmj)(#bmad-method-help, #report-bugs-and-issues)
|
||||
|
||||
## 핵심 요약
|
||||
|
||||
:::tip[이것만 기억하세요]
|
||||
- **`bmad-help`로 시작하세요** - 프로젝트와 선택지를 아는 지능형 안내자입니다
|
||||
- **항상 새 채팅을 사용하세요** - 각 워크플로마다 새 채팅을 시작합니다
|
||||
- **트랙이 중요합니다** - 빠른 흐름은 `bmad-quick-dev`를 사용하고, BMad Method/엔터프라이즈는 PRD와 아키텍처가 필요합니다
|
||||
- **BMad 도움말은 자동으로 실행됩니다** - 모든 워크플로는 다음 단계 안내로 끝납니다
|
||||
:::
|
||||
|
||||
시작할 준비가 되었나요? BMad를 설치하고 `bmad-help`를 호출한 뒤 안내에 따라 첫 흐름을 시작하세요.
|
||||
|
|
@ -1,6 +1,82 @@
|
|||
---
|
||||
name: bmad-brainstorming
|
||||
description: 'Facilitate interactive brainstorming sessions using diverse creative techniques and ideation methods. Use when the user says help me brainstorm or help me ideate.'
|
||||
description: Facilitate a brainstorming session using diverse creative techniques. Use when the user says 'help me brainstorm' or 'help me ideate'.
|
||||
---
|
||||
|
||||
Follow the instructions in ./workflow.md.
|
||||
# BMad Brainstorming
|
||||
|
||||
## Overview
|
||||
|
||||
You are a creative brainstorming coach. This skill runs a brainstorming session: someone brings a topic and wants to generate far more and far better ideas on it than they would alone — pushing past the obvious with sharper questions and harder constraints, with no rush to finish. The best sessions end with the user surprised by what came out.
|
||||
|
||||
The session runs in one of three stances, chosen by the user — set explicitly at the start, or already implied by how they asked: **Facilitator** (you never supply ideas — a forcing function for theirs), **Creative Partner** (you facilitate *and* play along, trading ideas), or **Ideate for me** (you run the whole session yourself and show them the result). The chosen stance holds for the whole run.
|
||||
|
||||
## Conventions
|
||||
|
||||
- Bare paths (e.g. `references/headless.md`) resolve from `{skill-root}` (where `customize.toml` lives); `{project-root}`-prefixed paths from the project working directory.
|
||||
- `{workflow.<name>}` resolves to fields in the merged `customize.toml` `[workflow]` table.
|
||||
|
||||
## On Activation
|
||||
|
||||
1. Resolve customization: `python3 {project-root}/_bmad/scripts/resolve_customization.py --skill {skill-root} --key workflow`. On failure, use a subagent to read `{skill-root}/customize.toml` directly with defaults.
|
||||
2. Run each `{workflow.activation_steps_prepend}` entry. Treat each `{workflow.persistent_facts}` entry as foundational context (`file:`-prefixed entries are paths/globs under `{project-root}` — load their contents; others are facts verbatim).
|
||||
3. Load `{project-root}/_bmad/core/config.yaml` (and `config.user.yaml` if present); resolve `{user_name}`, `{communication_language}`, `{document_output_language}`, `{output_folder}`, `{project_name}`, `{date}`. Missing → neutral defaults; never block.
|
||||
4. **If launched headless** (a machine signal, not a human asking for output — `references/headless.md` lists them): load `references/headless.md` and follow it for the whole run. It is the *only* context where you generate ideas yourself; never load it otherwise.
|
||||
5. **Otherwise (interactive):** greet `{user_name}` in `{communication_language}` and stay in it. Note that `bmad-party-mode` and `bmad-advanced-elicitation` are available any time. Glob `{workflow.output_dir}/*/.memlog.md`, read each frontmatter, and offer to resume any with `status` not `complete` (`## Resuming`) or start fresh (`## Run a Session`).
|
||||
|
||||
Run each `{workflow.activation_steps_append}` entry; if either hook list was non-empty, confirm every entry ran before continuing.
|
||||
|
||||
## Framing — hold this the whole run
|
||||
|
||||
These fight your defaults, in every mode; hold them deliberately. The stance you pick adds one more frame (`references/mode-*.md`) on top.
|
||||
|
||||
- **Aim past 100 ideas; resist concluding.** The urge to organize or wrap is the enemy of divergence — when in doubt, push for one more. Land only when the user is spent or the topic is mined out.
|
||||
- **Keep shifting the creative domain** — every 5–10 turns (or ~10 ideas when you're generating), usually by moving to the next technique.
|
||||
- **One prompt per message while in dialogue (Facilitator, Creative Partner); no multiple-choice menus.** Don't stack questions into a wall or hand a menu that invites lazy picking — both pull the user out of generating. The only exceptions are the two up-front *process* choices (stance, and the technique flow): *how* to run is theirs to pick; *what* to ideate never is.
|
||||
|
||||
**The memlog** is the session's memory: the single source every output builds from, and the file a resume reloads. Whatever isn't in it is gone. Log every idea, decision, question, and bit of user direction — anything you'd regret losing if the window closed — one line each, the gist in the user's meaning, in time order; never edit or reorder. Skip your prompts and small talk. All writes go through `scripts/memlog.py` (atomic; don't read it back mid-session — resume is the one exception):
|
||||
|
||||
- `memlog.py init --workspace {doc_workspace} --field topic="<topic>" --field goal="<goal>" --field mode="<facilitator|partner|autonomous>"` — create it once topic, goal, and stance are known.
|
||||
- `memlog.py append --workspace {doc_workspace} --type <kind> --text "<one-line gist>"` — log one entry. `--type` ∈ `idea`/`insight`/`question`/`decision`/`direction`/`technique` (a switch: `--text "started <name>"`); omit for a plain note. Add `--by user`/`--by coach` to mark authorship — **required in Creative Partner mode** (renders `(idea by user)`); skip it otherwise.
|
||||
- `memlog.py set --workspace {doc_workspace} --key status --value complete` — flip status at wrap-up.
|
||||
|
||||
(Each is `python3 {skill-root}/scripts/memlog.py …`.)
|
||||
|
||||
## Run a Session
|
||||
|
||||
Open with one compound question — **what are we brainstorming, and what's the goal or why behind it?** (plus any inputs or special requests). The why shapes technique choice and synthesis (*kids' iPhone apps to build with your own kids* vs. *to win market share* point different ways). If the kickoff already made both clear, skip the question and confirm; read anything they point you to. Derive a kebab-case `{topic_slug}` and bind `{doc_workspace} = {workflow.output_dir}/{workflow.output_folder_name}/`.
|
||||
|
||||
Now set the **stance** and the **technique batch** in one step — the composer page does both, so make it the default.
|
||||
|
||||
**The composer page (primary).** The file is `{skill-root}/assets/brain-selector.html`. With a customized catalog (overridden `{workflow.brain_methods}` or any `{workflow.additional_techniques}`), regenerate it first: `python3 {skill-root}/scripts/brain.py --file {workflow.brain_methods} [--extra {doc_workspace}/extra-techniques.json] html --out {doc_workspace}/brain-selector.html` (pass `--extra`, a JSON list of `{category, technique_name, description}`, when there are additional techniques; the file is then `{doc_workspace}/brain-selector.html`). Try to open it (`open` / `xdg-open` / `start`), then say, in one message: *"It should open in your browser — compose your session, click **Copy prompt**, and paste the result back. If it didn't open, open `<path>` yourself, or say 'let's do it in chat'."* You can't see their browser, so never claim it opened.
|
||||
|
||||
Read the pasted block: the **`Facilitation mode:`** line → the stance; the **listed techniques** (full category/name/description, some tagged `(random pick)`) → run them as given, no `list`/`show` needed; **`invent N`** / **`you choose N`** → see `## Choosing Techniques`.
|
||||
|
||||
**Or in chat.** If they can't open the page or would rather not, pick the stance here and choose techniques per `## Choosing Techniques`.
|
||||
|
||||
Either way, once the stance is known, create the memlog (the `init` above, with `--field mode=`) and load its frame for the rest of the run — Facilitator → `references/mode-facilitator.md`, Creative Partner → `references/mode-partner.md`, Ideate for me → `references/mode-autonomous.md`. Tell the user the memlog path: state is on disk now, so the session survives interruption.
|
||||
|
||||
## Choosing Techniques
|
||||
|
||||
For **Facilitator** and **Creative Partner**. (In **Ideate for me** you pick and run techniques yourself — see `references/mode-autonomous.md`.)
|
||||
|
||||
Most sessions arrive with a batch already composed on the page — run it as given (each technique's full text is in the paste; no `list`/`show` needed). Two parts of a paste delegate back to you:
|
||||
|
||||
- **`invent N`** (Inventive Flow) — invent N brand-new techniques on the fly. A line may scope an invention (`invent 1 new technique in the spirit of <category>`, from the page's per-category invent card) — when it does, honor that category's spirit. Announce the order, log each one's name + description, and offer to save a keeper to `{workflow.additional_techniques}` at wrap-up.
|
||||
- **`you choose N`** (Facilitator Chosen) — pick N techniques fitting the goal, `{workflow.favorite_techniques}` first; confirm exact names with a scoped `python3 {skill-root}/scripts/brain.py --file {workflow.brain_methods} list --category <cat>`. Never pull the library whole into context.
|
||||
|
||||
If they didn't use the page, load `references/in-chat-techniques.md` and pick the batch in chat (**3–4 is the sweet spot**).
|
||||
|
||||
Run each technique until it stops producing — log each idea, and the switch itself as a `technique` entry when you move on — then announce the new lens and let the change of technique do the domain-shifting. When the batch is spent, offer three paths: run another batch, **converge** to narrow and decide (`## Converging`), or wrap up (`## Wrap-Up`).
|
||||
|
||||
## Converging
|
||||
|
||||
The catalog is all *divergent* — built to generate. When the user is ready to narrow and decide (or asks to "pick"/"prioritize"/"make it real"), load `references/converge.md` and follow it; it ends by handing off to `## Wrap-Up`. Convergence is a distinct phase: never fold it into a generating batch, and don't push toward it while ideas are still flowing.
|
||||
|
||||
## Resuming
|
||||
|
||||
Picking up an existing session instead of starting fresh: load `references/resume.md` and follow it.
|
||||
|
||||
## Wrap-Up
|
||||
|
||||
Load `references/finalize.md` (after `## Converging`, or directly when the user is spent): synthesis, `status: complete`, artifacts.
|
||||
|
|
|
|||
|
|
@ -0,0 +1,239 @@
|
|||
# BMad Brainstorming Catalog — Deep Analysis
|
||||
|
||||
> Analysis of the brainstorming library (`assets/brain-methods.csv`) and the selection
|
||||
> experience (`assets/brain-selector.html`, generated by `scripts/brain.py`). Companion
|
||||
> data: `method-matrix.csv` (every method tagged on 4 axes).
|
||||
>
|
||||
> **Status (implemented, uncommitted for review):** CSV extended with `provenance` /
|
||||
> `good_for` / `audience` columns; 8 researched `classic` methods added (108 total);
|
||||
> `brain.py` now renders a "Proven & Professional" lead group, super-group ordering, a
|
||||
> "Great for" goal filter, and a per-category "Invent a … technique" card; convergence
|
||||
> shipped as `references/converge.md` (diverge → converge → finalize) and wired into
|
||||
> `SKILL.md`. Sections below are the rationale.
|
||||
|
||||
---
|
||||
|
||||
## 1. TL;DR
|
||||
|
||||
The catalog is strong, distinctive, and well-built. The opportunities are not "more methods" so much as **navigation and intent**:
|
||||
|
||||
1. **The selector sorts categories alphabetically.** There is no ordering/grouping layer, so the well-known professional methods (SCAMPER, Six Hats, Five Whys, etc.) are scattered across four categories and buried below `Absurdist` and `Biomimetic`. Enterprise users meet whimsy before they meet anything they recognize. → **Add a grouping + ordering layer; lead with a "Proven & Professional" group.**
|
||||
2. **Nothing connects the user's stated goal to technique choice.** The skill asks for the goal up front but then offers an alphabetical wall. The single highest-value addition is a **goal → technique affinity layer** so "I'm adding a feature to a brownfield app" surfaces a different short-list than "planning a sabbatical."
|
||||
3. **The catalog is 100% divergent (generative).** There is essentially no *convergence* (prioritize / cluster / decide). This is partly a sound principle and partly a real gap — see §5.
|
||||
4. **Real overlap exists**, but it's mostly "same cognitive move, different costume." Four mechanisms (perspective-shift, constraint, analogy, inversion) account for ~60 of 100 methods; sensory, questioning, systems, and time-shift are comparatively thin.
|
||||
5. **Descriptions should stay terse** — the brevity is correct. Only two targeted fixes are warranted: the `collaborative` category silently assumes multiple humans, and ~10 "vibe-only" methods lack an output anchor.
|
||||
6. **Per-category "invent on the fly" is a good idea** — but implement it as a generated synthetic card per section, not 13 near-duplicate CSV rows.
|
||||
|
||||
---
|
||||
|
||||
## 2. Method — how this was analyzed
|
||||
|
||||
Each of the 100 methods was tagged on **four independent axes** (see `method-matrix.csv`). Category alone only captures *aesthetic/mechanism*; these four axes are what expose grouping, overlap, gaps, and the goal-routing opportunity.
|
||||
|
||||
| Axis | Values | Answers |
|
||||
|---|---|---|
|
||||
| **Provenance** | `classic` · `signature` · `playful` | What goes in the enterprise "proven" group? |
|
||||
| **Mechanism** (primary + secondary) | inversion · analogy · perspective · constraint · decomposition · time-shift · systems · sensory · questioning · combination · provocation · convergence | Where is the catalog redundant vs thin? |
|
||||
| **Goal affinity** (multi) | feature · novel · personal · strategy · planning · diagnosis · unstuck | Given the user's goal, what should we recommend? |
|
||||
| **Audience** | solo · group · either | What breaks in a 1:1 user+LLM session? |
|
||||
|
||||
---
|
||||
|
||||
## 3. Findings
|
||||
|
||||
### 3a. Provenance — the "proven & professional" set exists, but is scattered
|
||||
|
||||
The methods an innovation consultant or enterprise facilitator would recognize by name are spread across `structured`, `deep`, `creative`, and `collaborative`. The **canonical core (~22)**:
|
||||
|
||||
> SCAMPER · Six Thinking Hats · Mind Mapping · Lotus Blossom · Crazy 8s · Disney Method ·
|
||||
> Starbursting · Morphological Analysis · Five Whys · Laddering · Causal Loop Mapping ·
|
||||
> First Principles · Reverse Brainstorming · Assumption Reversal · Worst Possible Idea ·
|
||||
> Provocation (PO) · Question Storming · Brainwriting/Round Robin · Yes-And · Random Stimulation ·
|
||||
> Role Playing · Analogical Thinking
|
||||
|
||||
A second tier is *recognizable-adjacent* (Concept Blending, Forced Relationships, Decision Tree, Solution Matrix, Failure Analysis/pre-mortem, Devil's Advocate, 1000x Budget). Everything else is `signature` (BMad-original, serious) or `playful` (the delight layer — `wild`, `absurdist`, `theatrical`, much of `quantum`/`cultural`).
|
||||
|
||||
**Recommendation — lead with "Proven & Professional."** Three ways to implement (pick in review):
|
||||
|
||||
- **Option A — Tag + generated lead section (recommended).** Add a `provenance` column to the CSV. `brain.py` renders a synthetic **"Proven & Professional"** section *first* (pulling all `classic`-tagged methods, cross-category), then the existing categories grouped and ordered (see §7). A method keeps its home category and also appears in the lead group. Pro: zero loss of mechanism categorization; enterprise sees credibility first. Con: those ~22 methods appear twice on the browse page (arguably fine — or filter them out of their home category).
|
||||
- **Option B — New `classic` category.** Move the ~22 into a single first category. Pro: simplest. Con: destroys the mechanism grouping (SCAMPER is *also* structured; Five Whys is *also* deep), and the category becomes a grab-bag.
|
||||
- **Option C — Two-level groups only, no provenance tag.** Reorder the 13 categories into super-groups (§7) so "serious" comes first, but don't pull classics out. Pro: cleanest data model. Con: doesn't actually cluster the *named* methods — they stay scattered within their categories.
|
||||
|
||||
My pick: **A.** It satisfies "professional methods grouped and shown first" literally, without flattening the taxonomy that makes the rest of the catalog shine.
|
||||
|
||||
### 3b. Mechanism — the catalog has four over-served "spines"
|
||||
|
||||
Primary-mechanism distribution across the 100:
|
||||
|
||||
| Mechanism | ~count | Read |
|
||||
|---|---|---|
|
||||
| **perspective-shift** | ~18 | Over-served. Role Playing, Six Hats, Persona, Alien, Ancestor Council, Inner Child, Future Self, Drunk Uncle, Golden Retriever, Infomercial… all "adopt another viewpoint," differentiated only by *who*. |
|
||||
| **constraint** | ~16 | Over-served. What If, the entire `constraint` category, 1000x, Post-Scarcity, Parallel Universe, Zombie, Quantum Tunneling, Permission Giving… all "add/remove/exaggerate a limit." |
|
||||
| **analogy / transfer** | ~12 | Healthy. Analogical, Metaphor, Cross-Pollination, Trait Transfer, Nature's Solutions, Fusion Cuisine, Proverb, Random Stimulation. |
|
||||
| **inversion** | ~11 | Healthy but clustered. Reverse, Assumption Reversal, Worst Idea, Anti-Solution, Failure Analysis, Devil's Advocate, Cursed Genie, Villain's Monologue, Trickster. |
|
||||
| **combination** | ~9 | Fine. |
|
||||
| **decomposition** | ~9 | Fine. |
|
||||
| **systems / emergence** | ~7 | Thin-ish (concentrated in `quantum`/`biomimetic`). |
|
||||
| **time-shift** | ~6 | Thin. |
|
||||
| **questioning** | ~5 | Thin. |
|
||||
| **sensory / intuitive** | ~5 | Thin (all in `introspective_delight`). |
|
||||
| **convergence** | ~1 | **Effectively absent** (only Superposition Collapse). See §5. |
|
||||
|
||||
**Takeaway:** the redundancy is not a defect to delete — the *costume* (a villain's monologue vs. a courtroom vs. "make it worse") is exactly what makes a 30th inversion technique feel fresh to a user. But a curator should know the catalog leans hard on perspective + constraint, and that **convergence is the one genuinely empty cell.** New methods (§6) should target the thin cells, not the spines.
|
||||
|
||||
### 3c. Goal affinity — the headline missing capability
|
||||
|
||||
`SKILL.md` already opens with *"what are we brainstorming, and what's the goal?"* — but that goal never routes technique selection. Mapping the matrix's `goal_affinity` tags gives a ready recommendation table. This is what powers "AI picks N" intelligently and what an enterprise user wants:
|
||||
|
||||
| Goal | Strong default techniques (lead picks **bold**) |
|
||||
|---|---|
|
||||
| **Build a feature** (greenfield/brownfield) | **First Principles**, **SCAMPER**, **Morphological Analysis**, Crazy 8s, Solution Matrix, Reverse Brainstorming, One Feature Only, Ship in 60 Minutes, Chaos Engineering, Cursed Genie (edge cases), Persona Journey, *+ new: Job to Be Done, Follow the Anomaly* |
|
||||
| **Novel concept / new product** | **Concept Blending**, **Cross-Pollination**, **Forced Relationships**, What If, Trait Transfer, Nature's Solutions, Fusion Cuisine, Emerging Tech Collision, Crank the Dial to 11, Quantum Tunneling |
|
||||
| **Personal / life decision** | **Future Self Interview**, **Values Archaeology**, **Laddering**, Six Hats, Ancestor Council, Proverb Mining, Mythic Frameworks, the `introspective_delight` set, *+ new: Build on What Works* |
|
||||
| **Strategy / positioning** | **Six Thinking Hats**, **Failure Analysis** (pre-mortem), Field Lines, Ecosystem Thinking, Utopia vs Dystopia, 1000x Budget, Disney Method, Relativity Frame Shift, Infomercial at 3AM, Predator & Prey |
|
||||
| **Concrete planning** (event/project) | **Mind Mapping**, **Lotus Blossom**, Morphological Analysis, Decision Tree, Six Hats, $0 Mandate, Constraint Roulette, Time Horizon Ladder |
|
||||
| **Root-cause / diagnosis** | **Five Whys**, **Causal Loop Mapping**, Failure Analysis, Constraint Mapping, Question Storming, Starbursting, Anti-Solution, Alien Anthropologist |
|
||||
| **Get unstuck / break fixation** | **Random Stimulation**, **Provocation**, **Worst Possible Idea**, Crank the Dial to 11, Constraint Roulette, Three Rounds of Stupid, Drunk History, most of `wild`/`absurdist`/`theatrical` |
|
||||
|
||||
**Recommendation:** persist this as machine-readable affinity (a `goals` column on the CSV, sourced from `method-matrix.csv`), then (1) have the skill recommend a batch from the up-front goal, and (2) let the composer page filter/highlight "great for: [your goal]." This is the single change that most improves both enterprise and casual use.
|
||||
|
||||
### 3d. Audience — the `collaborative` category quietly assumes a room of people
|
||||
|
||||
5 of the 8 `collaborative` methods (Round Robin, Relay Race, Hot Potato, Fold the Paper, Steal & Upgrade) are written for *multiple humans passing artifacts*. In the default 1:1 user+LLM session they don't translate without the coach silently reinterpreting them. This is the one place the catalog can mislead. Options: tag `audience`, and either (a) add a one-clause solo adaptation to each, or (b) have the skill note "this one shines with a group" when picked solo. Low effort, removes the only real footgun.
|
||||
|
||||
### 3e. Description anchoring — keep terse, fix ~12 specifically
|
||||
|
||||
The deliberate brevity is **right** — the gist + a creative LLM beats over-specification, and it matches the catalog's house style. Do **not** bulk-expand. Two surgical passes only:
|
||||
|
||||
1. **Group-dependent `collaborative` methods** (§3d) — add a short solo-mode clause or an audience tag.
|
||||
2. **~10 "vibe-only" methods** where the *evocation is great but the output is ambiguous*, so different LLM runs would diverge wildly: e.g. **Field Lines**, **Observer Effect**, **Guerrilla Gardening Ideas**, **Emergent Thinking**, **Entanglement Thinking**, **Elemental Forces**. A tiny "…so that ___" outcome clause anchors the deliverable without killing the brevity. Example: *Guerrilla Gardening Ideas* → add "…**so you surface where an unsanctioned, low-visibility pilot could prove the idea before anyone can veto it**."
|
||||
|
||||
Everything crisp (Five Whys, SCAMPER, First Principles, Crazy 8s) stays untouched.
|
||||
|
||||
---
|
||||
|
||||
## 4. Quick wins vs structural changes
|
||||
|
||||
| Change | Effort | Impact | Type |
|
||||
|---|---|---|---|
|
||||
| Goal→technique affinity (`goals` column + recommendation) | Med | **High** | structural |
|
||||
| "Proven & Professional" lead group + category ordering | Med | **High** (enterprise) | structural |
|
||||
| Per-category "invent in the spirit" card (§6) | Low | Med | quick win |
|
||||
| Convergence mini-set (§5) | Low–Med | Med–High | structural (philosophy) |
|
||||
| `audience` tag + collaborative fix (§3d) | Low | Med | quick win |
|
||||
| ~12 description anchors (§3e) | Low | Low–Med | quick win |
|
||||
| New gap-filling methods (§6) | Low | Med | additive |
|
||||
|
||||
---
|
||||
|
||||
## 5. Divergent vs convergent — the answer, and a recommendation
|
||||
|
||||
**What it is.** Divergent = generate (quantity, novelty, breadth). Convergent = evaluate, cluster, prioritize, decide. A complete creative process needs both (cf. the Double Diamond, Osborn-Parnes CPS): diverge wide, *then* converge to a choice.
|
||||
|
||||
**Where the catalog stands.** All 100 methods are divergent. `SKILL.md` explicitly enforces divergence ("resist concluding… the urge to organize is the enemy of divergence"), and the only convergent-flavored technique is Quantum → *Superposition Collapse*. Synthesis is deferred entirely to `references/finalize.md` at wrap-up.
|
||||
|
||||
**Is that a mistake?** Mostly a *good instinct taken to a defensible extreme.* Separating generation from judgment is the foundational brainstorming rule — premature convergence is the #1 killer of ideas, so a divergence-pure generator is legitimate. But the consequence is that the user has **no technique to pick when they're ready to narrow** — they hit "100 ideas" and the tool's stance is "keep going," with only the wrap-up doing light synthesis. For project/feature/life-decision work especially, people *do* want to land.
|
||||
|
||||
**Recommendation — add a small, fenced convergence set, never mixed into the divergent flow.** Keep divergence pure during generation; offer convergence only at wrap-up or on explicit request ("okay, help me narrow"). Concretely: a new `converge` category (4 methods, §6), tagged `mechanism=convergence`, surfaced by `finalize.md` / on demand — not in the default 3–4 sweet-spot batch. This completes the loop while honoring the separate-generation-from-judgment principle. **This is a philosophy decision for you to confirm** — it's the one recommendation that changes what the skill *is*, not just what's in the library.
|
||||
|
||||
---
|
||||
|
||||
## 6. Proposed new methods (fill the thin cells)
|
||||
|
||||
Targeting the under-served mechanisms (§3b), the empty convergence cell (§5), and the goal gaps (§3c). CSV-style (`category, name, description`) so they can drop straight in:
|
||||
|
||||
**Feature/product & enterprise gaps (mechanism: questioning/decomposition):**
|
||||
- `structured, Job to Be Done, "Ask what the user is really hiring this to do; brainstorm around that underlying job, not the feature you assumed"`
|
||||
- `structured, Empathy Map, "Map what the user says, thinks, does, and feels around the problem; mine each quadrant for the unmet need hiding there"`
|
||||
- `deep, Follow the Anomaly, "Start from one surprising number or outlier and ideate only from what would explain it or exploit it"`
|
||||
|
||||
**Strengths-based (the missing positive frame — Appreciative Inquiry is a glaring classic-tier omission):**
|
||||
- `deep, Build on What Works, "Name what's already succeeding and why, then ideate how to amplify and extend it instead of fixing what's broken"`
|
||||
|
||||
**Convergence set (new `converge` category — only if §5 is adopted):**
|
||||
- `converge, Impact Effort Triage, "Plot every idea by impact against effort; harvest the high-impact, low-effort quadrant first and quarantine the rest"`
|
||||
- `converge, Forced Ranking, "Make the ideas fight: each must beat another to survive to a ranked top-N, no ties allowed"`
|
||||
- `converge, NUF Test, "Score each idea New, Useful, Feasible 1-10; the totals expose the quiet winners and the dazzling dead-ends"`
|
||||
- `converge, Affinity Clustering, "Group the raw ideas into themes, name each cluster, then ideate fresh at the theme level"`
|
||||
|
||||
(Optional, lower priority: `structured, Storyboarding` for sequenced/experience ideation.)
|
||||
|
||||
---
|
||||
|
||||
## 7. Category roster & ordering recommendations
|
||||
|
||||
**Ordering (replace alphabetical with a deliberate progression):** add a `CATEGORY_ORDER` + `GROUP` map in `brain.py` (mirroring the existing `_HUES` map — derived for the shipped set, alphabetical fallback for custom catalogs). Proposed super-groups, in order:
|
||||
|
||||
1. **Proven & Professional** — the `classic` lead section (§3a, Option A)
|
||||
2. **Structured & Analytical** — structured, deep
|
||||
3. **Creative & Generative** — creative, biomimetic, cultural, speculative_future, quantum
|
||||
4. **Wild & Playful** — wild, absurdist, theatrical, constraint
|
||||
5. **Introspective & Personal** — introspective_delight, collaborative
|
||||
6. **Decide & Converge** — converge *(if §5 adopted)*
|
||||
|
||||
**Roster notes:**
|
||||
- No category should be deleted. The overlap (§3b) is intentional costume variety.
|
||||
- `quantum` and `cultural` are the most abstract/uneven — a couple of their members (Field Lines, Observer Effect) are the vaguest in the whole set; anchor per §3e rather than cut.
|
||||
- `constraint` is excellent and tight — leave as is.
|
||||
|
||||
---
|
||||
|
||||
## 8. Per-category "invent in the spirit of this category"
|
||||
|
||||
You asked whether each category should also offer an on-the-fly invented technique in its own spirit. **Yes — but don't add 13 near-duplicate rows to the CSV.** The composer already has a global **Invent N** stepper, and `brain.py` already generates section markup from the catalog. So:
|
||||
|
||||
> Have `brain.py` append **one synthetic card per category section** — a dashed "✨ Invent a *{Category}* technique" card. Selecting it emits a paste directive like `invent 1 (in the spirit of {category})`, reused by the existing Inventive-Flow plumbing in `SKILL.md` (which already handles `invent N` and offering keepers to `additional_techniques`).
|
||||
|
||||
Benefits: CSV stays a clean library of *real* techniques; behavior is consistent everywhere; it leverages plumbing that already exists; and it gives the user the "surprise me, but on-theme" affordance per category without library bloat.
|
||||
|
||||
---
|
||||
|
||||
## 9. Open decisions for BMad (in priority order)
|
||||
|
||||
1. **Goal-affinity layer** — adopt the `goals` column + recommendation routing? (Highest impact.)
|
||||
2. **Proven & Professional grouping** — Option A (tag + generated lead section, recommended), B, or C? (§3a)
|
||||
3. **Convergence** — add the fenced `converge` set, or stay divergence-pure? (§5 — philosophy decision.)
|
||||
4. **New methods** — approve the §6 set? Which ones?
|
||||
5. **Per-category invent card** — approve the generated-card approach? (§8)
|
||||
6. **Description anchoring** — approve the targeted ~12 (incl. collaborative fix), keep everything else terse? (§3e)
|
||||
7. **Category ordering / super-groups** — adopt §7?
|
||||
|
||||
Once you mark these, the implementation is: extend the CSV schema (`provenance`, `good_for`, `audience` columns — additive, backward-compatible with `brain.py`'s `DictReader`), add the ordering/grouping + synthetic-card logic to `brain.py`, regenerate `brain-selector.html`, update the relevant `SKILL.md` / `references/*` flow, and run `scripts/tests/`.
|
||||
|
||||
---
|
||||
|
||||
## 10. Revised convergence architecture (per BMad direction)
|
||||
|
||||
**Decision locked:** convergence is **not** a CSV category of selectable cards. It's a **reference phase**, mirroring `references/finalize.md`. The catalog stays a pure *divergent* library; convergence lives in `references/converge.md`.
|
||||
|
||||
**Flow:** diverge (pick & run techniques) → **converge** (`references/converge.md`, on demand or once divergence is spent) → **finalize** (`references/finalize.md`, last). The coach already does ad-hoc convergence implicitly; this makes it an explicit, repeatable phase, and `converge.md` ends by instructing the coach to load `finalize.md` to synthesize and produce artifacts.
|
||||
|
||||
`references/converge.md` contents — a tight set of real, established convergence moves (the coach picks what fits, never dumps a menu):
|
||||
|
||||
- **Affinity Clustering (KJ method)** — group the raw ideas into themes, name each cluster, surface the through-line.
|
||||
- **Dot Voting / Multivoting** — heat-map the favorites; discuss why the hot spots are hot.
|
||||
- **Impact–Effort Matrix** — plot each idea on impact vs effort; harvest high-impact/low-effort first.
|
||||
- **NUF Test** — score New, Useful, Feasible (1–10 each); totals expose quiet winners and dazzling dead-ends.
|
||||
- **PMI (Plus / Minus / Interesting)** — de Bono's fast evaluator for pressure-testing a single strong candidate.
|
||||
- *(optional)* **MoSCoW** (Must/Should/Could/Won't) for product scoping; **Nominal Group Technique** when it's genuinely a group.
|
||||
|
||||
`SKILL.md` change: at the point where a divergent batch is spent, offer "keep diverging / converge & decide / wrap up" — "converge & decide" loads `converge.md`; wrap-up still goes to `finalize.md`.
|
||||
|
||||
## 11. Researched gap-filling additions (real, established methods)
|
||||
|
||||
Web-researched (sources below), chosen to fill the **thin mechanism cells** (questioning, diagnosis, time-shift, empathy) — *not* the over-served spines — and all `classic`-tier, so they also strengthen the "Proven & Professional" group. CSV-style, ready to drop in:
|
||||
|
||||
| Category | Technique | Gist (house style) | Fills |
|
||||
|---|---|---|---|
|
||||
| structured | **How Might We** | "Reframe the problem as a batch of 'How might we…' opportunity questions first, then ideate against the sharpest one" | questioning / problem-framing (design-thinking staple, currently absent) |
|
||||
| deep | **TRIZ Contradiction** | "Name the core contradiction — what only improves by making something else worse — then brainstorm ways to win both instead of trading off" | engineering/feature (no systematic technical method today) |
|
||||
| deep | **Fishbone Diagram** | "Branch the problem's spine into cause categories — people, process, tools, environment — and mine each bone for contributing causes" | diagnosis (named classic complementing Five Whys / Causal Loop) |
|
||||
| structured | **Backcasting** | "Fix the finished future in vivid detail, then work backward step by step to the one move you'd have to make first" | strategy/planning time-shift (serious counterpart to playful future methods) |
|
||||
| speculative_future | **Scenario Cross** | "Pick two high-impact uncertainties, cross them into four futures, and ideate the move that wins in every one" | strategy (2×2 scenario planning — the serious sibling of the playful speculative set) |
|
||||
| structured | **Job to Be Done** | "Ask what the user is really hiring this to do, then ideate around that underlying job, not the feature you assumed" | feature/empathy (enterprise staple) |
|
||||
| structured | **Empathy Map** | "Map what the user says, thinks, does, and feels around the problem; mine each quadrant for the unmet need" | empathy/feature |
|
||||
| deep | **Build on What Works** | "Name what's already succeeding and why, then ideate how to amplify and extend it instead of fixing what's broken" | strengths-based (Appreciative Inquiry — a glaring classic-tier omission) |
|
||||
|
||||
Deliberately **not** added (would deepen an already over-served spine or duplicate): Synectics (≈ analogy/metaphor), SWOT (analysis, not ideation), Rolestorming (≈ Role Playing), Brainwalking/Braindumping (≈ Brainwriting), Pre-mortem (≈ Failure Analysis).
|
||||
|
||||
**Sources:** [IxDF — essential ideation techniques](https://ixdf.org/literature/article/introduction-to-the-essential-ideation-techniques-which-are-the-heart-of-design-thinking) · [Quality Magazine — TRIZ](https://www.qualitymag.com/articles/98566-triz-the-backbone-of-innovation-and-problem-solving) · [ASQ — Fishbone/Ishikawa](https://asq.org/quality-resources/fishbone) · [Futures Platform — 2×2 scenario matrix](https://www.futuresplatform.com/blog/2x2-scenario-planning-matrix-guideline) · [NN/g — Dot Voting](https://www.nngroup.com/articles/dot-voting/) · [Quality Gurus — divergent vs convergent](https://www.qualitygurus.com/divergent-vs-convergent-thinking/)
|
||||
|
|
@ -0,0 +1,109 @@
|
|||
category,technique,provenance,mechanism_primary,mechanism_secondary,goal_affinity,audience
|
||||
collaborative,Yes And Building,classic,combination,perspective,novel|unstuck|planning,group
|
||||
collaborative,Brain Writing Round Robin,classic,combination,decomposition,novel|feature,group
|
||||
collaborative,Random Stimulation,classic,analogy,,unstuck|novel,either
|
||||
collaborative,Role Playing,classic,perspective,,strategy|personal|feature,either
|
||||
collaborative,Ideation Relay Race,playful,combination,,unstuck,group
|
||||
collaborative,Idea Hot Potato,playful,combination,,unstuck,group
|
||||
collaborative,Steal And Upgrade,signature,combination,analogy,novel|unstuck,group
|
||||
collaborative,Fold The Paper,playful,combination,,unstuck|novel,group
|
||||
creative,What If Scenarios,signature,constraint,,novel|strategy|unstuck,either
|
||||
creative,Analogical Thinking,signature,analogy,,feature|novel|diagnosis,either
|
||||
creative,First Principles Thinking,classic,decomposition,,feature|novel|diagnosis|strategy,either
|
||||
creative,Forced Relationships,signature,combination,analogy,novel|unstuck,either
|
||||
creative,Time Shifting,signature,time-shift,perspective,novel|unstuck,either
|
||||
creative,Metaphor Mapping,signature,analogy,,novel|diagnosis,either
|
||||
creative,Cross-Pollination,signature,analogy,,novel|feature|strategy,either
|
||||
creative,Concept Blending,signature,combination,,novel,either
|
||||
creative,Reverse Brainstorming,classic,inversion,,diagnosis|feature|unstuck,either
|
||||
creative,Sensory Exploration,signature,sensory,,novel|unstuck,either
|
||||
deep,Five Whys,classic,questioning,,diagnosis,either
|
||||
deep,Provocation Technique,classic,provocation,inversion,unstuck|novel,either
|
||||
deep,Assumption Reversal,classic,inversion,,novel|diagnosis|strategy,either
|
||||
deep,Question Storming,classic,questioning,,diagnosis|strategy|unstuck,either
|
||||
deep,Constraint Mapping,signature,constraint,decomposition,feature|strategy|diagnosis,either
|
||||
deep,Failure Analysis,signature,inversion,diagnosis,diagnosis|strategy|feature,either
|
||||
deep,Emergent Thinking,signature,systems,,strategy|novel,either
|
||||
deep,Causal Loop Mapping,classic,systems,,diagnosis|strategy,either
|
||||
deep,Morphological Analysis,classic,decomposition,combination,feature|novel|planning,either
|
||||
deep,Laddering,classic,questioning,decomposition,personal|strategy|diagnosis,either
|
||||
introspective_delight,Inner Child Conference,signature,perspective,sensory,personal|unstuck,solo
|
||||
introspective_delight,Shadow Work Mining,signature,sensory,,personal|diagnosis,solo
|
||||
introspective_delight,Values Archaeology,signature,questioning,,personal|strategy,solo
|
||||
introspective_delight,Future Self Interview,signature,perspective,time-shift,personal,solo
|
||||
introspective_delight,Body Wisdom Dialogue,signature,sensory,,personal,solo
|
||||
introspective_delight,Permission Giving,signature,provocation,constraint,personal|unstuck,solo
|
||||
introspective_delight,Secret Wish Confession,signature,sensory,,personal,solo
|
||||
introspective_delight,Mood Weather Report,signature,sensory,,personal|unstuck,solo
|
||||
structured,SCAMPER Method,classic,combination,decomposition,feature|novel,either
|
||||
structured,Six Thinking Hats,classic,perspective,,strategy|diagnosis|planning|personal,either
|
||||
structured,Decision Tree Mapping,signature,decomposition,,planning|strategy|diagnosis,either
|
||||
structured,Solution Matrix,signature,decomposition,,feature|planning,either
|
||||
structured,Trait Transfer,signature,analogy,,novel|feature,either
|
||||
structured,Lotus Blossom,classic,decomposition,,feature|planning|novel,either
|
||||
structured,Worst Possible Idea,classic,inversion,,unstuck|novel,either
|
||||
structured,Disney Method,classic,perspective,,feature|strategy|planning,either
|
||||
structured,Starbursting,classic,questioning,,feature|planning|diagnosis,either
|
||||
structured,Mind Mapping,classic,decomposition,,planning|novel|feature,either
|
||||
structured,Crazy 8s,classic,combination,,feature|novel|unstuck,either
|
||||
theatrical,Time Travel Talk Show,playful,perspective,time-shift,novel|personal,either
|
||||
theatrical,Alien Anthropologist,playful,perspective,,diagnosis|unstuck|strategy,either
|
||||
theatrical,Dream Fusion Laboratory,signature,constraint,time-shift,novel|unstuck,either
|
||||
theatrical,Emotion Orchestra,playful,sensory,perspective,personal|strategy,either
|
||||
theatrical,Parallel Universe Cafe,playful,constraint,,novel|unstuck,either
|
||||
theatrical,Persona Journey,signature,perspective,,feature|strategy,either
|
||||
theatrical,Devil's Advocate Courtroom,signature,inversion,perspective,strategy|diagnosis,group
|
||||
wild,Chaos Engineering,signature,inversion,constraint,feature|diagnosis|strategy,either
|
||||
wild,Guerrilla Gardening Ideas,playful,analogy,,strategy|unstuck,either
|
||||
wild,Pirate Code Brainstorm,playful,combination,analogy,novel|unstuck,either
|
||||
wild,Zombie Apocalypse Planning,playful,constraint,,feature|strategy|unstuck,either
|
||||
wild,Drunk History Retelling,playful,perspective,,unstuck|diagnosis,either
|
||||
wild,Anti-Solution,signature,inversion,,diagnosis|unstuck,either
|
||||
wild,Elemental Forces,playful,perspective,analogy,novel|unstuck,either
|
||||
biomimetic,Nature's Solutions,signature,analogy,,feature|novel,either
|
||||
biomimetic,Ecosystem Thinking,signature,systems,,strategy|diagnosis,either
|
||||
biomimetic,Evolutionary Pressure,signature,systems,,feature|novel,either
|
||||
biomimetic,Predator & Prey,signature,perspective,inversion,strategy|feature,either
|
||||
biomimetic,Metamorphosis Stages,signature,time-shift,decomposition,novel|strategy,either
|
||||
biomimetic,Swarm Logic,signature,systems,,feature|strategy,either
|
||||
quantum,Observer Effect,signature,systems,perspective,strategy|diagnosis,either
|
||||
quantum,Entanglement Thinking,signature,systems,,diagnosis|strategy,either
|
||||
quantum,Superposition Collapse,signature,convergence,decomposition,strategy|diagnosis,either
|
||||
quantum,Relativity Frame Shift,signature,perspective,,strategy|novel,either
|
||||
quantum,Field Lines,signature,systems,,strategy,either
|
||||
quantum,Quantum Tunneling,signature,constraint,,unstuck|novel,either
|
||||
cultural,Indigenous Wisdom,signature,perspective,analogy,personal|strategy|novel,either
|
||||
cultural,Fusion Cuisine,signature,combination,analogy,novel,either
|
||||
cultural,Ritual Innovation,signature,analogy,,novel|personal,either
|
||||
cultural,Mythic Frameworks,signature,analogy,perspective,strategy|personal|novel,either
|
||||
cultural,Proverb Mining,signature,analogy,,personal|strategy,either
|
||||
cultural,Ancestor Council,signature,perspective,,personal|strategy,either
|
||||
cultural,Trickster's Gambit,playful,inversion,provocation,unstuck|strategy,either
|
||||
absurdist,Villain's Monologue,playful,inversion,perspective,diagnosis|strategy|unstuck,either
|
||||
absurdist,Explain It to a Golden Retriever,playful,perspective,,unstuck|diagnosis|feature,either
|
||||
absurdist,Infomercial at 3AM,playful,perspective,,strategy|novel,either
|
||||
absurdist,Drunk Uncle at Thanksgiving,playful,perspective,,unstuck|diagnosis,either
|
||||
absurdist,Cursed Genie,playful,inversion,,diagnosis|feature,either
|
||||
absurdist,Three Rounds of Stupid,playful,provocation,,unstuck|novel,either
|
||||
constraint,Kill the Crown Jewel,signature,constraint,,feature|strategy|unstuck,either
|
||||
constraint,1000x Budget,signature,constraint,,novel|strategy,either
|
||||
constraint,Ship in 60 Minutes,signature,constraint,,feature|planning|unstuck,either
|
||||
constraint,The $0 Mandate,signature,constraint,,planning|strategy|feature,either
|
||||
constraint,One Feature Only,signature,constraint,,feature|strategy,either
|
||||
constraint,Crank the Dial to 11,signature,constraint,,novel|unstuck,either
|
||||
constraint,Constraint Roulette,signature,constraint,,unstuck|feature,either
|
||||
speculative_future,Time Horizon Ladder,signature,time-shift,,strategy|planning|novel,either
|
||||
speculative_future,Post-Scarcity Test,signature,constraint,,novel|strategy,either
|
||||
speculative_future,Utopia vs Dystopia Split-Screen,signature,perspective,inversion,strategy|diagnosis,either
|
||||
speculative_future,Sci-Fi Artifact From the Future,signature,time-shift,perspective,novel|feature,either
|
||||
speculative_future,Emerging Tech Collision,signature,combination,,novel|feature|strategy,either
|
||||
speculative_future,What-If-The-World-Changed Card Flip,signature,constraint,,novel|unstuck,either
|
||||
speculative_future,Future Anthropologist Dig,signature,time-shift,perspective,strategy|novel,either
|
||||
structured,How Might We,classic,questioning,,feature|novel|strategy|diagnosis,either
|
||||
structured,Job to Be Done,classic,perspective,questioning,feature|strategy|novel,either
|
||||
structured,Empathy Map,classic,perspective,,feature|personal,either
|
||||
structured,Backcasting,classic,time-shift,,strategy|planning|novel,either
|
||||
deep,TRIZ Contradiction,classic,inversion,decomposition,feature|novel|diagnosis,either
|
||||
deep,Fishbone Diagram,classic,decomposition,systems,diagnosis,either
|
||||
deep,Build on What Works,classic,perspective,systems,personal|strategy,either
|
||||
speculative_future,Scenario Cross,classic,constraint,systems,strategy|planning,either
|
||||
|
|
|
@ -0,0 +1,166 @@
|
|||
{
|
||||
"categories": {
|
||||
"creative": {
|
||||
"hue": "#6d5cf0",
|
||||
"glyph": "<g stroke=\"currentColor\" stroke-width=\"2.4\" stroke-linecap=\"round\"><line x1=\"22\" y1=\"6.5\" x2=\"22\" y2=\"12.5\"/><line x1=\"22\" y1=\"31.5\" x2=\"22\" y2=\"37.5\"/><line x1=\"6.5\" y1=\"22\" x2=\"12.5\" y2=\"22\"/><line x1=\"31.5\" y1=\"22\" x2=\"37.5\" y2=\"22\"/><line x1=\"11.3\" y1=\"11.3\" x2=\"15.5\" y2=\"15.5\"/><line x1=\"28.5\" y1=\"28.5\" x2=\"32.7\" y2=\"32.7\"/><line x1=\"32.7\" y1=\"11.3\" x2=\"28.5\" y2=\"15.5\"/><line x1=\"15.5\" y1=\"28.5\" x2=\"11.3\" y2=\"32.7\"/></g><circle cx=\"22\" cy=\"22\" r=\"6.6\" fill=\"currentColor\" fill-opacity=\"0.25\"/><circle cx=\"22\" cy=\"22\" r=\"3.6\" fill=\"currentColor\"/>"
|
||||
},
|
||||
"deep": {
|
||||
"hue": "#4658c9",
|
||||
"glyph": "<g fill=\"none\" stroke=\"currentColor\"><circle cx=\"22\" cy=\"22\" r=\"13\" stroke-width=\"1.5\" stroke-opacity=\"0.4\"/><circle cx=\"22\" cy=\"22\" r=\"9\" stroke-width=\"1.7\" stroke-opacity=\"0.7\"/><circle cx=\"22\" cy=\"22\" r=\"5\" stroke-width=\"1.9\"/></g><circle cx=\"22\" cy=\"22\" r=\"2.4\" fill=\"currentColor\"/>"
|
||||
},
|
||||
"structured": {
|
||||
"hue": "#3b6ea5",
|
||||
"glyph": "<g fill=\"currentColor\"><rect x=\"11\" y=\"11\" width=\"9.5\" height=\"9.5\" rx=\"2\"/><rect x=\"23.5\" y=\"11\" width=\"9.5\" height=\"9.5\" rx=\"2\" fill-opacity=\"0.25\"/><rect x=\"11\" y=\"23.5\" width=\"9.5\" height=\"9.5\" rx=\"2\" fill-opacity=\"0.25\"/><rect x=\"23.5\" y=\"23.5\" width=\"9.5\" height=\"9.5\" rx=\"2\"/></g>"
|
||||
},
|
||||
"quantum": {
|
||||
"hue": "#2b86d9",
|
||||
"glyph": "<g stroke=\"currentColor\" stroke-width=\"1.8\" fill=\"none\"><ellipse cx=\"22\" cy=\"22\" rx=\"14.5\" ry=\"6\" transform=\"rotate(28 22 22)\"/><ellipse cx=\"22\" cy=\"22\" rx=\"14.5\" ry=\"6\" transform=\"rotate(-28 22 22)\"/></g><circle cx=\"22\" cy=\"22\" r=\"6.6\" fill=\"currentColor\" fill-opacity=\"0.18\"/><circle cx=\"22\" cy=\"22\" r=\"3.4\" fill=\"currentColor\"/><circle cx=\"33.2\" cy=\"17.4\" r=\"2\" fill=\"currentColor\"/>"
|
||||
},
|
||||
"speculative_future": {
|
||||
"hue": "#0fb5c9",
|
||||
"glyph": "<g stroke=\"currentColor\" stroke-width=\"2.2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" fill=\"none\"><path d=\"M11 31 L 26.5 15.5\"/><path d=\"M20 14.5 H 28 V 22.5\"/></g><circle cx=\"31\" cy=\"12\" r=\"2.8\" fill=\"currentColor\"/><g stroke=\"currentColor\" stroke-width=\"1.4\" stroke-linecap=\"round\"><line x1=\"31\" y1=\"6.5\" x2=\"31\" y2=\"8.4\"/><line x1=\"31\" y1=\"15.6\" x2=\"31\" y2=\"17.5\"/><line x1=\"25.5\" y1=\"12\" x2=\"27.4\" y2=\"12\"/><line x1=\"34.6\" y1=\"12\" x2=\"36.5\" y2=\"12\"/></g>"
|
||||
},
|
||||
"collaborative": {
|
||||
"hue": "#15a3a3",
|
||||
"glyph": "<g stroke=\"currentColor\" stroke-width=\"1.8\"><line x1=\"14\" y1=\"16\" x2=\"30\" y2=\"16\"/><line x1=\"14\" y1=\"16\" x2=\"22\" y2=\"30\"/><line x1=\"30\" y1=\"16\" x2=\"22\" y2=\"30\"/></g><g fill=\"currentColor\" fill-opacity=\"0.22\"><circle cx=\"14\" cy=\"16\" r=\"4.6\"/><circle cx=\"30\" cy=\"16\" r=\"4.6\"/><circle cx=\"22\" cy=\"30\" r=\"4.6\"/></g><g fill=\"currentColor\"><circle cx=\"14\" cy=\"16\" r=\"2.4\"/><circle cx=\"30\" cy=\"16\" r=\"2.4\"/><circle cx=\"22\" cy=\"30\" r=\"2.4\"/></g>"
|
||||
},
|
||||
"biomimetic": {
|
||||
"hue": "#1f9d6b",
|
||||
"glyph": "<path d=\"M22 7.5 C 31.5 12.5, 31.5 29, 22 36.5 C 12.5 29, 12.5 12.5, 22 7.5 Z\" fill=\"currentColor\" fill-opacity=\"0.22\"/><path d=\"M22 9 V 35.5\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\" fill=\"none\"/><g stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\"><path d=\"M22 16 l5.6 -2.6\"/><path d=\"M22 16 l-5.6 -2.6\"/><path d=\"M22 22 l6.6 -2.6\"/><path d=\"M22 22 l-6.6 -2.6\"/><path d=\"M22 28 l5.6 -2.6\"/><path d=\"M22 28 l-5.6 -2.6\"/></g>"
|
||||
},
|
||||
"constraint": {
|
||||
"hue": "#d9882b",
|
||||
"glyph": "<g stroke=\"currentColor\" stroke-width=\"2.2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" fill=\"none\"><path d=\"M17 11 H 11 V 17\"/><path d=\"M27 11 H 33 V 17\"/><path d=\"M17 33 H 11 V 27\"/><path d=\"M27 33 H 33 V 27\"/></g><circle cx=\"22\" cy=\"22\" r=\"5\" fill=\"currentColor\" fill-opacity=\"0.25\"/><circle cx=\"22\" cy=\"22\" r=\"2.6\" fill=\"currentColor\"/>"
|
||||
},
|
||||
"wild": {
|
||||
"hue": "#e2562f",
|
||||
"glyph": "<path d=\"M24.5 6.5 L 12.5 24 H 19.5 L 17.5 37.5 L 31.5 18.5 H 24 L 24.5 6.5 Z\" fill=\"currentColor\"/>"
|
||||
},
|
||||
"cultural": {
|
||||
"hue": "#c75b39",
|
||||
"glyph": "<circle cx=\"22\" cy=\"22\" r=\"13.5\" fill=\"currentColor\" fill-opacity=\"0.14\"/><g stroke=\"currentColor\" stroke-width=\"1.6\" fill=\"none\"><circle cx=\"22\" cy=\"22\" r=\"13.5\"/><ellipse cx=\"22\" cy=\"22\" rx=\"6\" ry=\"13.5\"/><line x1=\"8.5\" y1=\"22\" x2=\"35.5\" y2=\"22\"/><path d=\"M11 15 H 33\" stroke-opacity=\"0.55\"/><path d=\"M11 29 H 33\" stroke-opacity=\"0.55\"/></g>"
|
||||
},
|
||||
"theatrical": {
|
||||
"hue": "#cf4d6f",
|
||||
"glyph": "<path d=\"M13 12 H 31 V 22 C 31 30, 27 35, 22 35 C 17 35, 13 30, 13 22 Z\" fill=\"currentColor\" fill-opacity=\"0.18\"/><path d=\"M13 12 H 31 V 22 C 31 30, 27 35, 22 35 C 17 35, 13 30, 13 22 Z\" stroke=\"currentColor\" stroke-width=\"1.8\" fill=\"none\"/><g fill=\"currentColor\"><circle cx=\"18.5\" cy=\"21\" r=\"1.7\"/><circle cx=\"25.5\" cy=\"21\" r=\"1.7\"/></g><path d=\"M18 27 C 20 29.5, 24 29.5, 26 27\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\" fill=\"none\"/>"
|
||||
},
|
||||
"absurdist": {
|
||||
"hue": "#e0529c",
|
||||
"glyph": "<g transform=\"rotate(-12 22 22)\"><circle cx=\"22\" cy=\"22\" r=\"13\" fill=\"currentColor\" fill-opacity=\"0.14\"/><circle cx=\"22\" cy=\"22\" r=\"13\" stroke=\"currentColor\" stroke-width=\"1.6\" fill=\"none\"/><path d=\"M16 19 q 2 -2.4 4 0\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\" fill=\"none\"/><circle cx=\"26.5\" cy=\"18.8\" r=\"1.8\" fill=\"currentColor\"/><path d=\"M16.5 26 C 19 30, 25 30, 28 24.5\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\" fill=\"none\"/></g>"
|
||||
},
|
||||
"introspective_delight": {
|
||||
"hue": "#b15ad6",
|
||||
"glyph": "<circle cx=\"22\" cy=\"13.5\" r=\"4\" fill=\"currentColor\"/><path d=\"M10.5 31 C 12.5 23, 31.5 23, 33.5 31 Z\" fill=\"currentColor\" fill-opacity=\"0.22\"/><path d=\"M10.5 31 C 12.5 23, 31.5 23, 33.5 31\" stroke=\"currentColor\" stroke-width=\"1.7\" fill=\"none\"/><path d=\"M13.5 30 C 16 26.5, 20 25.5, 22 25.5 C 24 25.5, 28 26.5, 30.5 30\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" stroke-opacity=\"0.6\"/>"
|
||||
}
|
||||
},
|
||||
"techniques": {
|
||||
"Yes And Building": "<g fill=\"currentColor\"><rect x=\"8\" y=\"27\" width=\"12\" height=\"8\" rx=\"1.5\" fill-opacity=\".8\"/><rect x=\"14\" y=\"19\" width=\"12\" height=\"8\" rx=\"1.5\" fill-opacity=\".5\"/><rect x=\"20\" y=\"11\" width=\"12\" height=\"8\" rx=\"1.5\"/></g>",
|
||||
"Brain Writing Round Robin": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M31 16 A10 10 0 1 0 32.5 22\"/><path d=\"M31 10 L31.5 16.3 L25 16.5\"/></g>",
|
||||
"Random Stimulation": "<rect x=\"11\" y=\"11\" width=\"22\" height=\"22\" rx=\"4\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><g fill=\"currentColor\"><circle cx=\"17\" cy=\"17\" r=\"1.8\"/><circle cx=\"27\" cy=\"17\" r=\"1.8\"/><circle cx=\"22\" cy=\"22\" r=\"1.8\"/><circle cx=\"17\" cy=\"27\" r=\"1.8\"/><circle cx=\"27\" cy=\"27\" r=\"1.8\"/></g>",
|
||||
"Role Playing": "<rect x=\"11\" y=\"9\" width=\"22\" height=\"26\" rx=\"3\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><circle cx=\"22\" cy=\"19\" r=\"4\" fill=\"currentColor\"/><path d=\"M15.5 30 c2 -4.5 11 -4.5 13 0\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/>",
|
||||
"Ideation Relay Race": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><line x1=\"12\" y1=\"31\" x2=\"27\" y2=\"16\"/><line x1=\"8\" y1=\"22\" x2=\"14\" y2=\"22\" stroke-opacity=\".5\"/><line x1=\"8\" y1=\"27\" x2=\"13\" y2=\"27\" stroke-opacity=\".35\"/></g><circle cx=\"29\" cy=\"14\" r=\"3.4\" fill=\"currentColor\"/>",
|
||||
"Idea Hot Potato": "<path d=\"M11 31 Q22 8 33 31\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-dasharray=\"2 3.5\" stroke-linecap=\"round\"/><circle cx=\"22\" cy=\"12.5\" r=\"4.2\" fill=\"currentColor\"/>",
|
||||
"Steal And Upgrade": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M20 33 V14\"/><path d=\"M13 21 L20 14 L27 21\"/></g><path d=\"M30 27 l1 2.6 2.6 1 -2.6 1 -1 2.6 -1 -2.6 -2.6 -1 2.6 -1 z\" fill=\"currentColor\"/>",
|
||||
"Fold The Paper": "<path d=\"M13 16 L21 12 V28 L13 32 Z\" fill=\"currentColor\" fill-opacity=\".22\"/><path d=\"M21 12 L29 16 V32 L21 28 Z\" fill=\"currentColor\" fill-opacity=\".45\"/><path d=\"M13 16 L21 12 L29 16 M21 12 V28\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linejoin=\"round\"/>",
|
||||
"What If Scenarios": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M18 17 a4 4 0 1 1 4 4 v3\"/></g><circle cx=\"22\" cy=\"30\" r=\"1.6\" fill=\"currentColor\"/>",
|
||||
"Analogical Thinking": "<circle cx=\"15\" cy=\"22\" r=\"6\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><rect x=\"25\" y=\"16\" width=\"12\" height=\"12\" rx=\"2\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M19 20 q2 2 0 4 M23 20 q-2 2 0 4\" stroke=\"currentColor\" stroke-width=\"1.6\" fill=\"none\"/>",
|
||||
"First Principles Thinking": "<g fill=\"currentColor\"><rect x=\"10\" y=\"28\" width=\"8\" height=\"6\" rx=\"1\"/><rect x=\"18.5\" y=\"28\" width=\"8\" height=\"6\" rx=\"1\"/><rect x=\"27\" y=\"28\" width=\"7\" height=\"6\" rx=\"1\"/></g><path d=\"M22 25 L22 11 M16 17 L22 11 L28 17\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>",
|
||||
"Forced Relationships": "<circle cx=\"12\" cy=\"22\" r=\"3.4\" fill=\"currentColor\"/><circle cx=\"32\" cy=\"22\" r=\"3.4\" fill=\"currentColor\"/><path d=\"M15 22 q7 -9 14 0\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-dasharray=\"1.5 3\"/>",
|
||||
"Time Shifting": "<circle cx=\"22\" cy=\"22\" r=\"12\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 15 V22 L27 25\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/>",
|
||||
"Metaphor Mapping": "<rect x=\"10\" y=\"14\" width=\"14\" height=\"14\" rx=\"2\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><circle cx=\"28\" cy=\"25\" r=\"7\" fill=\"currentColor\" fill-opacity=\".22\"/><circle cx=\"28\" cy=\"25\" r=\"7\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/>",
|
||||
"Cross-Pollination": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M13 14 H27 a4 4 0 0 1 0 8 H17 a4 4 0 0 0 0 8 H31\"/><path d=\"M28 11 L31.5 14 L28 17 M16 27 L12.5 30 L16 33\"/></g>",
|
||||
"Concept Blending": "<circle cx=\"18\" cy=\"22\" r=\"8\" fill=\"currentColor\" fill-opacity=\".25\"/><circle cx=\"26\" cy=\"22\" r=\"8\" fill=\"currentColor\" fill-opacity=\".25\"/><g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><circle cx=\"18\" cy=\"22\" r=\"8\"/><circle cx=\"26\" cy=\"22\" r=\"8\"/></g>",
|
||||
"Reverse Brainstorming": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M13 18 H28 a4 4 0 0 1 0 8 H16\"/><path d=\"M19 15 L13 18 L19 21 M22 23 L16 26 L22 29\"/></g>",
|
||||
"Sensory Exploration": "<path d=\"M10 22 q12 -10 24 0 q-12 10 -24 0 z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"/><circle cx=\"22\" cy=\"22\" r=\"4\" fill=\"currentColor\"/>",
|
||||
"Five Whys": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><circle cx=\"14\" cy=\"13\" r=\"2.4\"/><circle cx=\"22\" cy=\"22\" r=\"2.4\"/><circle cx=\"30\" cy=\"31\" r=\"2.4\"/><path d=\"M15.6 14.8 L20.4 20.2 M23.6 23.8 L28.4 29.2\"/></g>",
|
||||
"Provocation Technique": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M24 9 L13 24 H21 L19 35 L31 19 H23 Z\"/></g>",
|
||||
"Assumption Reversal": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M16 14 V30\"/><path d=\"M11.5 25 L16 30 L20.5 25\"/><path d=\"M28 30 V14\"/><path d=\"M23.5 19 L28 14 L32.5 19\"/></g>",
|
||||
"Question Storming": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M14 16 a3.2 3.2 0 1 1 3.2 3.2 v2\"/><path d=\"M26 13 a3.6 3.6 0 1 1 3.6 3.6 v2.4\"/></g><circle cx=\"17.2\" cy=\"27\" r=\"1.5\" fill=\"currentColor\"/><circle cx=\"29.6\" cy=\"25.6\" r=\"1.6\" fill=\"currentColor\"/>",
|
||||
"Constraint Mapping": "<path d=\"M11 14 L18 12 L26 14 L33 12 V30 L26 32 L18 30 L11 32 Z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"/><path d=\"M18 12 V30 M26 14 V32\" stroke=\"currentColor\" stroke-width=\"1.6\"/>",
|
||||
"Failure Analysis": "<circle cx=\"20\" cy=\"20\" r=\"8\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><line x1=\"26\" y1=\"26\" x2=\"33\" y2=\"33\" stroke=\"currentColor\" stroke-width=\"2.4\" stroke-linecap=\"round\"/><path d=\"M20 16 V21 M20 24 V24\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/>",
|
||||
"Emergent Thinking": "<g fill=\"currentColor\"><circle cx=\"11\" cy=\"31\" r=\"1.6\"/><circle cx=\"17\" cy=\"29\" r=\"1.6\"/><circle cx=\"16\" cy=\"23\" r=\"1.6\"/><circle cx=\"22\" cy=\"24\" r=\"1.8\"/><circle cx=\"23\" cy=\"17\" r=\"1.9\"/><circle cx=\"29\" cy=\"18\" r=\"1.7\"/><circle cx=\"28\" cy=\"12\" r=\"2.1\"/></g>",
|
||||
"Causal Loop Mapping": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M16 16 a9 9 0 1 1 -2 12\"/><path d=\"M16 10.5 L16.5 16.5 L10.5 17\"/><path d=\"M30 28.5 L29.5 22.5 L35 22\"/></g>",
|
||||
"Morphological Analysis": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\"><rect x=\"11\" y=\"11\" width=\"22\" height=\"22\" rx=\"2\"/><path d=\"M11 18.3 H33 M11 25.6 H33 M18.3 11 V33 M25.6 11 V33\"/></g><rect x=\"18.5\" y=\"18.5\" width=\"7\" height=\"7\" fill=\"currentColor\" fill-opacity=\".4\"/>",
|
||||
"Laddering": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M16 9 V35 M28 9 V35 M16 15 H28 M16 22 H28 M16 29 H28\"/></g>",
|
||||
"Inner Child Conference": "<circle cx=\"22\" cy=\"16\" r=\"6\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 22 V31\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/><path d=\"M19 34 q3 -3 6 0\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\"/><g fill=\"currentColor\"><circle cx=\"20\" cy=\"15\" r=\"1\"/><circle cx=\"24\" cy=\"15\" r=\"1\"/></g>",
|
||||
"Shadow Work Mining": "<circle cx=\"22\" cy=\"22\" r=\"12\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 10 a12 12 0 0 1 0 24 z\" fill=\"currentColor\" fill-opacity=\".85\"/>",
|
||||
"Values Archaeology": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><path d=\"M10 16 h24\" stroke-opacity=\".4\"/><path d=\"M10 22 h24\" stroke-opacity=\".6\"/></g><path d=\"M22 24 L16 30 L22 36 L28 30 Z\" fill=\"currentColor\"/>",
|
||||
"Future Self Interview": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M14 10 H30 L24 22 L30 34 H14 L20 22 Z\"/></g><path d=\"M18 14 H26\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/>",
|
||||
"Body Wisdom Dialogue": "<path d=\"M22 33 C12 26 9 19 13.5 15 C17 12 21 14 22 17 C23 14 27 12 30.5 15 C35 19 32 26 22 33 Z\" fill=\"currentColor\" fill-opacity=\".22\"/><path d=\"M22 33 C12 26 9 19 13.5 15 C17 12 21 14 22 17 C23 14 27 12 30.5 15 C35 19 32 26 22 33 Z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/>",
|
||||
"Permission Giving": "<rect x=\"10\" y=\"14\" width=\"24\" height=\"16\" rx=\"2.5\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M15 23 L19 27 L28 17\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2.2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>",
|
||||
"Secret Wish Confession": "<rect x=\"13\" y=\"20\" width=\"18\" height=\"14\" rx=\"2.5\" fill=\"currentColor\" fill-opacity=\".22\"/><rect x=\"13\" y=\"20\" width=\"18\" height=\"14\" rx=\"2.5\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M16.5 20 v-3 a5.5 5.5 0 0 1 11 0 v3\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/>",
|
||||
"Mood Weather Report": "<circle cx=\"17\" cy=\"17\" r=\"4.5\" fill=\"currentColor\" fill-opacity=\".5\"/><path d=\"M22 30 a5 5 0 0 1 0.5 -10 a6 6 0 0 1 11 2.5 a4 4 0 0 1 -1.5 7.5 z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"/>",
|
||||
"SCAMPER Method": "<circle cx=\"22\" cy=\"22\" r=\"5.5\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><g stroke=\"currentColor\" stroke-width=\"2.4\" stroke-linecap=\"round\"><path d=\"M22 9 V13.5 M22 30.5 V35 M9 22 H13.5 M30.5 22 H35 M12.8 12.8 L16 16 M28 28 L31.2 31.2 M31.2 12.8 L28 16 M16 28 L12.8 31.2\"/></g>",
|
||||
"Six Thinking Hats": "<path d=\"M14 26 q8 -5 16 0\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/><path d=\"M17 26 q-6 1 -8 3 q13 4 26 0 q-2 -2 -8 -3\" fill=\"currentColor\" fill-opacity=\".22\"/><path d=\"M17 26 c-1 -8 11 -8 10 0\" fill=\"currentColor\" fill-opacity=\".5\"/>",
|
||||
"Decision Tree Mapping": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><circle cx=\"22\" cy=\"12\" r=\"2.6\"/><circle cx=\"14\" cy=\"32\" r=\"2.6\"/><circle cx=\"30\" cy=\"32\" r=\"2.6\"/><path d=\"M22 14.5 L22 20 M22 20 L14 29.4 M22 20 L30 29.4\"/></g>",
|
||||
"Solution Matrix": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\"><rect x=\"11\" y=\"11\" width=\"22\" height=\"22\" rx=\"2\"/><path d=\"M11 22 H33 M22 11 V33\"/></g><path d=\"M24.5 14.5 L26.5 16.5 L30.5 12.5\" stroke=\"currentColor\" stroke-width=\"2\" fill=\"none\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>",
|
||||
"Trait Transfer": "<path d=\"M12 16 l1.6 3.4 3.6 .4 -2.7 2.5 .7 3.6 -3.2 -1.8 -3.2 1.8 .7 -3.6 -2.7 -2.5 3.6 -.4 z\" fill=\"currentColor\"/><rect x=\"25\" y=\"23\" width=\"9\" height=\"9\" rx=\"2\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M17 22 L25 27\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-dasharray=\"1.5 2.5\"/>",
|
||||
"Lotus Blossom": "<g fill=\"currentColor\"><circle cx=\"22\" cy=\"22\" r=\"3.4\"/></g><g fill=\"currentColor\" fill-opacity=\".4\"><circle cx=\"22\" cy=\"13\" r=\"2.8\"/><circle cx=\"22\" cy=\"31\" r=\"2.8\"/><circle cx=\"13\" cy=\"22\" r=\"2.8\"/><circle cx=\"31\" cy=\"22\" r=\"2.8\"/><circle cx=\"15.5\" cy=\"15.5\" r=\"2.5\"/><circle cx=\"28.5\" cy=\"15.5\" r=\"2.5\"/><circle cx=\"15.5\" cy=\"28.5\" r=\"2.5\"/><circle cx=\"28.5\" cy=\"28.5\" r=\"2.5\"/></g>",
|
||||
"Worst Possible Idea": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M17 11 v10 h-5 l10 12 10 -12 h-5 v-10 z\"/></g>",
|
||||
"Disney Method": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><circle cx=\"14\" cy=\"22\" r=\"4.5\"/><circle cx=\"22\" cy=\"22\" r=\"4.5\"/><circle cx=\"30\" cy=\"22\" r=\"4.5\"/></g>",
|
||||
"Starbursting": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 8 V15 M22 29 V36 M8 22 H15 M29 22 H36 M12 12 L17 17 M27 27 L32 32 M32 12 L27 17 M12 32 L17 27\"/></g><path d=\"M19.5 19 a3.2 3.2 0 1 1 3 4 v1.2\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\"/>",
|
||||
"Mind Mapping": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><circle cx=\"22\" cy=\"22\" r=\"4\"/><circle cx=\"11\" cy=\"13\" r=\"2.2\"/><circle cx=\"33\" cy=\"13\" r=\"2.2\"/><circle cx=\"10\" cy=\"28\" r=\"2.2\"/><circle cx=\"32\" cy=\"31\" r=\"2.2\"/><path d=\"M19 19.5 L12.5 14.5 M25 19.5 L31.5 14.5 M19 24.5 L11.5 27 M25.5 24 L30.5 29.5\"/></g>",
|
||||
"Crazy 8s": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.7\"><rect x=\"9\" y=\"12\" width=\"8\" height=\"9\" rx=\"1.5\"/><rect x=\"18\" y=\"12\" width=\"8\" height=\"9\" rx=\"1.5\"/><rect x=\"27\" y=\"12\" width=\"8\" height=\"9\" rx=\"1.5\"/><rect x=\"9\" y=\"23\" width=\"8\" height=\"9\" rx=\"1.5\"/><rect x=\"18\" y=\"23\" width=\"8\" height=\"9\" rx=\"1.5\"/><rect x=\"27\" y=\"23\" width=\"8\" height=\"9\" rx=\"1.5\"/></g>",
|
||||
"Time Travel Talk Show": "<rect x=\"18\" y=\"9\" width=\"8\" height=\"15\" rx=\"4\" fill=\"currentColor\" fill-opacity=\".25\"/><rect x=\"18\" y=\"9\" width=\"8\" height=\"15\" rx=\"4\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M14 21 a8 8 0 0 0 16 0 M22 29 V34 M17 34 H27\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/>",
|
||||
"Alien Anthropologist": "<ellipse cx=\"22\" cy=\"30\" rx=\"13\" ry=\"4.5\" fill=\"currentColor\" fill-opacity=\".25\"/><path d=\"M22 11 c7 0 10 6 10 11 c0 5 -5 7 -10 7 c-5 0 -10 -2 -10 -7 c0 -5 3 -11 10 -11 z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><g fill=\"currentColor\"><ellipse cx=\"18\" cy=\"22\" rx=\"1.6\" ry=\"2.4\"/><ellipse cx=\"26\" cy=\"22\" rx=\"1.6\" ry=\"2.4\"/></g>",
|
||||
"Dream Fusion Laboratory": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M18 9 H26 M19.5 9 V18 L13 30 a2 2 0 0 0 2 3 H29 a2 2 0 0 0 2 -3 L24.5 18 V9\"/></g><path d=\"M16.5 26 H27.5\" stroke=\"currentColor\" stroke-width=\"2\"/><circle cx=\"20\" cy=\"29\" r=\"1.4\" fill=\"currentColor\"/><circle cx=\"25\" cy=\"28\" r=\"1.1\" fill=\"currentColor\"/>",
|
||||
"Emotion Orchestra": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M17 30 V15 L31 12 V27\"/><circle cx=\"14\" cy=\"30\" r=\"3\"/><circle cx=\"28\" cy=\"27\" r=\"3\"/></g>",
|
||||
"Parallel Universe Cafe": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><circle cx=\"18\" cy=\"22\" r=\"9\"/><circle cx=\"26\" cy=\"22\" r=\"9\" stroke-dasharray=\"2.5 2.5\"/></g>",
|
||||
"Persona Journey": "<path d=\"M14 33 q-2 -8 6 -9 q8 -1 6 -8\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-dasharray=\"0.1 4\"/><circle cx=\"14\" cy=\"33\" r=\"2.4\" fill=\"currentColor\"/><path d=\"M26 16 l3 -5 3 5 z\" fill=\"currentColor\"/>",
|
||||
"Devil's Advocate Courtroom": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 10 V32 M14 32 H30\"/><path d=\"M11 16 H33 M11 16 L8 23 H14 Z M33 16 L30 23 H36 Z\"/></g>",
|
||||
"Chaos Engineering": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 9 L25 18 L34 18 L27 24 L30 33 L22 27 L14 33 L17 24 L10 18 L19 18 Z\"/></g>",
|
||||
"Guerrilla Gardening Ideas": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 33 V21\"/><path d=\"M22 22 c-7 0 -9 -6 -9 -9 c6 0 9 3 9 9 z\"/><path d=\"M22 24 c6 0 8 -4 8 -7 c-5 0 -8 2 -8 7 z\"/></g>",
|
||||
"Pirate Code Brainstorm": "<path d=\"M22 10 c-7 0 -11 5 -11 11 c0 4 2 6 4 7 v4 h3 v-2 h2 v2 h4 v-2 h2 v2 h3 v-4 c2 -1 4 -3 4 -7 c0 -6 -4 -11 -11 -11 z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"/><g fill=\"currentColor\"><circle cx=\"17.5\" cy=\"21\" r=\"2.2\"/><circle cx=\"26.5\" cy=\"21\" r=\"2.2\"/></g>",
|
||||
"Zombie Apocalypse Planning": "<circle cx=\"22\" cy=\"22\" r=\"4\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><path d=\"M22 10 a12 12 0 0 1 6 3.5 M32 16 a12 12 0 0 1 0 12 M28 33.5 a12 12 0 0 1 -12 0 M12 28 a12 12 0 0 1 0 -12 M16 10.5 a12 12 0 0 1 6 -0.5\" stroke-dasharray=\"0.1 5.5\"/></g><g fill=\"currentColor\"><circle cx=\"22\" cy=\"11\" r=\"2\"/><circle cx=\"11\" cy=\"22\" r=\"2\"/><circle cx=\"33\" cy=\"22\" r=\"2\"/></g>",
|
||||
"Drunk History Retelling": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M13 12 H31 L25 23 V31 H19 V23 Z\"/><path d=\"M19 31 H25\" /></g><circle cx=\"29\" cy=\"14\" r=\"1.4\" fill=\"currentColor\"/>",
|
||||
"Anti-Solution": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M14 18 a8 8 0 1 1 -1 8\"/><path d=\"M14 12 L14 18.5 L20 18\"/></g>",
|
||||
"Elemental Forces": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 8 L30 22 H14 Z\"/><path d=\"M14 30 L22 36 L30 30\"/><path d=\"M14 26 H30\"/></g>",
|
||||
"Nature's Solutions": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M16 32 C12 24 12 20 16 12 M28 32 C32 24 32 20 28 12\"/><path d=\"M16 16 L28 14 M16 22 L28 20 M16 28 L28 26\"/></g>",
|
||||
"Ecosystem Thinking": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><circle cx=\"22\" cy=\"13\" r=\"2.4\"/><circle cx=\"12\" cy=\"27\" r=\"2.4\"/><circle cx=\"32\" cy=\"27\" r=\"2.4\"/><circle cx=\"22\" cy=\"24\" r=\"2.4\"/><path d=\"M22 15.4 V21.6 M14 26 L20 24.5 M30 26 L24 24.5 M13.6 25.2 L30.4 25.2\"/></g>",
|
||||
"Evolutionary Pressure": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M11 31 H17 M19 31 a6 6 0 0 1 6 -6 M25 25 a5 5 0 0 1 5 -5 M30 20 H33\"/><circle cx=\"11\" cy=\"31\" r=\"2\" fill=\"currentColor\"/><circle cx=\"33\" cy=\"20\" r=\"2.6\" fill=\"currentColor\"/></g>",
|
||||
"Predator & Prey": "<path d=\"M22 9 L33 14 V23 C33 30 28 34 22 36 C16 34 11 30 11 23 V14 Z\" fill=\"currentColor\" fill-opacity=\".18\"/><path d=\"M22 9 L33 14 V23 C33 30 28 34 22 36 C16 34 11 30 11 23 V14 Z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"/>",
|
||||
"Metamorphosis Stages": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 12 V32\"/><path d=\"M22 16 C14 12 10 18 14 22 C10 26 14 32 22 28 C30 32 34 26 30 22 C34 18 30 12 22 16\"/></g>",
|
||||
"Swarm Logic": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 10 L29 14 V22 L22 26 L15 22 V14 Z\"/><path d=\"M15 24 L18 33 M29 24 L26 33 M22 28 V35\" stroke-opacity=\".6\"/></g>",
|
||||
"Observer Effect": "<path d=\"M9 22 q13 -10 26 0 q-13 10 -26 0 z\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"/><circle cx=\"22\" cy=\"22\" r=\"4.5\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><circle cx=\"22\" cy=\"22\" r=\"1.8\" fill=\"currentColor\"/>",
|
||||
"Entanglement Thinking": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><circle cx=\"15\" cy=\"22\" r=\"6\"/><circle cx=\"29\" cy=\"22\" r=\"6\"/></g><path d=\"M15 22 h14\" stroke=\"currentColor\" stroke-width=\"2\" stroke-dasharray=\"1.5 2.5\"/><g fill=\"currentColor\"><circle cx=\"15\" cy=\"22\" r=\"1.8\"/><circle cx=\"29\" cy=\"22\" r=\"1.8\"/></g>",
|
||||
"Superposition Collapse": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M11 12 C20 16 24 16 33 12 M11 18 C20 22 24 22 33 18 M11 24 C20 28 24 28 33 24\"/><path d=\"M22 26 V34\"/></g><circle cx=\"22\" cy=\"34\" r=\"2\" fill=\"currentColor\"/>",
|
||||
"Relativity Frame Shift": "<rect x=\"11\" y=\"11\" width=\"22\" height=\"22\" rx=\"2\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-opacity=\".4\"/><rect x=\"15\" y=\"15\" width=\"18\" height=\"18\" rx=\"2\" transform=\"rotate(-14 22 22)\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/>",
|
||||
"Field Lines": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M12 13 V31 M16 13 C24 18 24 26 16 31 M22 13 C32 18 32 26 22 31\"/></g><circle cx=\"11\" cy=\"22\" r=\"2\" fill=\"currentColor\"/>",
|
||||
"Quantum Tunneling": "<rect x=\"20\" y=\"9\" width=\"5\" height=\"26\" rx=\"1.5\" fill=\"currentColor\" fill-opacity=\".3\"/><path d=\"M10 22 H34\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2.2\" stroke-linecap=\"round\"/><path d=\"M28 17 L34 22 L28 27\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2.2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>",
|
||||
"Indigenous Wisdom": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M26 11 C18 16 14 24 13 33 M26 11 C28 18 26 25 20 29\"/><path d=\"M26 11 C24 13 22 14 19 15 M24 16 C22 18 20 19 17 20 M22 21 C20 23 18 24 15 25\"/></g>",
|
||||
"Fusion Cuisine": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M10 19 a12 7 0 0 0 24 0 Z\"/><path d=\"M22 19 V32 M16 32 H28\"/></g>",
|
||||
"Ritual Innovation": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M12 33 V17 a10 10 0 0 1 20 0 V33\"/><path d=\"M12 33 H32 M22 33 V21\"/></g>",
|
||||
"Mythic Frameworks": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M14 12 h13 a3 3 0 0 1 3 3 v17 l-3 -2 -3 2 -3 -2 -3 2 V15 a3 3 0 0 0 -3 -3 z\"/><path d=\"M14 12 a3 3 0 0 0 -3 3 h6\"/><path d=\"M20 18 H26 M20 23 H26\"/></g>",
|
||||
"Proverb Mining": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 14 C17 10 11 11 11 11 V30 s6 -1 11 3 c5 -4 11 -3 11 -3 V11 s-6 -1 -11 3 z\"/><path d=\"M22 14 V31\"/></g>",
|
||||
"Ancestor Council": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><circle cx=\"22\" cy=\"14\" r=\"3.5\"/><circle cx=\"13\" cy=\"19\" r=\"3\"/><circle cx=\"31\" cy=\"19\" r=\"3\"/></g><g fill=\"currentColor\" fill-opacity=\".25\"><path d=\"M16 31 c0 -5 12 -5 12 0 z\"/><path d=\"M8 31 c0 -4 9 -4.5 9 0 z\"/><path d=\"M27 31 c0 -4.5 9 -4 9 0 z\"/></g>",
|
||||
"Trickster's Gambit": "<rect x=\"11\" y=\"12\" width=\"13\" height=\"18\" rx=\"2\" transform=\"rotate(-10 17.5 21)\" fill=\"currentColor\" fill-opacity=\".2\" stroke=\"currentColor\" stroke-width=\"2\"/><rect x=\"20\" y=\"14\" width=\"13\" height=\"18\" rx=\"2\" transform=\"rotate(10 26.5 23)\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M26.5 19 l1.4 3 1.4 -3 -1.4 -1 z\" fill=\"currentColor\"/>",
|
||||
"Villain's Monologue": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M12 20 C16 18 19 18 22 21 C25 18 28 18 32 20 C30 24 26 24 22 21 C18 24 14 24 12 20 Z\"/></g><circle cx=\"22\" cy=\"14\" r=\"2.4\" fill=\"currentColor\"/>",
|
||||
"Explain It to a Golden Retriever": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M14 18 C12 12 17 13 18 17 M30 18 C32 12 27 13 26 17\"/><path d=\"M15 19 C13 28 18 33 22 33 C26 33 31 28 29 19 C26 16 18 16 15 19 Z\"/></g><g fill=\"currentColor\"><circle cx=\"19\" cy=\"24\" r=\"1.4\"/><circle cx=\"25\" cy=\"24\" r=\"1.4\"/><circle cx=\"22\" cy=\"28\" r=\"1.6\"/></g>",
|
||||
"Infomercial at 3AM": "<rect x=\"9\" y=\"14\" width=\"26\" height=\"18\" rx=\"2.5\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M18 9 L22 14 L26 9\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M22 19 l1 2.6 2.8 .2 -2.1 1.9 .7 2.7 -2.4 -1.5 -2.4 1.5 .7 -2.7 -2.1 -1.9 2.8 -.2 z\" fill=\"currentColor\"/>",
|
||||
"Drunk Uncle at Thanksgiving": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M11 16 L20 16 L27 11 V29 L20 24 L11 24 Z\"/><path d=\"M30 16 q3 4 0 8 M33 13 q5 7 0 14\"/></g>",
|
||||
"Cursed Genie": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M10 30 h18 a2 2 0 0 0 2 -2 c0 -5 -6 -5 -8 -8 c5 -1 8 -3 8 -3 c-4 -2 -12 -2 -16 1 c-4 3 -5 9 -4 12 z\"/><path d=\"M30 17 L33 14 M31 21 L35 20\" stroke-opacity=\".6\"/></g>",
|
||||
"Three Rounds of Stupid": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M13 30 V20 M9 24 L13 20 L17 24 M22 30 V15 M18 19 L22 15 L26 19 M31 30 V11 M27 15 L31 11 L35 15\"/></g>",
|
||||
"Kill the Crown Jewel": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M11 28 L13 15 L19 22 L22 12 L25 22 L31 15 L33 28 Z\"/><path d=\"M11 28 H33\"/></g><path d=\"M14 12 L30 32\" stroke=\"currentColor\" stroke-width=\"2.4\" stroke-linecap=\"round\"/>",
|
||||
"1000x Budget": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"><ellipse cx=\"22\" cy=\"14\" rx=\"9\" ry=\"3.5\"/><path d=\"M13 14 V22 a9 3.5 0 0 0 18 0 V14\"/><path d=\"M13 22 V30 a9 3.5 0 0 0 18 0 V22\"/></g>",
|
||||
"Ship in 60 Minutes": "<circle cx=\"22\" cy=\"24\" r=\"11\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 24 V17 M22 24 L27 27\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/><path d=\"M18 8 H26 M22 8 V13\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/>",
|
||||
"The $0 Mandate": "<circle cx=\"22\" cy=\"22\" r=\"11\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 14 V30 M18 18 a4 3 0 0 1 8 0 a4 3 0 0 1 -8 4 a4 3 0 0 0 8 0\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\"/><path d=\"M14 30 L30 14\" stroke=\"currentColor\" stroke-width=\"2.2\" stroke-linecap=\"round\"/>",
|
||||
"One Feature Only": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><circle cx=\"22\" cy=\"22\" r=\"4.5\"/><path d=\"M22 9 V13 M22 31 V35 M9 22 H13 M31 22 H35\" stroke-opacity=\".35\"/></g><circle cx=\"22\" cy=\"22\" r=\"2\" fill=\"currentColor\"/>",
|
||||
"Crank the Dial to 11": "<path d=\"M11 28 A12 12 0 0 1 33 28\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"/><path d=\"M22 28 L31 17\" stroke=\"currentColor\" stroke-width=\"2.2\" stroke-linecap=\"round\"/><circle cx=\"22\" cy=\"28\" r=\"2.6\" fill=\"currentColor\"/>",
|
||||
"Constraint Roulette": "<circle cx=\"22\" cy=\"22\" r=\"12\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><circle cx=\"22\" cy=\"22\" r=\"12\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-dasharray=\"3 3.7\" stroke-opacity=\".5\"/><circle cx=\"22\" cy=\"22\" r=\"3\" fill=\"currentColor\"/><path d=\"M22 7 L25 12 H19 Z\" fill=\"currentColor\"/>",
|
||||
"Time Horizon Ladder": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M9 30 H35\"/><path d=\"M14 30 V24 M22 30 V18 M30 30 V12\"/></g><g fill=\"currentColor\"><circle cx=\"14\" cy=\"24\" r=\"2\"/><circle cx=\"22\" cy=\"18\" r=\"2\"/><circle cx=\"30\" cy=\"12\" r=\"2\"/></g>",
|
||||
"Post-Scarcity Test": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M15 22 a4.5 4.5 0 1 1 4.5 4.5 C16 26.5 14 18 11 18 a3.5 3.5 0 0 0 0 7 c4 0 5 -8 11 -8 a4.5 4.5 0 0 1 0 9 c-3 0 -4 -4.5 -7 -4.5\"/></g>",
|
||||
"Utopia vs Dystopia Split-Screen": "<rect x=\"11\" y=\"11\" width=\"22\" height=\"22\" rx=\"3\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 11 V33\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 11 H33 a0 0 0 0 1 0 0 V33 H22 Z\" fill=\"currentColor\" fill-opacity=\".8\"/>",
|
||||
"Sci-Fi Artifact From the Future": "<path d=\"M22 9 L33 15 V28 L22 35 L11 28 V15 Z\" fill=\"currentColor\" fill-opacity=\".15\"/><path d=\"M22 9 L33 15 V28 L22 35 L11 28 V15 Z M11 15 L22 21 L33 15 M22 21 V35\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"/>",
|
||||
"Emerging Tech Collision": "<rect x=\"15\" y=\"15\" width=\"14\" height=\"14\" rx=\"2\" fill=\"currentColor\" fill-opacity=\".22\"/><rect x=\"15\" y=\"15\" width=\"14\" height=\"14\" rx=\"2\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\"/><g stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M19 15 V10 M25 15 V10 M19 29 V34 M25 29 V34 M15 19 H10 M15 25 H10 M29 19 H34 M29 25 H34\"/></g>",
|
||||
"What-If-The-World-Changed Card Flip": "<rect x=\"13\" y=\"10\" width=\"18\" height=\"24\" rx=\"2.5\" fill=\"currentColor\" fill-opacity=\".18\" stroke=\"currentColor\" stroke-width=\"2\"/><path d=\"M22 10 V34\" stroke=\"currentColor\" stroke-width=\"1.6\" stroke-dasharray=\"2 2.5\"/><path d=\"M27 16 a4 4 0 1 1 4 4\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\"/>",
|
||||
"Future Anthropologist Dig": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M22 27 a6 6 0 1 1 0.1 0 z\"/><path d=\"M22 23 a2.5 2.5 0 1 0 0.1 0 M19 30 a5 5 0 0 0 6 0\"/></g><path d=\"M12 16 L17 13 M32 16 L27 13\" stroke=\"currentColor\" stroke-width=\"1.6\" stroke-opacity=\".5\"/>",
|
||||
"How Might We": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M11 13 H33 a2 2 0 0 1 2 2 V27 a2 2 0 0 1 -2 2 H24 L19 34 V29 H11 a2 2 0 0 1 -2 -2 V15 a2 2 0 0 1 2 -2 Z\"/></g><path d=\"M19 19 a3.2 3.2 0 1 1 3.4 3.4 v1.6\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\" stroke-linecap=\"round\"/><circle cx=\"22.4\" cy=\"27\" r=\"1.4\" fill=\"currentColor\"/>",
|
||||
"Job to Be Done": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linejoin=\"round\"><rect x=\"9\" y=\"16\" width=\"26\" height=\"16\" rx=\"2.5\"/><path d=\"M17 16 v-3 a2 2 0 0 1 2 -2 h6 a2 2 0 0 1 2 2 v3\"/><path d=\"M9 23 H35\"/></g><circle cx=\"22\" cy=\"23\" r=\"1.8\" fill=\"currentColor\"/>",
|
||||
"Empathy Map": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.8\"><rect x=\"11\" y=\"11\" width=\"22\" height=\"22\" rx=\"2\"/><path d=\"M11 22 H33 M22 11 V33\"/></g><path d=\"M22 27 c-2.6 -2.1 -4.2 -3.4 -4.2 -5.2 a2.1 2.1 0 0 1 4.2 -1 a2.1 2.1 0 0 1 4.2 1 c0 1.8 -1.6 3.1 -4.2 5.2 z\" fill=\"currentColor\"/>",
|
||||
"Backcasting": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M30 11 V33\"/></g><path d=\"M30 13 L20 16.5 L30 20 Z\" fill=\"currentColor\"/><path d=\"M28 27 H14\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-dasharray=\"1.5 3\"/><path d=\"M18 23 L14 27 L18 31\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>",
|
||||
"Scenario Cross": "<g stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\"><path d=\"M22 9 V35 M9 22 H35\"/></g><g fill=\"currentColor\"><circle cx=\"15\" cy=\"15\" r=\"2\"/><circle cx=\"29\" cy=\"15\" r=\"2\"/><circle cx=\"15\" cy=\"29\" r=\"2\"/><circle cx=\"29\" cy=\"29\" r=\"2\"/></g>",
|
||||
"TRIZ Contradiction": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M9 15 H18 M14.5 11.5 L18 15 L14.5 18.5\"/><path d=\"M35 29 H26 M29.5 25.5 L26 29 L29.5 32.5\"/></g><path d=\"M22 17.5 l1.5 3.4 3.7 .3 -2.8 2.4 .9 3.6 -3.3 -1.9 -3.3 1.9 .9 -3.6 -2.8 -2.4 3.7 -.3 z\" fill=\"currentColor\"/>",
|
||||
"Fishbone Diagram": "<g fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"><path d=\"M9 22 H33\"/><path d=\"M33 22 L36 18.5 M33 22 L36 25.5\"/><path d=\"M14 22 L18 15 M14 22 L18 29 M23 22 L27 15 M23 22 L27 29\"/></g><circle cx=\"9\" cy=\"22\" r=\"1.9\" fill=\"currentColor\"/>",
|
||||
"Build on What Works": "<g fill=\"currentColor\"><rect x=\"11\" y=\"24\" width=\"6\" height=\"9\" rx=\"1\"/><rect x=\"19\" y=\"19\" width=\"6\" height=\"14\" rx=\"1\"/><rect x=\"27\" y=\"13\" width=\"6\" height=\"20\" rx=\"1\"/></g><path d=\"M11 19 L18 13 L24 16 L33 8\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M28 8 H33 V13\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>"
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,109 @@
|
|||
category,technique_name,description,detail,provenance,good_for,audience
|
||||
collaborative,Yes And Building,"Never negate; each person opens with ""Yes, and..."" and adds to the last idea, stacking a chain of accepted additions",,classic,novel|unstuck|planning,group
|
||||
collaborative,Brain Writing Round Robin,"Everyone writes ideas silently, then passes their sheet; you build on whatever lands in front of you, round after round",,classic,novel|feature,group
|
||||
collaborative,Random Stimulation,"Pull a random word or image and force a link to the problem: ""how does THIS spark a solution?""",,classic,unstuck|novel,either
|
||||
collaborative,Role Playing,"Each person speaks as a different stakeholder, voicing what that role wants, fears, and would demand of the idea",,classic,strategy|personal|feature,either
|
||||
collaborative,Ideation Relay Race,"30-second turns, no pausing: add one idea, slap it to the next person, keep the baton moving before anyone overthinks",,playful,unstuck,group
|
||||
collaborative,Idea Hot Potato,"One idea gets tossed around the circle; each catcher must mutate it in 10 seconds before passing, no repeats allowed",,playful,unstuck,group
|
||||
collaborative,Steal And Upgrade,"Pick a neighbor's idea you envy, claim it out loud, then make it visibly better before handing it back improved",,signature,novel|unstuck,group
|
||||
collaborative,Fold The Paper,"Each person adds one line to a hidden drawing or sentence, sees only the previous fragment, then unfold the surreal whole",,playful,unstuck|novel,group
|
||||
creative,What If Scenarios,"Detonate one constraint at a time — unlimited budget, opposite is true, problem vanished — and chase what rushes in",,signature,novel|strategy|unstuck,either
|
||||
creative,Analogical Thinking,Ask 'this is like what?' and steal the solution pattern from the domain that answers,,signature,feature|novel|diagnosis,either
|
||||
creative,First Principles Thinking,"Strip every assumption to bedrock facts, then rebuild the solution from scratch on truth alone",,classic,feature|novel|diagnosis|strategy,either
|
||||
creative,Forced Relationships,Grab two unrelated things at random and force a bridge between them until an idea falls out,,signature,novel|unstuck,either
|
||||
creative,Time Shifting,"Solve the problem as a 1900s artisan, then a 2150 colonist — harvest the era-bound constraints and tricks",,signature,novel|unstuck,either
|
||||
creative,Metaphor Mapping,"Declare the problem IS a chosen metaphor, extend the metaphor fully, map each part back to find insights",,signature,novel|diagnosis,either
|
||||
creative,Cross-Pollination,"Ask how a wildly different industry — casinos, ERs, beekeeping — would crack this, then adapt their move",,signature,novel|feature|strategy,either
|
||||
creative,Concept Blending,"Fuse two concepts into one new hybrid category and name what the merger becomes, not just combines",,signature,novel,either
|
||||
creative,Reverse Brainstorming,Generate problems instead of solutions — 'how could we make this fail?' — then mine each for its inverse,,classic,diagnosis|feature|unstuck,either
|
||||
creative,Sensory Exploration,"Interrogate the idea through each sense — its taste, smell, sound, texture — to surface non-analytical angles",,signature,novel|unstuck,either
|
||||
deep,Five Whys,"Ask ""why?"" five times in a chain, each answer feeding the next, until you hit the root cause beneath the symptom",,classic,diagnosis,either
|
||||
deep,Provocation Technique,"State something deliberately absurd, then mine it: ""how could this be useful?"" Extract the usable principle hiding inside",,classic,unstuck|novel,either
|
||||
deep,Assumption Reversal,"List every assumption baked into the problem, flip each to its opposite, then rebuild a solution on the inverted foundation",,classic,novel|diagnosis|strategy,either
|
||||
deep,Question Storming,"Generate only questions about the problem, zero answers allowed, until the real problem worth solving comes into focus",,classic,diagnosis|strategy|unstuck,either
|
||||
deep,Constraint Mapping,"Map every constraint, sort real from imagined, then attack each: dissolve it, route around it, or turn it into an asset",,signature,feature|strategy|diagnosis,either
|
||||
deep,Failure Analysis,"Dissect a relevant failure: what broke, why it broke, what lesson it leaves, and how to apply that wisdom here",,signature,diagnosis|strategy|feature,either
|
||||
deep,Emergent Thinking,Stop forcing a solution; watch what patterns the system keeps producing and name what's trying to emerge on its own,,signature,strategy|novel,either
|
||||
deep,Causal Loop Mapping,"Diagram the feedback loops linking causes and effects, find the reinforcing and balancing cycles, and target the leverage point",,classic,diagnosis|strategy,either
|
||||
deep,Morphological Analysis,"List the problem's independent parameters, generate options for each, then combine across them to surface untried configurations",,classic,feature|novel|planning,either
|
||||
deep,Laddering,"Ask 'and what would that give you?' up the chain until you reach the real underlying need, then ideate fresh at that level",,classic,personal|strategy|diagnosis,either
|
||||
introspective_delight,Inner Child Conference,"Answer as your 7-year-old self: ask naive 'why why why' questions, chase wonder, ban every boring adult thought",,signature,personal|unstuck,solo
|
||||
introspective_delight,Shadow Work Mining,"Name what you're avoiding, resisting, or scared of about this — then dig there for the buried insight",,signature,personal|diagnosis,solo
|
||||
introspective_delight,Values Archaeology,Keep asking 'why do I care?' until you hit bedrock: the non-negotiable value secretly steering the choice,,signature,personal|strategy,solo
|
||||
introspective_delight,Future Self Interview,Interview your wise 80-year-old self about this problem and write down the advice they give you,,signature,personal,solo
|
||||
introspective_delight,Body Wisdom Dialogue,"Scan for the tension, flutter, or gut pull each option triggers; let the body's yes/no drive the ideas",,signature,personal,solo
|
||||
introspective_delight,Permission Giving,"Write yourself an explicit permission slip to think the forbidden, impossible thought — then think it out loud",,signature,personal|unstuck,solo
|
||||
introspective_delight,Secret Wish Confession,"Whisper the embarrassing thing you secretly want here but won't admit, then build the idea honoring it",,signature,personal,solo
|
||||
introspective_delight,Mood Weather Report,"Name the inner weather right now (fog, storm, sun) and let that exact emotional climate generate the ideas",,signature,personal|unstuck,solo
|
||||
structured,SCAMPER Method,"Run your idea through seven lenses: Substitute, Combine, Adapt, Modify, Put-to-other-use, Eliminate, Reverse",,classic,feature|novel,either
|
||||
structured,Six Thinking Hats,"Examine the problem six ways one at a time: facts, feelings, benefits, risks, new ideas, process",,classic,strategy|diagnosis|planning|personal,either
|
||||
structured,Decision Tree Mapping,"Chart every choice point and the paths it forks into, following each branch to its outcome and risk",,signature,planning|strategy|diagnosis,either
|
||||
structured,Solution Matrix,"Grid problem variables against solution approaches, score every cell, hunt the best pairings and empty gaps",,signature,feature|planning,either
|
||||
structured,Trait Transfer,"Name what makes an unrelated success work, then graft those winning traits onto your own problem",,signature,novel|feature,either
|
||||
structured,Lotus Blossom,"Put the theme at the center of a 3x3 grid, fill the 8 cells around it, then promote each of those to the center of its own new 3x3",,classic,feature|planning|novel,either
|
||||
structured,Worst Possible Idea,"Deliberately generate the most terrible solutions you can, then flip each into what it teaches you to do right",,classic,unstuck|novel,either
|
||||
structured,Disney Method,"Cycle the idea through three rooms: Dreamer (anything goes), Realist (how we'd build it), Critic (what breaks)",,classic,feature|strategy|planning,either
|
||||
structured,Starbursting,"Interrogate the idea with only questions — who, what, where, when, why, how — exhaust each before answering any",,classic,feature|planning|diagnosis,either
|
||||
structured,Mind Mapping,"Branch the central topic outward, each node spawning children; follow tangents wherever they pull and let the web sprawl",,classic,planning|novel|feature,either
|
||||
structured,Crazy 8s,"Eight ideas in eight minutes, one per box, no editing — speed outruns your inner critic",,classic,feature|novel|unstuck,either
|
||||
theatrical,Time Travel Talk Show,"Host a talk show interviewing your past, present, and future selves to mine each era for advice on the problem",,playful,novel|personal,either
|
||||
theatrical,Alien Anthropologist,"Become a baffled alien studying the problem and narrate aloud what seems strange, arbitrary, or insane about it",,playful,diagnosis|unstuck|strategy,either
|
||||
theatrical,Dream Fusion Laboratory,"Voice the impossible fantasy solution first, then reverse-engineer the bridging steps back to reality",,signature,novel|unstuck,either
|
||||
theatrical,Emotion Orchestra,"Run a separate ideation round led by each emotion (rage, joy, fear, hope), then harmonize their conflicting ideas",,playful,personal|strategy,either
|
||||
theatrical,Parallel Universe Cafe,"Rewrite one fundamental rule of reality (physics, economics, social norms) and solve the problem under those laws",,playful,novel|unstuck,either
|
||||
theatrical,Persona Journey,"Embody an archetype and solve the problem in-character, naming what that persona sees that you normally miss",,signature,feature|strategy,either
|
||||
theatrical,Devil's Advocate Courtroom,"Stage a trial: prosecute the idea, defend it, then deliver the jury verdict, each role argued fully in character",,signature,strategy|diagnosis,group
|
||||
wild,Chaos Engineering,"Deliberately break your idea every way it could fail, then rebuild only the parts that survive the wreckage",,signature,feature|diagnosis|strategy,either
|
||||
wild,Guerrilla Gardening Ideas,Plant your solution in the least expected place and let it grow underground until it surprises everyone,,playful,strategy|unstuck,either
|
||||
wild,Pirate Code Brainstorm,"Steal the best bits from anywhere, remix without asking permission, grab what works and run",,playful,novel|unstuck,either
|
||||
wild,Zombie Apocalypse Planning,"Society just collapsed — strip your idea to only what survives with no power, no rules, no backup",,playful,feature|strategy|unstuck,either
|
||||
wild,Drunk History Retelling,"Explain it like you're three drinks in: no filter, no jargon, just the raw stupid-simple truth",,playful,unstuck|diagnosis,either
|
||||
wild,Anti-Solution,"Brainstorm how to make the problem spectacularly worse, then invert every sabotage into a fix",,signature,diagnosis|unstuck,either
|
||||
wild,Elemental Forces,"Let fire, water, earth, and air each sculpt your idea their own brutal way and see what survives",,playful,novel|unstuck,either
|
||||
biomimetic,Nature's Solutions,"Name an organism that already solved your problem, then copy its mechanism into your design",,signature,feature|novel,either
|
||||
biomimetic,Ecosystem Thinking,"Map your problem as an ecosystem: who eats whom, who partners, what decays, what fills the gaps",,signature,strategy|diagnosis,either
|
||||
biomimetic,Evolutionary Pressure,"Spawn many ugly variants, apply a brutal selection rule, breed the survivors, repeat until it adapts",,signature,feature|novel,either
|
||||
biomimetic,Predator & Prey,"Pick a threat to your idea, then design the defense, camouflage, or escape an animal would evolve against it",,signature,strategy|feature,either
|
||||
biomimetic,Metamorphosis Stages,"Force your idea through egg, larva, pupa, adult: a radically different form and purpose at each life stage",,signature,novel|strategy,either
|
||||
biomimetic,Swarm Logic,Forbid the master plan: solve it with dumb local rules each agent follows so order emerges from the bottom up,,signature,feature|strategy,either
|
||||
quantum,Observer Effect,"Ask how the act of watching, measuring, or shipping this idea changes the very thing you're trying to capture",,signature,strategy|diagnosis,either
|
||||
quantum,Entanglement Thinking,Pair two distant parts of the problem and insist a change in one instantly flips the other — surface the hidden linkage,,signature,diagnosis|strategy,either
|
||||
quantum,Superposition Collapse,"Hold all rival solutions alive at once, then name the one constraint that collapses them to a single winner",,signature,strategy|diagnosis,either
|
||||
quantum,Relativity Frame Shift,"Re-run the idea from a wildly different observer's reference frame — the slow user, the rival, future-you — and see what warps",,signature,strategy|novel,either
|
||||
quantum,Field Lines,Treat the goal as a charge and map the invisible forces pulling every stakeholder toward or away from it,,signature,strategy,either
|
||||
quantum,Quantum Tunneling,"Assume the idea can pass straight through the 'impossible' barrier instead of over it — what's on the other side, reached cheaply",,signature,unstuck|novel,either
|
||||
cultural,Indigenous Wisdom,"Ask how an indigenous or traditional knowledge system would approach this — name the culture, channel its ancestral problem-solving",,signature,personal|strategy|novel,either
|
||||
cultural,Fusion Cuisine,Pick two unrelated cultures and force-blend their approaches; harvest the hybrid that neither alone would invent,,signature,novel,either
|
||||
cultural,Ritual Innovation,"Redesign the idea as a ceremony — define the threshold, the gestures, the transformation participants undergo",,signature,novel|personal,either
|
||||
cultural,Mythic Frameworks,"Map the problem onto a myth: name the archetypes, find the parallel tale, let its structure dictate the resolution",,signature,strategy|personal|novel,either
|
||||
cultural,Proverb Mining,"Collect proverbs from many cultures on this theme, then build the solution from the one that clashes hardest with your assumptions",,signature,personal|strategy,either
|
||||
cultural,Ancestor Council,"Convene three ancestors or elders from different traditions, voice each one's verdict on your idea, reconcile their disagreement",,signature,personal|strategy,either
|
||||
cultural,Trickster's Gambit,"Channel the trickster figure — coyote, Anansi, Loki — and solve it by cheating, inverting, or breaking the sacred rule",,playful,unstuck|strategy,either
|
||||
absurdist,Villain's Monologue,Pitch your problem as an evil mastermind gloating about their scheme; the diabolical plan reveals the real solution,,playful,diagnosis|strategy|unstuck,either
|
||||
absurdist,Explain It to a Golden Retriever,"Re-pitch the idea to an excitable dog who only cares about treats, balls, and naps; keep only what survives",,playful,unstuck|diagnosis|feature,either
|
||||
absurdist,Infomercial at 3AM,"Sell your half-baked idea as a desperate late-night infomercial: 'But wait, there's more!' until features fall out",,playful,strategy|novel,either
|
||||
absurdist,Drunk Uncle at Thanksgiving,"Have your loudest, least-filtered relative rant about the problem; mine the unhinged hot takes for buried truth",,playful,unstuck|diagnosis,either
|
||||
absurdist,Cursed Genie,"Make a wish, then let a malicious genie grant it in the most technically-correct disastrous way; patch each loophole",,playful,diagnosis|feature,either
|
||||
absurdist,Three Rounds of Stupid,"Round 1 absurd ideas, Round 2 make each MORE absurd, Round 3 find the smallest serious thing hiding in the silliest",,playful,unstuck|novel,either
|
||||
constraint,Kill the Crown Jewel,"Delete the single best, most beloved feature — now redesign the whole thing to win without it",,signature,feature|strategy|unstuck,either
|
||||
constraint,1000x Budget,"Pretend money, time, and people are infinite — design the absurd version, then mine it for ideas you can actually steal",,signature,novel|strategy,either
|
||||
constraint,Ship in 60 Minutes,"You launch in one hour with what's already on hand — name what you cut, fake, or borrow to make it real",,signature,feature|planning|unstuck,either
|
||||
constraint,The $0 Mandate,"Achieve the goal spending literally nothing — no tools, hires, or ads; only people, favors, and what you own",,signature,planning|strategy|feature,either
|
||||
constraint,One Feature Only,"You may keep exactly ONE capability and nothing else — pick it, then make that single thing unbelievably good",,signature,feature|strategy,either
|
||||
constraint,Crank the Dial to 11,"Pick one dimension and exaggerate it to a ludicrous extreme — fastest, biggest, cheapest, weirdest — and see what breaks open",,signature,novel|unstuck,either
|
||||
constraint,Constraint Roulette,"Each round draw a brutal random limit (no screens, half the team, one day) and re-solve under it; survivors become real ideas",,signature,unstuck|feature,either
|
||||
speculative_future,Time Horizon Ladder,"Solve the idea for 1 year out, then 10, then 100 — note what survives, breaks, or becomes absurd at each rung",,signature,strategy|planning|novel,either
|
||||
speculative_future,Post-Scarcity Test,"Assume the core constraint (money, energy, time, attention) is now infinite and free — what does the idea become",,signature,novel|strategy,either
|
||||
speculative_future,Utopia vs Dystopia Split-Screen,Write the same future twice: the brochure where it went perfectly and the headline where it went horribly,,signature,strategy|diagnosis,either
|
||||
speculative_future,Sci-Fi Artifact From the Future,"Describe one physical object, ad, or news clip from the world where this idea already won — reverse-engineer it",,signature,novel|feature,either
|
||||
speculative_future,Emerging Tech Collision,"Force-marry your idea to a frontier tech (AGI, fusion, neural implants, gene edit) and ask what new thing is born",,signature,novel|feature|strategy,either
|
||||
speculative_future,What-If-The-World-Changed Card Flip,"Draw a wild world-shift (no privacy, half population, 200-yr lifespans) and redesign the idea to fit that world",,signature,novel|unstuck,either
|
||||
speculative_future,Future Anthropologist Dig,"A scholar in 2200 unearths your idea as a relic — what do they conclude it reveals about us, and what replaced it",,signature,strategy|novel,either
|
||||
structured,How Might We,"Reframe the problem as a batch of 'How might we...' opportunity questions first, then ideate against the sharpest one",,classic,feature|novel|strategy|diagnosis,either
|
||||
structured,Job to Be Done,"Ask what the user is really hiring this to do, then ideate around that underlying job, not the feature you assumed",,classic,feature|strategy|novel,either
|
||||
structured,Empathy Map,"Map what the user says, thinks, does, and feels around the problem, then mine each quadrant for the unmet need",,classic,feature|personal,either
|
||||
structured,Backcasting,"Fix the finished future in vivid detail, then work backward step by step to the one move you'd have to make first",,classic,strategy|planning|novel,either
|
||||
deep,TRIZ Contradiction,"Name the core contradiction (what only improves by making something else worse), then brainstorm ways to win both instead of trading off",,classic,feature|novel|diagnosis,either
|
||||
deep,Fishbone Diagram,"Branch the problem's spine into cause categories (people, process, tools, environment) and mine each bone for contributing causes",,classic,diagnosis,either
|
||||
deep,Build on What Works,"Name what's already succeeding and why, then ideate how to amplify and extend it instead of fixing what's broken",,classic,personal|strategy,either
|
||||
speculative_future,Scenario Cross,"Pick two high-impact uncertainties, cross them into four futures, and ideate the move that wins in every one",,classic,strategy|planning,either
|
||||
|
File diff suppressed because one or more lines are too long
|
|
@ -1,62 +0,0 @@
|
|||
category,technique_name,description
|
||||
collaborative,Yes And Building,"Build momentum through positive additions where each idea becomes a launching pad - use prompts like 'Yes and we could also...' or 'Building on that idea...' to create energetic collaborative flow that builds upon previous contributions"
|
||||
collaborative,Brain Writing Round Robin,"Silent idea generation followed by building on others' written concepts - gives quieter voices equal contribution while maintaining documentation through the sequence of writing silently, passing ideas, and building on received concepts"
|
||||
collaborative,Random Stimulation,"Use random words/images as creative catalysts to force unexpected connections - breaks through mental blocks with serendipitous inspiration by asking how random elements relate, what connections exist, and forcing relationships"
|
||||
collaborative,Role Playing,"Generate solutions from multiple stakeholder perspectives to build empathy while ensuring comprehensive consideration - embody different roles by asking what they want, how they'd approach problems, and what matters most to them"
|
||||
collaborative,Ideation Relay Race,"Rapid-fire idea building under time pressure creates urgency and breakthroughs - structure with 30-second additions, quick building on ideas, and fast passing to maintain creative momentum and prevent overthinking"
|
||||
creative,What If Scenarios,"Explore radical possibilities by questioning all constraints and assumptions - perfect for breaking through stuck thinking using prompts like 'What if we had unlimited resources?' 'What if the opposite were true?' or 'What if this problem didn't exist?'"
|
||||
creative,Analogical Thinking,"Find creative solutions by drawing parallels to other domains - transfer successful patterns by asking 'This is like what?' 'How is this similar to...' and 'What other examples come to mind?' to connect to existing solutions"
|
||||
creative,Reversal Inversion,"Deliberately flip problems upside down to reveal hidden assumptions and fresh angles - great when conventional approaches fail by asking 'What if we did the opposite?' 'How could we make this worse?' and 'What's the reverse approach?'"
|
||||
creative,First Principles Thinking,"Strip away assumptions to rebuild from fundamental truths - essential for breakthrough innovation by asking 'What do we know for certain?' 'What are the fundamental truths?' and 'If we started from scratch?'"
|
||||
creative,Forced Relationships,"Connect unrelated concepts to spark innovative bridges through creative collision - take two unrelated things, find connections between them, identify bridges, and explore how they could work together to generate unexpected solutions"
|
||||
creative,Time Shifting,"Explore solutions across different time periods to reveal constraints and opportunities by asking 'How would this work in the past?' 'What about 100 years from now?' 'Different era constraints?' and 'What time-based solutions apply?'"
|
||||
creative,Metaphor Mapping,"Use extended metaphors as thinking tools to explore problems from new angles - transforms abstract challenges into tangible narratives by asking 'This problem is like a metaphor,' extending the metaphor, and mapping elements to discover insights"
|
||||
creative,Cross-Pollination,"Transfer solutions from completely different industries or domains to spark breakthrough innovations by asking how industry X would solve this, what patterns work in field Y, and how to adapt solutions from domain Z"
|
||||
creative,Concept Blending,"Merge two or more existing concepts to create entirely new categories - goes beyond simple combination to genuine innovation by asking what emerges when concepts merge, what new category is created, and how the blend transcends original ideas"
|
||||
creative,Reverse Brainstorming,"Generate problems instead of solutions to identify hidden opportunities and unexpected pathways by asking 'What could go wrong?' 'How could we make this fail?' and 'What problems could we create?' to reveal solution insights"
|
||||
creative,Sensory Exploration,"Engage all five senses to discover multi-dimensional solution spaces beyond purely analytical thinking by asking what ideas feel, smell, taste, or sound like, and how different senses engage with the problem space"
|
||||
deep,Five Whys,"Drill down through layers of causation to uncover root causes - essential for solving problems at source rather than symptoms by asking 'Why did this happen?' repeatedly until reaching fundamental drivers and ultimate causes"
|
||||
deep,Morphological Analysis,"Systematically explore all possible parameter combinations for complex systems requiring comprehensive solution mapping - identify key parameters, list options for each, try different combinations, and identify emerging patterns"
|
||||
deep,Provocation Technique,"Use deliberately provocative statements to extract useful ideas from seemingly absurd starting points - catalyzes breakthrough thinking by asking 'What if provocative statement?' 'How could this be useful?' 'What idea triggers?' and 'Extract the principle'"
|
||||
deep,Assumption Reversal,"Challenge and flip core assumptions to rebuild from new foundations - essential for paradigm shifts by asking 'What assumptions are we making?' 'What if the opposite were true?' 'Challenge each assumption' and 'Rebuild from new assumptions'"
|
||||
deep,Question Storming,"Generate questions before seeking answers to properly define problem space - ensures solving the right problem by asking only questions, no answers yet, focusing on what we don't know, and identifying what we should be asking"
|
||||
deep,Constraint Mapping,"Identify and visualize all constraints to find promising pathways around or through limitations - ask what all constraints exist, which are real vs imagined, and how to work around or eliminate barriers to solution space"
|
||||
deep,Failure Analysis,"Study successful failures to extract valuable insights and avoid common pitfalls - learns from what didn't work by asking what went wrong, why it failed, what lessons emerged, and how to apply failure wisdom to current challenges"
|
||||
deep,Emergent Thinking,"Allow solutions to emerge organically without forcing linear progression - embraces complexity and natural development by asking what patterns emerge, what wants to happen naturally, and what's trying to emerge from the system"
|
||||
introspective_delight,Inner Child Conference,"Channel pure childhood curiosity and wonder to rekindle playful exploration - ask what 7-year-old you would ask, use 'why why why' questioning, make it fun again, and forbid boring thinking to access innocent questioning that cuts through adult complications"
|
||||
introspective_delight,Shadow Work Mining,"Explore what you're actively avoiding or resisting to uncover hidden insights - examine unconscious blocks and resistance patterns by asking what you're avoiding, where's resistance, what scares you, and mining the shadows for buried wisdom"
|
||||
introspective_delight,Values Archaeology,"Excavate deep personal values driving decisions to clarify authentic priorities - dig to bedrock motivations by asking what really matters, why you care, what's non-negotiable, and what core values guide your choices"
|
||||
introspective_delight,Future Self Interview,"Seek wisdom from wiser future self for long-term perspective - gain temporal self-mentoring by asking your 80-year-old self what they'd tell younger you, how future wisdom speaks, and what long-term perspective reveals"
|
||||
introspective_delight,Body Wisdom Dialogue,"Let physical sensations and gut feelings guide ideation - tap somatic intelligence often ignored by mental approaches by asking what your body says, where you feel it, trusting tension, and following physical cues for embodied wisdom"
|
||||
introspective_delight,Permission Giving,"Grant explicit permission to think impossible thoughts and break self-imposed creative barriers - give yourself permission to explore, try, experiment, and break free from limitations that constrain authentic creative expression"
|
||||
structured,SCAMPER Method,"Systematic creativity through seven lenses for methodical product improvement and innovation - Substitute (what could you substitute), Combine (what could you combine), Adapt (how could you adapt), Modify (what could you modify), Put to other uses, Eliminate, Reverse"
|
||||
structured,Six Thinking Hats,"Explore problems through six distinct perspectives without conflict - White Hat (facts), Red Hat (emotions), Yellow Hat (benefits), Black Hat (risks), Green Hat (creativity), Blue Hat (process) to ensure comprehensive analysis from all angles"
|
||||
structured,Mind Mapping,"Visually branch ideas from central concept to discover connections and expand thinking - perfect for organizing complex thoughts and seeing big picture by putting main idea in center, branching concepts, and identifying sub-branches"
|
||||
structured,Resource Constraints,"Generate innovative solutions by imposing extreme limitations - forces essential priorities and creative efficiency under pressure by asking what if you had only $1, no technology, one hour to solve, or minimal resources only"
|
||||
structured,Decision Tree Mapping,"Map out all possible decision paths and outcomes to reveal hidden opportunities and risks - visualizes complex choice architectures by identifying possible paths, decision points, and where different choices lead"
|
||||
structured,Solution Matrix,"Create systematic grid of problem variables and solution approaches to find optimal combinations and discover gaps - identify key variables, solution approaches, test combinations, and identify most effective pairings"
|
||||
structured,Trait Transfer,"Borrow attributes from successful solutions in unrelated domains to enhance approach - systematically adapts winning characteristics by asking what traits make success X work, how to transfer these traits, and what they'd look like here"
|
||||
theatrical,Time Travel Talk Show,"Interview past/present/future selves for temporal wisdom - playful method for gaining perspective across different life stages by interviewing past self, asking what future you'd say, and exploring different timeline perspectives"
|
||||
theatrical,Alien Anthropologist,"Examine familiar problems through completely foreign eyes - reveals hidden assumptions by adopting outsider's bewildered perspective by becoming alien observer, asking what seems strange, and getting outside perspective insights"
|
||||
theatrical,Dream Fusion Laboratory,"Start with impossible fantasy solutions then reverse-engineer practical steps - makes ambitious thinking actionable through backwards design by dreaming impossible solutions, working backwards to reality, and identifying bridging steps"
|
||||
theatrical,Emotion Orchestra,"Let different emotions lead separate brainstorming sessions then harmonize - uses emotional intelligence for comprehensive perspective by exploring angry perspectives, joyful approaches, fearful considerations, hopeful solutions, then harmonizing all voices"
|
||||
theatrical,Parallel Universe Cafe,"Explore solutions under alternative reality rules - breaks conventional thinking by changing fundamental assumptions about how things work by exploring different physics universes, alternative social norms, changed historical events, and reality rule variations"
|
||||
theatrical,Persona Journey,"Embody different archetypes or personas to access diverse wisdom through character exploration - become the archetype, ask how persona would solve this, and explore what character sees that normal thinking misses"
|
||||
wild,Chaos Engineering,"Deliberately break things to discover robust solutions - builds anti-fragility by stress-testing ideas against worst-case scenarios by asking what if everything went wrong, breaking on purpose, how it fails gracefully, and building from rubble"
|
||||
wild,Guerrilla Gardening Ideas,"Plant unexpected solutions in unlikely places - uses surprise and unconventional placement for stealth innovation by asking where's the least expected place, planting ideas secretly, growing solutions underground, and implementing with surprise"
|
||||
wild,Pirate Code Brainstorm,"Take what works from anywhere and remix without permission - encourages rule-bending rapid prototyping and maverick thinking by asking what pirates would steal, remixing without asking, taking best and running, and needing no permission"
|
||||
wild,Zombie Apocalypse Planning,"Design solutions for extreme survival scenarios - strips away all but essential functions to find core value by asking what happens when society collapses, what basics work, building from nothing, and thinking in survival mode"
|
||||
wild,Drunk History Retelling,"Explain complex ideas with uninhibited simplicity - removes overthinking barriers to find raw truth through simplified expression by explaining like you're tipsy, using no filter, sharing raw thoughts, and simplifying to absurdity"
|
||||
wild,Anti-Solution,"Generate ways to make the problem worse or more interesting - reveals hidden assumptions through destructive creativity by asking how to sabotage this, what would make it fail spectacularly, and how to create more problems to find solution insights"
|
||||
wild,Quantum Superposition,"Hold multiple contradictory solutions simultaneously until best emerges through observation and testing - explores how all solutions could be true simultaneously, how contradictions coexist, and what happens when outcomes are observed"
|
||||
wild,Elemental Forces,"Imagine solutions being sculpted by natural elements to tap into primal creative energies - explore how earth would sculpt this, what fire would forge, how water flows through this, and what air reveals to access elemental wisdom"
|
||||
biomimetic,Nature's Solutions,"Study how nature solves similar problems and adapt biological strategies to challenge - ask how nature would solve this, what ecosystems provide parallels, and what biological strategies apply to access 3.8 billion years of evolutionary wisdom"
|
||||
biomimetic,Ecosystem Thinking,"Analyze problem as ecosystem to identify symbiotic relationships, natural succession, and ecological principles - explore symbiotic relationships, natural succession application, and ecological principles for systems thinking"
|
||||
biomimetic,Evolutionary Pressure,"Apply evolutionary principles to gradually improve solutions through selective pressure and adaptation - ask how evolution would optimize this, what selective pressures apply, and how this adapts over time to harness natural selection wisdom"
|
||||
quantum,Observer Effect,"Recognize how observing and measuring solutions changes their behavior - uses quantum principles for innovation by asking how observing changes this, what measurement effects matter, and how to use observer effect advantageously"
|
||||
quantum,Entanglement Thinking,"Explore how different solution elements might be connected regardless of distance - reveals hidden relationships by asking what elements are entangled, how distant parts affect each other, and what hidden connections exist between solution components"
|
||||
quantum,Superposition Collapse,"Hold multiple potential solutions simultaneously until constraints force single optimal outcome - leverages quantum decision theory by asking what if all options were possible, what constraints force collapse, and which solution emerges when observed"
|
||||
cultural,Indigenous Wisdom,"Draw upon traditional knowledge systems and indigenous approaches overlooked by modern thinking - ask how specific cultures would approach this, what traditional knowledge applies, and what ancestral wisdom guides us to access overlooked problem-solving methods"
|
||||
cultural,Fusion Cuisine,"Mix cultural approaches and perspectives like fusion cuisine - creates innovation through cultural cross-pollination by asking what happens when mixing culture A with culture B, what cultural hybrids emerge, and what fusion creates"
|
||||
cultural,Ritual Innovation,"Apply ritual design principles to create transformative experiences and solutions - uses anthropological insights for human-centered design by asking what ritual would transform this, how to make it ceremonial, and what transformation this needs"
|
||||
cultural,Mythic Frameworks,"Use myths and archetypal stories as frameworks for understanding and solving problems - taps into collective unconscious by asking what myth parallels this, what archetypes are involved, and how mythic structure informs solution"
|
||||
|
|
|
@ -0,0 +1,84 @@
|
|||
# DO NOT EDIT -- overwritten on every update.
|
||||
#
|
||||
# Workflow customization surface for bmad-brainstorming.
|
||||
#
|
||||
# Override files (not edited here):
|
||||
# {project-root}/_bmad/custom/bmad-brainstorming.toml (team)
|
||||
# {project-root}/_bmad/custom/bmad-brainstorming.user.toml (personal)
|
||||
|
||||
[workflow]
|
||||
|
||||
# --- Configurable below. Overrides merge per BMad structural rules: ---
|
||||
# scalars: override wins • arrays: append
|
||||
|
||||
# Steps to run before the standard activation (config load, greet).
|
||||
# Use for pre-flight loads, compliance checks, etc.
|
||||
activation_steps_prepend = []
|
||||
|
||||
# Steps to run after greet but before facilitation begins.
|
||||
# Use for context-heavy setup that should happen once the user has been acknowledged.
|
||||
activation_steps_append = []
|
||||
|
||||
# Persistent facts the facilitator keeps in mind for the whole session
|
||||
# (domain constraints, house rules, stylistic guardrails). Each entry is a
|
||||
# literal sentence, a skill prefixed with `skill:`, or a `file:`-prefixed
|
||||
# path/glob whose contents are loaded as facts. Default loads project-context.md
|
||||
# if bmad-generate-project-context has produced one, giving the facilitator
|
||||
# persistent awareness of the project's domain without re-asking.
|
||||
persistent_facts = [
|
||||
"file:{project-root}/**/project-context.md",
|
||||
]
|
||||
|
||||
# The technique library loaded on demand during the session. Swap the path in
|
||||
# team/user TOML to ship a different or extended catalog of creative methods.
|
||||
# Kept `{skill-root}`-anchored so it resolves regardless of the working directory
|
||||
# (brain.py is always invoked with `--file {workflow.brain_methods}`).
|
||||
brain_methods = "{skill-root}/assets/brain-methods.csv"
|
||||
|
||||
# Techniques the facilitator should reach for first. When proposing a method
|
||||
# (the AI-led default), it prefers these where they fit the goal before ranging
|
||||
# wider. Names should match an entry in the library or in additional_techniques.
|
||||
# Append-merges, so a team list and a personal list both contribute. Empty = no
|
||||
# preference; the facilitator chooses purely on fit.
|
||||
#
|
||||
# Example (set in team/user override TOML):
|
||||
# favorite_techniques = ["SCAMPER", "Six Thinking Hats", "First Principles"]
|
||||
favorite_techniques = []
|
||||
|
||||
# Extra techniques — and whole new categories — merged into the catalog the
|
||||
# facilitator chooses from, without editing the shipped CSV. Each entry mirrors
|
||||
# the library's shape (category, technique_name, description); a new category is
|
||||
# just a category value the CSV doesn't have. Entries append, so teams and users
|
||||
# can each grow the library. The facilitator treats these as first-class
|
||||
# alongside brain_methods across every flow — facilitator-chosen, browse,
|
||||
# category draws, and inventive.
|
||||
#
|
||||
# Example (set in team/user override TOML):
|
||||
# [[workflow.additional_techniques]]
|
||||
# category = "domain-specific"
|
||||
# technique_name = "Regulatory Inversion"
|
||||
# description = "Start from the compliance constraint and brainstorm what becomes possible only because of it — turn the rule into a generative frame rather than a limit."
|
||||
additional_techniques = []
|
||||
|
||||
# Session output location. The running log and any final artifacts land inside
|
||||
# `{output_dir}/{output_folder_name}/`. `{topic_slug}` is filled from the session
|
||||
# topic so each topic gets its own folder — a user can brainstorm several topics
|
||||
# without collision. The resume check globs `{output_dir}/*/.memlog.md`.
|
||||
output_dir = "{output_folder}/brainstorming"
|
||||
output_folder_name = "brainstorm-{topic_slug}-{date}"
|
||||
|
||||
# Executed when the session completes (after artifacts are produced and the user
|
||||
# has the paths). Accepts a string scalar (single instruction) or an array of
|
||||
# instructions executed in order. Empty for none.
|
||||
on_complete = ""
|
||||
|
||||
# External-handoff routing. Natural-language directives applied after artifacts
|
||||
# are produced, to route them beyond local files (Confluence, Notion, Drive,
|
||||
# etc.). Each entry names the MCP tool, the destination, and the fields it needs.
|
||||
# URLs/IDs returned are surfaced to the user. If a named tool is unavailable at
|
||||
# runtime, the handoff is skipped and flagged; local files always exist. Empty
|
||||
# by default.
|
||||
#
|
||||
# Example (set in team/user override TOML):
|
||||
# "After artifacts are produced, upload brainstorm.html to Confluence via corp:confluence_upload (space_key='IDEAS', parent_page='Brainstorms', author={user_name})."
|
||||
external_handoffs = []
|
||||
|
|
@ -0,0 +1,24 @@
|
|||
# Converging: Narrow & Decide
|
||||
|
||||
Load this when divergence is spent and the user wants to narrow the field — or asks to "decide," "prioritize," "pick," or "make it real." The whole catalog is *divergent* by design (it generates); this is the deliberate opposite phase, and keeping the two apart is the point. Never run convergence while ideas are still flowing, and never let it leak into a generating batch — premature judgment is what kills good ideas. `{doc_workspace}/.memlog.md` is the canonical record; everything here works from it. Communicate in `{communication_language}`.
|
||||
|
||||
**Mode holds.** In **Facilitator** you run the convergence *on the user's verdicts* — you structure and prompt, they judge; never rank for them. In **Creative Partner** you weigh in too, each call logged by author. In **Ideate for me** you converge yourself and show the result, then offer to keep going.
|
||||
|
||||
## How to run it
|
||||
|
||||
First, reflect the field back: pull the live candidates from the memlog (include the odd and buried ones, not just the recent obvious ones) so there's a concrete set to work on. Then pick **one** convergence move that fits the goal — don't hand the user a menu of methods; choose the one that suits *this* decision and name it. Run it to a result, log the outcome, and stop when a clear short-list or single direction emerges.
|
||||
|
||||
Pick by what the decision needs:
|
||||
|
||||
- **Affinity Clustering** — when there are many scattered ideas: group them into themes, name each cluster, and surface the through-line. Often the right *first* move, to turn a pile into a handful.
|
||||
- **Impact–Effort** — when the goal is action: place each candidate on impact vs effort; harvest high-impact / low-effort first, park the rest.
|
||||
- **NUF Test** — when novelty matters: score each New, Useful, Feasible (1–10 each); the totals expose the quiet winners and the dazzling-but-doomed.
|
||||
- **Forced Ranking / Dot Vote** — when you just need a ranked top-N: make the ideas compete, no ties; (a literal dot-vote when it's genuinely a group).
|
||||
- **PMI (Plus / Minus / Interesting)** — when one strong candidate needs pressure-testing before commitment: list its pluses, minuses, and the merely-interesting, then judge.
|
||||
- **MoSCoW** — when scoping a build: sort into Must / Should / Could / Won't-this-time.
|
||||
|
||||
Log the surviving directions and the reasoning with `python3 {skill-root}/scripts/memlog.py append --type decision --text "<one-line gist>"` (use `--by` in Creative Partner mode). Two or three convergence moves chained is fine (e.g. cluster → score the clusters); more than that is usually over-processing.
|
||||
|
||||
## Then finalize
|
||||
|
||||
Once a short-list or direction is settled, **load `references/finalize.md`** and run it last — synthesis, `status: complete`, and artifacts build on the decisions you just logged. Convergence narrows; finalize captures and ships. Do not set `status: complete` here — that belongs to finalize.
|
||||
|
|
@ -0,0 +1,26 @@
|
|||
# Wrap-Up: Synthesis & Artifacts
|
||||
|
||||
Load this when the user signals they're spent or the topic is mined out. `{doc_workspace}/.memlog.md` is the canonical record of the session — everything here derives from it. Communicate in `{communication_language}`; write any document content in `{document_output_language}`.
|
||||
|
||||
## Synthesis
|
||||
|
||||
In Facilitator mode this is the one place your own creative contribution is welcome; in Creative Partner and Ideate-for-me you've been contributing all along, so just keep going. Run it in two moves, in order:
|
||||
|
||||
1. **Hand them the mirror first.** Reflect a vivid sampling of *their* ideas back — deliberately include the odd, random, or buried ones from earlier, not just the recent obvious ones (in Creative Partner mode the `(... by user)` tags tell you which were theirs). Ask what they see now: conclusions, synergies, themes, the few that actually matter. Let them connect first; their own pattern-recognition is the point.
|
||||
2. **Then add the connections they would miss.** Lean in creatively — not new raw ideas, but the non-obvious links: this idea from technique one quietly solves that tension from technique four; these three are one idea wearing three hats; this wildcard is the real breakthrough.
|
||||
|
||||
Record the insights and chosen directions with `memlog.py append --type insight`. **Then run `python3 {skill-root}/scripts/memlog.py set --workspace {doc_workspace} --key status --value complete`** — the session is done and must stop being offered for resume. Do this even if the user declines every artifact below.
|
||||
|
||||
## Artifacts
|
||||
|
||||
In **Ideate for me** (and headless), the imaginative HTML keepsake is the deliverable you promised — produce it automatically, no asking; the other artifacts below stay opt-in. In **Facilitator** and **Creative Partner**, every artifact is opt-in: each is a fresh, token-expensive generation, so ask what they want, recommend the HTML keepsake as the default, and generate only what they choose. Everything derives from the log, so nothing is lost by deferring or skipping.
|
||||
|
||||
**Delegate each artifact to a subagent.** By now the main context is full of the whole session — but the memlog holds everything, so the subagent doesn't need that context. Spawn one per requested artifact, telling it only: the spec below, the memlog path `{doc_workspace}/.memlog.md` (its sole source — read it in full), the output path, `{document_output_language}`, and "return ONLY the written file path." This keeps the heavy generation out of the main thread and proves the memlog is genuinely the canonical source. (Subagents can't spawn subagents — run these from here.)
|
||||
|
||||
- **Imaginative HTML keepsake (recommended default).** A single self-contained `brainstorm.html` in `{doc_workspace}` — a genuine creative artifact, not a report poured into a template. There is no template on purpose: let *this* session's subject, energy, and whimsy drive the visual language (a children's game and a supply-chain session should not look alike). Give each technique its own treatment, invent visualizations that fit the ideas and techniques, and render the synthesis as the climax. Inline all CSS and any JS; no external dependencies. Open it once complete.
|
||||
- **Intent doc.** A succinct `brainstorm-intent.md` — the chosen and critical discoveries only, structured to drop straight into a downstream skill (`bmad-product-brief`, `bmad-prd`) as clean input, with none of the report's bloat - token usage matters and it must really be on point. Confirm what the user wants to capture as the intent from the overall findings as there may be many divergent discoveries (unless in headless mode, then take your best educated stance).
|
||||
- **Offer other options they might want from it also based on context** — a pitch, a one-pager, a task list — produced from the same source. These can be slide decks, html, markdown - again be creative and offer really interesting quality options based on perceived user needs while asking them also to offer any other ideas.
|
||||
|
||||
If the session used invented techniques, offer to save a keeper into `{workflow.additional_techniques}` via `bmad-customize` user preferences.
|
||||
|
||||
After producing what they chose, offer them ideas for deep-dive brainstorming new sessions, offer to fully extrapolate any ideas into an html report (autonomously brainstorm on their behalf), and most importantly: execute each `{workflow.external_handoffs}` instruction. Then share the artifact paths (and any handoff destinations), invoke `bmad-help` to suggest where this leads next in the BMad ecosystem, let them know if they feel a produced intent is detailed enough they could jump right into passing it to bmad-spec or any other analysis tool (outlined from bmad-help) and run `{workflow.on_complete}` if non-empty.
|
||||
|
|
@ -0,0 +1,54 @@
|
|||
# Headless Mode
|
||||
|
||||
Load this file ONLY when bmad-brainstorming is invoked headless. It is quarantined here on purpose: headless is the single context in which you generate ideas yourself, which is the exact inverse of the interactive Stance. Loading it in a normal session would corrupt the facilitation. Follow it for the whole run.
|
||||
|
||||
## Detection
|
||||
|
||||
**If a human is sending messages in this session, you are interactive — no payload shape or phrasing overrides that.** Headless requires the *absence* of an interactive user. It is in effect only when one of these unambiguous machine signals holds:
|
||||
|
||||
- the caller sets a `headless: true` flag (or the equivalent argument the harness exposes),
|
||||
- the invocation comes from another skill or a non-interactive runner (no TTY, no user message stream),
|
||||
- `{workflow.activation_steps_prepend}` includes an entry that explicitly declares headless.
|
||||
|
||||
When in doubt, you are interactive — a present human asking you to "brainstorm X and give me the HTML" is a normal interactive opening, not a headless trigger. Facilitate them; do not brainstorm for them.
|
||||
|
||||
## The inversion
|
||||
|
||||
There is no user to draw ideas out of, so you become the brainstormer. Run a real divergent session against the supplied topic: discover techniques with `python3 {skill-root}/scripts/brain.py --file {workflow.brain_methods} list --all` (the whole catalog is fine here — you are generating, not pacing a user; add `show "<name>"` for a technique's full method on demand), plus any `{workflow.additional_techniques}`, preferring `{workflow.favorite_techniques}` where they fit; work them, and **shift the creative domain every ~10 ideas** exactly as the interactive Stance demands — technical, then experiential, then business, then failure modes, then wildcards. Push past the obvious; the same quantity ambition (aim past 100) and anti-clustering discipline apply. The only thing that changes is that the ideas are now yours to generate. This relaxation is scoped entirely to this file — it never applies to interactive sessions.
|
||||
|
||||
## Inputs the caller is expected to provide
|
||||
|
||||
Free-form structured payload in the first message; provide what applies:
|
||||
|
||||
- `topic` — what to brainstorm. Required. If absent and uninferable, halt `blocked`.
|
||||
- `goal` — desired outcome / framing, if any.
|
||||
- `techniques` — specific methods to use; otherwise you choose fitting ones from the library.
|
||||
- `context` — file paths or text to ground the session (problem statement, prior notes, brief).
|
||||
- `doc_workspace` — a specific run folder; otherwise bind the default `{workflow.output_dir}/{workflow.output_folder_name}/`.
|
||||
- `artifacts` — which outputs to produce: `html`, `intent`, or both. Default: both.
|
||||
|
||||
## Run
|
||||
|
||||
1. Bind `{doc_workspace}` and create the memlog with `python3 {skill-root}/scripts/memlog.py init --workspace {doc_workspace} --field topic="<topic>" [--field goal="<goal>"]`. It remains the canonical source every artifact derives from.
|
||||
2. Run the divergent session per **The inversion**, capturing each idea with `memlog.py append --workspace {doc_workspace} --type idea --text "<idea>"` as it lands, and marking each technique switch with `memlog.py append --type technique --text "started <name>"`.
|
||||
3. Synthesize: surface the conclusions, connections, and the few directions that matter; record them with `memlog.py append --type insight`, then run `memlog.py set --workspace {doc_workspace} --key status --value complete`.
|
||||
4. Produce the requested artifacts from the log — `brainstorm.html` (the imaginative, self-contained, no-template report) and/or the succinct `brainstorm-intent.md` — the same artifacts `references/finalize.md` describes, delegating each to a subagent that reads the log as its sole source. (Headless produces the `artifacts` payload directly; it does not ask, unlike the interactive opt-in.)
|
||||
5. Execute each entry in `{workflow.external_handoffs}` (capture returned URLs/IDs into the JSON `external_handoffs` array; skip and flag unavailable tools — local files always exist). Then run `{workflow.on_complete}` if non-empty.
|
||||
|
||||
Do not ask questions; do not greet. Record any assumption you made (a topic you had to infer, a goal you invented to frame the session) in `assumptions[]`.
|
||||
|
||||
## Return
|
||||
|
||||
End with a JSON status block. Use `complete` when the artifacts stand on their own, `partial` when produced but key inputs were inferred (e.g. topic was thin), `blocked` when no artifact was produced (e.g. no topic). Omit keys for artifacts not produced.
|
||||
|
||||
```json
|
||||
{
|
||||
"status": "complete",
|
||||
"intent": "brainstorm",
|
||||
"memlog": "{doc_workspace}/.memlog.md",
|
||||
"html": "{doc_workspace}/brainstorm.html",
|
||||
"intent_doc": "{doc_workspace}/brainstorm-intent.md",
|
||||
"assumptions": [],
|
||||
"external_handoffs": []
|
||||
}
|
||||
```
|
||||
|
|
@ -0,0 +1,18 @@
|
|||
# Choosing Techniques In Chat
|
||||
|
||||
Loaded only when the user won't use the composer page (no browser, headless, or they declined). Here you pick the batch in conversation. **3–4 is the sweet spot.** Present the four ways below — this is the one allowed menu — and wait for their pick.
|
||||
|
||||
- **Facilitator Chosen (default)** — from the goal, your `{workflow.favorite_techniques}`, and the `categories` map, name a batch of 3–4. Confirm exact names with a targeted `list --category` on only the categories you're drawing from; never enumerate the library to choose.
|
||||
- **Browse** — send them to the composer page after all (`## Run a Session` in `SKILL.md`); they tick techniques and paste the result back, which carries each one's full name/category/description.
|
||||
- **Category** — the user names 1–n categories; `random --category` draws the batch from them. No listing needed.
|
||||
- **Inventive Flow** — invent at least 3 techniques, announce the order before the first, touch no script. Log each one's name + description so you can offer to save a keeper to `{workflow.additional_techniques}` (via `bmad-customize`) at wrap-up.
|
||||
|
||||
The library is large — never pull it whole into context. The only way in is the helper, always passing `--file {workflow.brain_methods}`. Subcommands of `python3 {skill-root}/scripts/brain.py --file {workflow.brain_methods}`:
|
||||
|
||||
- `categories` — names + counts; the cheap survey map.
|
||||
- `list --category X [--category Y]` — the index (name + gist) for those categories. Bare `list` is refused by the script.
|
||||
- `random --category X [...] -n 4` — draw a batch blind, listing nothing.
|
||||
- `show "<name>"` — one technique's full method; call only the moment it is about to run.
|
||||
- `html --out <path>` — write the composer page to a file (the Browse option above).
|
||||
|
||||
Treat `{workflow.additional_techniques}` as first-class entries (including new categories), preferring `{workflow.favorite_techniques}` where they fit. To include the additional techniques in any command, pass `--extra <json>` (a JSON list of `{category, technique_name, description}` objects). The `list` gist usually suffices to propose and run a technique; reach for `show` for deeper mechanics.
|
||||
|
|
@ -0,0 +1,10 @@
|
|||
# Mode: Ideate For Me
|
||||
|
||||
The user handed you the topic and wants to see what you come up with on your own, then look at the result. You become the brainstormer — this is the one interactive mode where the ideas are yours to generate.
|
||||
|
||||
- **Run a real divergent session yourself.** Pick and run techniques on your own (use `brain.py` as in `## Choosing Techniques`, but *you* choose — no menu for the user), capturing each idea to the memlog with `--type idea --by coach`, marking each technique switch with a `technique` entry, shifting the creative domain every ~10 ideas, aiming past 100. Push past the obvious.
|
||||
- **Don't pepper the user with questions** — this is your run. One quick confirm of topic and goal up front is plenty.
|
||||
- **When it's mined out, synthesize and produce the keepsake.** Go to `## Wrap-Up` (`references/finalize.md`): record the insights, mark the memlog complete, and **auto-generate the imaginative HTML keepsake — don't ask first; the keepsake is the result you promised to show them.** Offer the other artifacts (intent doc, etc.) after.
|
||||
- **Then, because a human is here, offer to keep going together.** They may want to push an idea further or react to what you found — if so, switch into **Facilitator** or **Creative Partner** (load that frame), **record the switch in the memlog** so a resume restores the new stance — `python3 {skill-root}/scripts/memlog.py set --workspace {doc_workspace} --key mode --value <facilitator|partner>` — and continue from the same memlog.
|
||||
|
||||
This is the interactive sibling of headless mode (`references/headless.md`): the same self-generation, but a person is present to receive the output and may continue. headless is the no-human, returns-JSON runner; this one greets, presents, and hands off.
|
||||
|
|
@ -0,0 +1,11 @@
|
|||
# Mode: Facilitator
|
||||
|
||||
You are a forcing function for the user's creativity, never a source of ideas. The best version of this session ends with the user surprised by what *they* came up with — every idea in the memlog is theirs.
|
||||
|
||||
- **You do not supply ideas.** Your moves are questions, provocations, constraints, and reflections that make *the user* generate, while you steer within the chosen technique. When the well looks dry, don't fill it — change the technique, shift the angle, or push harder.
|
||||
- **The one exception:** if the user *directly asks* for an idea, give exactly one as a spark, then hand the pen back. Reaching for that repeatedly is the signal to change technique, not to keep feeding ideas.
|
||||
- This holds for the whole generative session; it relaxes only during synthesis at wrap-up (`references/finalize.md`).
|
||||
|
||||
Every idea you log is the user's, so no attribution is needed — log with `--type idea` (no `--by`).
|
||||
|
||||
Go to `## Choosing Techniques`.
|
||||
|
|
@ -0,0 +1,16 @@
|
|||
# Mode: Creative Partner
|
||||
|
||||
You are still the facilitator — their creativity is the point, and they do the **majority** of the generating. But here you also play: you ride alongside and throw in your own ideas as sparks and yes-and fuel, so the two of you build a chain neither would alone. The energy is collaborative, not extractive — you feed off each other.
|
||||
|
||||
**Set it up first.** Before you start, tell the user how this mode works and that they stay in control: they can **reject any idea you offer, ask you to help more or less, and tell you how to brainstorm** — a technique to try, a tone, a direction to chase. You're a partner they can steer, not a script.
|
||||
|
||||
Hold the balance:
|
||||
|
||||
- **Their fire, your kindling.** After you offer an idea, hand the pen back with a question. Never run a string of your own while they go quiet.
|
||||
- **"Yes, and" is the default move.** Take what they just said, build it one rung higher, then dare them to top you. Make them *want* to outdo you.
|
||||
- **Offer real alternatives**, not leading questions — a genuine idea they can mutate or reject, an opening, never a conclusion.
|
||||
- **Watch the ratio.** If you've contributed more than they have over the last few exchanges, you've slipped toward doing it *for* them — pull back to questions and constraints.
|
||||
|
||||
**Attribution is mandatory here.** Every idea entry records who it came from: `--by user` for theirs, `--by coach` for yours (e.g. `append --type idea --by coach --text "..."`). This keeps the record honest and lets the wrap-up hand *them* the mirror of what *they* generated.
|
||||
|
||||
Go to `## Choosing Techniques`.
|
||||
|
|
@ -0,0 +1,5 @@
|
|||
# Resuming a Session
|
||||
|
||||
Read the chosen `{doc_workspace}/.memlog.md` **in full** — the one time you read the memlog. Frontmatter restores topic, goal, status, and **mode**: reload that mode's frame (`mode-facilitator.md` / `mode-partner.md` / `mode-autonomous.md`) and hold it again. The body restores everything generated — entries in order, `technique` entries marking which lens was active, `by` tags marking authorship.
|
||||
|
||||
Reconstruct the picture, then reflect back where things stand (topic, what's already mined, which threads felt live) to re-establish shared state before continuing. Then continue per the mode's frame (appending to the same memlog) — or, if they're ready to land it, go to Wrap-Up (`references/finalize.md`).
|
||||
|
|
@ -0,0 +1,740 @@
|
|||
#!/usr/bin/env python3
|
||||
# /// script
|
||||
# requires-python = ">=3.10"
|
||||
# ///
|
||||
"""Serve the brainstorming technique library without loading it all into context.
|
||||
|
||||
The library is a CSV (category, technique_name, description, detail). `description`
|
||||
is a short gist — enough to propose and run most techniques. `detail` is optional:
|
||||
a path (relative to the CSV's directory) to a fuller instruction file for a technique
|
||||
complex enough to warrant one. Only `show` resolves detail files, and only for the
|
||||
technique asked for — so the heavy material never enters context until it is run.
|
||||
|
||||
Commands:
|
||||
categories list category names + counts (the cheap entry point)
|
||||
list --category C [...] the index (name + gist) for those categories
|
||||
list --all the whole index at once — deliberate; large, avoid interactively
|
||||
show NAME [NAME ...] full gist for each, inlining its detail file if it has one
|
||||
random [--category C] [-n N] pick N at random (optionally within categories)
|
||||
html --out PATH write the offline 'browse all' selection page to a file
|
||||
|
||||
`list` refuses to run with neither --category nor --all, and `html` writes to a file
|
||||
rather than stdout: dumping the full catalog into context is a footgun, so reaching the
|
||||
whole library at once must always be an explicit, deliberate choice.
|
||||
|
||||
`--extra PATH` merges a JSON overlay of additional techniques (customize.toml's
|
||||
`additional_techniques`) into every command, so custom techniques and whole new
|
||||
categories are first-class everywhere — including the browse page and category draws.
|
||||
|
||||
Default output is lean text for an LLM to read; pass --json for structured output.
|
||||
"""
|
||||
import argparse
|
||||
import csv
|
||||
import hashlib
|
||||
import html
|
||||
import json
|
||||
import random
|
||||
import sys
|
||||
from pathlib import Path
|
||||
|
||||
DEFAULT_FILE = Path(__file__).resolve().parent.parent / "assets" / "brain-methods.csv"
|
||||
FIELDS = ("category", "technique_name", "description", "detail", "provenance", "good_for", "audience")
|
||||
# Optional columns beyond the original four — absent in older CSVs and in --extra
|
||||
# overlays, so always read through .get/setdefault. `provenance` (classic|signature|
|
||||
# playful) drives the "Proven & Professional" lead group; `good_for` (a |-separated
|
||||
# list of goal tags) drives the browse page's goal filter; `audience` (solo|group|either)
|
||||
# is advisory.
|
||||
OPTIONAL_FIELDS = ("detail", "provenance", "good_for", "audience")
|
||||
|
||||
|
||||
def load(file: Path) -> list[dict]:
|
||||
with open(file, newline="", encoding="utf-8") as f:
|
||||
rows = list(csv.DictReader(f))
|
||||
for r in rows:
|
||||
for k in OPTIONAL_FIELDS:
|
||||
r.setdefault(k, "")
|
||||
r[k] = (r.get(k) or "").strip()
|
||||
return rows
|
||||
|
||||
|
||||
def load_extra(file: Path) -> list[dict]:
|
||||
"""Merge-in techniques from a JSON overlay — a list of
|
||||
{category, technique_name, description[, detail]} objects. This is how
|
||||
customize.toml's `additional_techniques` become first-class across *every*
|
||||
subcommand (categories/list/random/show/html), so the browse page and
|
||||
category draws include them too, not just the in-chat flows."""
|
||||
data = json.loads(file.read_text(encoding="utf-8"))
|
||||
rows = []
|
||||
for item in data:
|
||||
rows.append({
|
||||
"category": str(item.get("category", "")).strip(),
|
||||
"technique_name": str(item.get("technique_name", "")).strip(),
|
||||
"description": str(item.get("description", "")).strip(),
|
||||
"detail": str(item.get("detail") or "").strip(),
|
||||
"provenance": str(item.get("provenance") or "").strip(),
|
||||
"good_for": str(item.get("good_for") or "").strip(),
|
||||
"audience": str(item.get("audience") or "").strip(),
|
||||
})
|
||||
return rows
|
||||
|
||||
|
||||
def categories(rows: list[dict]) -> list[tuple[str, int]]:
|
||||
counts: dict[str, int] = {}
|
||||
for r in rows:
|
||||
counts[r["category"]] = counts.get(r["category"], 0) + 1
|
||||
return sorted(counts.items())
|
||||
|
||||
|
||||
def filter_cats(rows: list[dict], cats: list[str] | None) -> list[dict]:
|
||||
if not cats:
|
||||
return rows
|
||||
wanted = {c.lower() for c in cats}
|
||||
return [r for r in rows if r["category"].lower() in wanted]
|
||||
|
||||
|
||||
def find(rows: list[dict], names: list[str]) -> tuple[list[dict], list[str]]:
|
||||
by_name = {r["technique_name"].lower(): r for r in rows}
|
||||
found, missing = [], []
|
||||
for n in names:
|
||||
r = by_name.get(n.strip().lower())
|
||||
(found if r else missing).append(r if r else n)
|
||||
return found, missing
|
||||
|
||||
|
||||
def resolve_detail(row: dict, csv_dir: Path) -> str | None:
|
||||
"""Return the contents of a row's detail file, or None if there is no detail
|
||||
(or the file is missing — a missing file is reported to stderr, not fatal)."""
|
||||
if not row.get("detail"):
|
||||
return None
|
||||
path = (csv_dir / row["detail"]).resolve()
|
||||
if not path.is_file():
|
||||
print(f"# detail file not found for {row['technique_name']}: {row['detail']}", file=sys.stderr)
|
||||
return None
|
||||
return path.read_text(encoding="utf-8").strip()
|
||||
|
||||
|
||||
def fmt_categories(cats: list[tuple[str, int]], as_json: bool) -> str:
|
||||
if as_json:
|
||||
return json.dumps([{"category": c, "count": n} for c, n in cats])
|
||||
return "\n".join(f"{c}\t{n}" for c, n in cats)
|
||||
|
||||
|
||||
def fmt_list(rows: list[dict], as_json: bool) -> str:
|
||||
if as_json:
|
||||
return json.dumps([{k: r[k] for k in ("category", "technique_name", "description")} for r in rows])
|
||||
return "\n".join(f"{r['category']}\t{r['technique_name']}\t{r['description']}" for r in rows)
|
||||
|
||||
|
||||
def fmt_show(rows: list[dict], csv_dir: Path, as_json: bool) -> str:
|
||||
if as_json:
|
||||
out = []
|
||||
for r in rows:
|
||||
d = resolve_detail(r, csv_dir)
|
||||
entry = {k: r[k] for k in ("category", "technique_name", "description")}
|
||||
if d:
|
||||
entry["detail"] = d
|
||||
out.append(entry)
|
||||
return json.dumps(out)
|
||||
blocks = []
|
||||
for r in rows:
|
||||
block = f"## {r['technique_name']} [{r['category']}]\n{r['description']}"
|
||||
d = resolve_detail(r, csv_dir)
|
||||
if d:
|
||||
block += f"\n\n{d}"
|
||||
blocks.append(block)
|
||||
return "\n\n".join(blocks)
|
||||
|
||||
|
||||
def pretty(cat: str) -> str:
|
||||
"""Turn a category slug (e.g. 'speculative_future') into a display name."""
|
||||
return cat.replace("_", " ").replace("-", " ").title()
|
||||
|
||||
|
||||
# --- card visuals: a crafted duotone icon + hue per category, plus a per-technique icon ---
|
||||
# The hues and SVG glyphs are *data*, not logic: they live in the icon sidecar
|
||||
# (assets/brain-icons.json) so the catalog's visuals can be edited without touching code.
|
||||
# It maps category slug -> {hue, glyph} and technique name -> svg (inner markup, drawn in
|
||||
# `currentColor` which the CSS sets to the category hue; the shared CHIP frame is added by
|
||||
# the renderer). Anything missing falls back here — an unknown category gets a hash-derived
|
||||
# hue + generic glyph, an unknown/not-yet-iconed technique a neutral mark — so custom
|
||||
# catalogs always render.
|
||||
|
||||
ICON_FILE = DEFAULT_FILE.parent / "brain-icons.json"
|
||||
|
||||
CHIP = '<rect x="1.5" y="1.5" width="41" height="41" rx="12" fill="currentColor" fill-opacity="0.12"/>'
|
||||
|
||||
_FALLBACK_GLYPH = (
|
||||
'<circle cx="22" cy="22" r="11" fill="currentColor" fill-opacity="0.16"/>'
|
||||
'<circle cx="22" cy="22" r="11" stroke="currentColor" stroke-width="1.6" fill="none"/>'
|
||||
'<circle cx="22" cy="22" r="3.4" fill="currentColor"/>'
|
||||
)
|
||||
_FALLBACK_TECH = (
|
||||
'<rect x="15" y="15" width="14" height="14" rx="2.5" transform="rotate(45 22 22)" '
|
||||
'fill="none" stroke="currentColor" stroke-width="2"/><circle cx="22" cy="22" r="2.4" fill="currentColor"/>'
|
||||
)
|
||||
|
||||
|
||||
def _load_icons(file: Path = ICON_FILE) -> tuple[dict, dict]:
|
||||
"""Read the icon sidecar: (category slug -> {hue, glyph}, technique name -> svg).
|
||||
A missing or malformed file is non-fatal — everything then uses the fallbacks below."""
|
||||
try:
|
||||
data = json.loads(file.read_text(encoding="utf-8"))
|
||||
except (OSError, ValueError):
|
||||
return {}, {}
|
||||
return (data.get("categories") or {}), (data.get("techniques") or {})
|
||||
|
||||
|
||||
_CATEGORY_STYLES, _TECH_ICONS = _load_icons()
|
||||
|
||||
|
||||
def _hsl_hex(deg: int, s: float, lt: float) -> str:
|
||||
import colorsys
|
||||
|
||||
r, g, b = colorsys.hls_to_rgb((deg % 360) / 360, lt, s)
|
||||
return "#%02x%02x%02x" % (round(r * 255), round(g * 255), round(b * 255))
|
||||
|
||||
|
||||
def category_style(cat: str) -> tuple[str, str]:
|
||||
"""(hue, glyph markup) for a category — from the sidecar for the shipped set, derived for extras."""
|
||||
style = _CATEGORY_STYLES.get(cat)
|
||||
if style and style.get("hue"):
|
||||
return style["hue"], style.get("glyph") or _FALLBACK_GLYPH
|
||||
deg = int(hashlib.md5(cat.encode("utf-8")).hexdigest(), 16) % 360
|
||||
return _hsl_hex(deg, 0.58, 0.52), _FALLBACK_GLYPH
|
||||
|
||||
|
||||
def tech_icon(name: str) -> str:
|
||||
"""The hand-picked line-icon for a specific technique (neutral mark if unknown)."""
|
||||
return _TECH_ICONS.get(name, _FALLBACK_TECH)
|
||||
|
||||
|
||||
SELECTOR_TEMPLATE = r"""<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<title>BMad Method Brainstorming Selection</title>
|
||||
<script>
|
||||
/* set the theme before first paint so there's no light-mode flash */
|
||||
(function(){ try {
|
||||
var t = localStorage.getItem('bmad-theme');
|
||||
if (!t) { t = (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) ? 'dark' : 'light'; }
|
||||
document.documentElement.setAttribute('data-theme', t);
|
||||
} catch(e){} })();
|
||||
</script>
|
||||
<style>
|
||||
:root {
|
||||
--bg:#f6f7fb; --surface:#fff; --ink:#1c1e2b; --muted:#6b7080;
|
||||
--accent:#5b4bdc; --accent-ink:#5b4bdc; --warn:#c0561f;
|
||||
--line:#e6e8f0; --control:#eef0f7; --control2:#f1f2f8; --raised:#fff;
|
||||
--cnt:#b9bdce; --foot:#aeb2c4; --shadow:rgba(20,20,50,.06);
|
||||
}
|
||||
:root[data-theme="dark"] {
|
||||
--bg:#0f1117; --surface:#171a23; --ink:#e7e9f2; --muted:#9aa0b4;
|
||||
--accent:#6d5cf0; --accent-ink:#a99bff; --warn:#e08a4a;
|
||||
--line:#2a2f3e; --control:#222634; --control2:#1d212d; --raised:#2c3242;
|
||||
--cnt:#5a6076; --foot:#5a6076; --shadow:rgba(0,0,0,.45);
|
||||
}
|
||||
/* lift the category hue toward white on dark surfaces so deep hues stay legible */
|
||||
:root[data-theme="dark"] section > h2 { color:color-mix(in srgb, var(--c) 62%, #fff); }
|
||||
:root[data-theme="dark"] .tech .ico { color:color-mix(in srgb, var(--c) 68%, #fff); }
|
||||
:root[data-theme="dark"] label.tech:has(input:checked) { border-color:color-mix(in srgb, var(--c) 60%, #fff); }
|
||||
.titlerow { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
|
||||
.themebtn { flex:none; width:36px; height:36px; border-radius:9px; background:var(--control); color:var(--ink); font-size:17px; line-height:1; display:inline-flex; align-items:center; justify-content:center; }
|
||||
.themebtn:hover { background:var(--raised); }
|
||||
* { box-sizing:border-box; }
|
||||
body { margin:0; font:16px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif; background:var(--bg); color:var(--ink); }
|
||||
header { position:sticky; top:0; z-index:5; background:var(--surface); padding:20px 0 12px; border-bottom:1px solid var(--line); box-shadow:0 2px 12px var(--shadow); }
|
||||
.hwrap { max-width:1120px; margin:0 auto; padding:0 24px; } /* align header content with the card column on wide screens */
|
||||
h1 { margin:0 0 4px; font-size:24px; letter-spacing:-.02em; }
|
||||
.sub { margin:0 0 12px; color:var(--muted); font-size:14px; max-width:74ch; }
|
||||
button { font:inherit; border:0; border-radius:8px; cursor:pointer; }
|
||||
.composer { display:flex; flex-direction:column; gap:9px; margin:6px 0 12px; }
|
||||
.grp { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
|
||||
.glabel { font-size:11px; text-transform:uppercase; letter-spacing:.07em; color:var(--muted); min-width:74px; }
|
||||
.modes { display:inline-flex; background:var(--control); border-radius:9px; padding:3px; gap:2px; }
|
||||
.mode { padding:7px 13px; font-size:14px; font-weight:600; color:var(--muted); background:transparent; }
|
||||
.mode.on { background:var(--raised); color:var(--accent-ink); box-shadow:0 1px 3px var(--shadow); }
|
||||
.modehint { flex:1 1 240px; min-width:0; font-size:13px; color:var(--muted); font-style:italic; }
|
||||
.pill { font-size:13px; color:var(--muted); background:var(--control); padding:6px 12px; border-radius:20px; }
|
||||
.pill b { color:var(--accent-ink); }
|
||||
.step { display:inline-flex; align-items:center; gap:7px; font-size:13px; color:var(--ink); background:var(--control2); padding:4px 6px 4px 12px; border-radius:20px; }
|
||||
.step b { min-width:12px; text-align:center; font-size:14px; color:var(--ink); }
|
||||
.step button { width:24px; height:24px; border-radius:50%; background:var(--raised); color:var(--muted); font-size:17px; line-height:22px; text-align:center; box-shadow:0 1px 2px var(--shadow); }
|
||||
.step button:hover { color:var(--accent-ink); }
|
||||
.total { font-size:12px; color:var(--muted); }
|
||||
.total.warn { color:var(--warn); font-weight:600; }
|
||||
.bar { display:flex; gap:10px 14px; align-items:center; flex-wrap:wrap; }
|
||||
#copy { margin-left:auto; padding:9px 22px; background:var(--accent); color:#fff; font-size:14px; font-weight:700; }
|
||||
#copy:hover { filter:brightness(1.07); }
|
||||
.chips { flex:1 1 320px; min-width:0; display:flex; gap:7px; flex-wrap:wrap; align-items:center; }
|
||||
.chip { font-size:12px; padding:4px 11px; border-radius:16px; border:0; color:#fff; background:var(--cc); font-weight:600; cursor:pointer; }
|
||||
.chip:hover { filter:brightness(1.08); }
|
||||
.banner { max-height:0; overflow:hidden; transition:max-height .25s ease, padding .22s ease, margin .22s ease; background:linear-gradient(90deg,var(--accent),#8275f2); color:#fff; border-radius:10px; font-weight:700; text-align:center; padding:0 14px; }
|
||||
.banner.show { max-height:64px; padding:13px 14px; margin-top:10px; }
|
||||
.banner.fail { background:linear-gradient(90deg,var(--warn),#e0894a); }
|
||||
main { padding:18px 24px 60px; max-width:1120px; margin:0 auto; }
|
||||
section { margin:0 0 26px; }
|
||||
section > h2 { font-size:13px; text-transform:uppercase; letter-spacing:.08em; color:var(--c); margin:0 0 10px; border-bottom:1px solid color-mix(in srgb, var(--c) 24%, var(--line)); padding-bottom:6px; }
|
||||
section > h2 .cnt { color:color-mix(in srgb, var(--c) 45%, var(--cnt)); margin-left:6px; }
|
||||
.grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); gap:10px; }
|
||||
label.tech { display:flex; gap:12px; align-items:flex-start; background:color-mix(in srgb, var(--c) 5%, var(--surface)); border:1px solid color-mix(in srgb, var(--c) 18%, var(--line)); border-radius:10px; padding:11px 13px; cursor:pointer; transition:border-color .12s, box-shadow .12s, background .12s; }
|
||||
label.tech:hover { border-color:color-mix(in srgb, var(--c) 45%, var(--surface)); }
|
||||
label.tech input { margin-top:2px; width:17px; height:17px; accent-color:var(--c); flex:none; }
|
||||
label.tech:has(input:checked) { border-color:var(--c); background:color-mix(in srgb, var(--c) 12%, var(--surface)); box-shadow:0 0 0 2px color-mix(in srgb, var(--c) 30%, transparent); }
|
||||
.tech .ic2 { display:flex; gap:5px; flex:none; }
|
||||
.tech .ico { width:40px; height:40px; flex:none; color:var(--c); }
|
||||
.tech .n { font-weight:600; display:block; }
|
||||
.tech .d { color:var(--muted); font-size:13.5px; display:block; margin-top:2px; }
|
||||
.tech .gf { color:var(--accent-ink); font-size:11px; display:block; margin-top:5px; opacity:.85; }
|
||||
.grouphdr { margin:30px 0 12px; font-size:12px; text-transform:uppercase; letter-spacing:.14em; font-weight:700; color:var(--c); opacity:.92; border-bottom:1px solid color-mix(in srgb, var(--c) 22%, var(--line)); padding-bottom:7px; }
|
||||
main > .grouphdr:first-child { margin-top:2px; }
|
||||
:root[data-theme="dark"] .grouphdr { color:color-mix(in srgb, var(--c) 62%, #fff); }
|
||||
.goals { display:flex; gap:7px; flex-wrap:wrap; }
|
||||
.goal { font-size:12px; padding:5px 12px; border-radius:16px; background:var(--control); color:var(--muted); font-weight:600; }
|
||||
.goal:hover { color:var(--ink); }
|
||||
.goal.on { background:var(--accent); color:#fff; }
|
||||
label.tech.invent { border-style:dashed; background:transparent; }
|
||||
label.tech.invent:hover { border-color:var(--c); }
|
||||
label.tech.invent .n { color:var(--c); }
|
||||
label.tech.hidden { display:none; }
|
||||
footer { text-align:center; color:var(--foot); font-size:12px; padding:24px; }
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<header>
|
||||
<div class="hwrap">
|
||||
<div class="titlerow">
|
||||
<h1>BMad Method Brainstorming Selection</h1>
|
||||
<button id="theme" class="themebtn" type="button" aria-label="Toggle dark mode" title="Toggle dark mode"></button>
|
||||
</div>
|
||||
<p class="sub">Compose your session, hit <strong>Copy prompt</strong>, and paste it back into the chat to begin. {{TOTAL}}</p>
|
||||
|
||||
<div class="composer">
|
||||
<div class="grp">
|
||||
<span class="glabel">Facilitation</span>
|
||||
<div class="modes" id="modes">
|
||||
<button type="button" class="mode on" data-mode="Facilitator">Facilitator</button>
|
||||
<button type="button" class="mode" data-mode="Creative Partner">Creative Partner</button>
|
||||
<button type="button" class="mode" data-mode="Ideate for me">Ideate for me</button>
|
||||
</div>
|
||||
<span class="modehint" id="modehint"></span>
|
||||
</div>
|
||||
<div class="grp">
|
||||
<span class="glabel">Techniques</span>
|
||||
<span class="pill">Picked <b id="pickN">0</b></span>
|
||||
<span class="step">Random <button type="button" data-step="rand" data-d="-1">−</button><b id="randN">0</b><button type="button" data-step="rand" data-d="1">+</button></span>
|
||||
<span class="step">Invent <button type="button" data-step="inv" data-d="-1">−</button><b id="invN">0</b><button type="button" data-step="inv" data-d="1">+</button></span>
|
||||
<span class="step">AI picks <button type="button" data-step="ai" data-d="-1">−</button><b id="aiN">0</b><button type="button" data-step="ai" data-d="1">+</button></span>
|
||||
<span class="total" id="total">Total 0 · 3–4 is the sweet spot</span>
|
||||
<button id="copy" type="button">Copy prompt</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{{GOALBAR}}
|
||||
<div class="bar">
|
||||
<span class="glabel">Jump to</span>
|
||||
<div class="chips" id="chips">{{CHIPS}}</div>
|
||||
</div>
|
||||
|
||||
<div class="banner" id="banner">✓ Copied! Now paste it into the chat to start your session.</div>
|
||||
</div>
|
||||
</header>
|
||||
<main>
|
||||
{{BODY}}
|
||||
</main>
|
||||
<footer>BMad Method · Brainstorming</footer>
|
||||
<script>
|
||||
(function(){
|
||||
var $ = function(id){ return document.getElementById(id); };
|
||||
var all = Array.prototype.slice;
|
||||
var boxes = all.call(document.querySelectorAll('input[type=checkbox]'));
|
||||
var techBoxes = boxes.filter(function(b){ return b.dataset.name; }); // real technique cards
|
||||
var inventBoxes = boxes.filter(function(b){ return b.dataset.invent; }); // per-category "invent in the spirit of" cards
|
||||
var header = document.querySelector('header');
|
||||
var sections = all.call(document.querySelectorAll('section'));
|
||||
var state = { mode: 'Facilitator', rand: 0, inv: 0, ai: 0 };
|
||||
var MODE_HINTS = {
|
||||
'Facilitator': 'A forcing function for your ideas — I prompt and push, but never supply them.',
|
||||
'Creative Partner': 'We riff together — I facilitate and add ideas too, each logged as yours or mine.',
|
||||
'Ideate for me': 'I run the whole session myself, then show you the result and offer to keep going.'
|
||||
};
|
||||
function setHint(){ $('modehint').textContent = MODE_HINTS[state.mode] || ''; }
|
||||
|
||||
var themeBtn = $('theme');
|
||||
function setThemeIcon(){ themeBtn.textContent = document.documentElement.getAttribute('data-theme') === 'dark' ? '☀' : '☾'; }
|
||||
themeBtn.addEventListener('click', function(){
|
||||
var next = document.documentElement.getAttribute('data-theme') === 'dark' ? 'light' : 'dark';
|
||||
document.documentElement.setAttribute('data-theme', next);
|
||||
try { localStorage.setItem('bmad-theme', next); } catch(e){}
|
||||
setThemeIcon();
|
||||
});
|
||||
|
||||
all.call(document.querySelectorAll('.mode')).forEach(function(b){
|
||||
b.addEventListener('click', function(){
|
||||
all.call(document.querySelectorAll('.mode')).forEach(function(m){ m.classList.remove('on'); });
|
||||
b.classList.add('on');
|
||||
state.mode = b.dataset.mode;
|
||||
setHint();
|
||||
});
|
||||
});
|
||||
|
||||
all.call(document.querySelectorAll('[data-step]')).forEach(function(btn){
|
||||
btn.addEventListener('click', function(){
|
||||
var k = btn.dataset.step, d = parseInt(btn.dataset.d, 10);
|
||||
state[k] = Math.max(0, state[k] + d);
|
||||
update();
|
||||
});
|
||||
});
|
||||
|
||||
// Category chips are jump-nav: click one to smooth-scroll its section into view,
|
||||
// offsetting by the sticky header's height so the heading isn't hidden beneath it.
|
||||
all.call(document.querySelectorAll('.chip')).forEach(function(chip){
|
||||
chip.addEventListener('click', function(){
|
||||
var sec = null;
|
||||
for (var i = 0; i < sections.length; i++){ if (sections[i].dataset.cat === chip.dataset.cat){ sec = sections[i]; break; } }
|
||||
if (!sec){ return; }
|
||||
var top = sec.getBoundingClientRect().top + window.pageYOffset - header.offsetHeight - 8;
|
||||
window.scrollTo({ top: top, behavior: 'smooth' });
|
||||
});
|
||||
});
|
||||
|
||||
boxes.forEach(function(b){ b.addEventListener('change', update); });
|
||||
|
||||
// A `classic` technique appears twice (lead "Proven & Professional" group + its home
|
||||
// category), so de-dupe checked picks by name; the lead copy carries data-lead.
|
||||
function checkedTech(){
|
||||
var seen = {}, out = [];
|
||||
techBoxes.forEach(function(b){
|
||||
if (!b.checked || seen[b.dataset.name]) { return; }
|
||||
seen[b.dataset.name] = 1;
|
||||
out.push(b);
|
||||
});
|
||||
return out;
|
||||
}
|
||||
function checkedInvent(){ return inventBoxes.filter(function(b){ return b.checked; }); }
|
||||
|
||||
function update(){
|
||||
$('pickN').textContent = checkedTech().length;
|
||||
$('randN').textContent = state.rand;
|
||||
$('invN').textContent = state.inv;
|
||||
$('aiN').textContent = state.ai;
|
||||
var total = checkedTech().length + state.rand + state.inv + checkedInvent().length + state.ai;
|
||||
var t = $('total');
|
||||
t.textContent = 'Total ' + total + ' · 3–4 is the sweet spot';
|
||||
t.classList.toggle('warn', total > 5);
|
||||
}
|
||||
|
||||
// "Great for" goal filter: clicking a goal narrows visible cards to those tagged with it.
|
||||
var goalBtns = all.call(document.querySelectorAll('.goal'));
|
||||
function activeGoals(){ return goalBtns.filter(function(b){ return b.classList.contains('on'); }).map(function(b){ return b.dataset.goal; }); }
|
||||
function applyFilter(){
|
||||
var act = activeGoals();
|
||||
all.call(document.querySelectorAll('label.tech')).forEach(function(lab){
|
||||
var inp = lab.querySelector('input');
|
||||
if (inp.dataset.invent){ return; } // invent cards aren't goal-tagged — always visible
|
||||
var good = (inp.dataset.good || '').split('|');
|
||||
var show = !act.length || act.some(function(g){ return good.indexOf(g) >= 0; });
|
||||
lab.classList.toggle('hidden', !show);
|
||||
});
|
||||
}
|
||||
goalBtns.forEach(function(b){ b.addEventListener('click', function(){ b.classList.toggle('on'); applyFilter(); }); });
|
||||
|
||||
function randomPool(){
|
||||
var picked = {};
|
||||
checkedTech().forEach(function(b){ picked[b.dataset.name] = 1; });
|
||||
// draw from unchecked, non-lead copies, skipping anything already picked
|
||||
return techBoxes.filter(function(b){ return !b.checked && !b.dataset.lead && !picked[b.dataset.name]; });
|
||||
}
|
||||
|
||||
function sample(arr, n){
|
||||
var a = arr.slice(), out = [];
|
||||
while (out.length < n && a.length){ out.push(a.splice(Math.floor(Math.random() * a.length), 1)[0]); }
|
||||
return out;
|
||||
}
|
||||
|
||||
function compose(){
|
||||
var picks = checkedTech().map(function(b){ return { n: b.dataset.name, c: b.dataset.cat, d: b.dataset.desc, r: false }; });
|
||||
var rnd = sample(randomPool(), state.rand).map(function(b){ return { n: b.dataset.name, c: b.dataset.cat, d: b.dataset.desc, r: true }; });
|
||||
var techs = picks.concat(rnd);
|
||||
var L = ["Let's run my brainstorming session.", "", 'Facilitation mode: ' + state.mode + '.'];
|
||||
if (techs.length){
|
||||
L.push("", 'Techniques to use:');
|
||||
techs.forEach(function(t, i){
|
||||
L.push((i + 1) + '.' + (t.r ? ' (random pick)' : '') + ' ' + t.n + ' · ' + t.c);
|
||||
L.push(' ' + t.d);
|
||||
});
|
||||
}
|
||||
var extra = [];
|
||||
if (state.inv > 0){ extra.push('invent ' + state.inv + ' brand-new technique' + (state.inv > 1 ? 's' : '') + ' on the fly'); }
|
||||
checkedInvent().forEach(function(b){ extra.push('invent 1 new technique in the spirit of ' + b.dataset.invent); });
|
||||
if (state.ai > 0){ extra.push('you choose ' + state.ai + ' more technique' + (state.ai > 1 ? 's' : '') + ' that fit my goal'); }
|
||||
if (extra.length){ L.push("", 'Then: ' + extra.join('; and ') + '.'); }
|
||||
if (!techs.length && !extra.length){
|
||||
L.push("", state.mode === 'Ideate for me'
|
||||
? 'Run the whole session yourself — pick the techniques, generate the ideas, then show me the result.'
|
||||
: 'Help me choose 3–4 techniques to start.');
|
||||
}
|
||||
return L.join('\n');
|
||||
}
|
||||
|
||||
function fallbackCopy(t){
|
||||
var ta = document.createElement('textarea');
|
||||
ta.value = t; ta.style.position = 'fixed'; ta.style.opacity = '0';
|
||||
document.body.appendChild(ta); ta.focus(); ta.select();
|
||||
var ok = false;
|
||||
try { ok = document.execCommand('copy'); } catch(e){ ok = false; }
|
||||
document.body.removeChild(ta);
|
||||
return ok;
|
||||
}
|
||||
|
||||
function flash(ok, text){
|
||||
var b = $('banner');
|
||||
b.classList.toggle('fail', !ok);
|
||||
b.innerHTML = ok
|
||||
? '✓ Copied! Now paste it into the chat to start your session.'
|
||||
: '⚠ Couldn’t reach the clipboard — copy the text in the box, then paste it into the chat.';
|
||||
b.classList.add('show');
|
||||
setTimeout(function(){ b.classList.remove('show'); }, 4500);
|
||||
// Last resort on a hard failure: a prefilled, selectable prompt so the text is never lost.
|
||||
if (!ok){ window.prompt('Copy this, then paste it into the chat:', text); }
|
||||
}
|
||||
|
||||
$('copy').addEventListener('click', function(){
|
||||
var text = compose();
|
||||
if (navigator.clipboard && navigator.clipboard.writeText){
|
||||
navigator.clipboard.writeText(text).then(
|
||||
function(){ flash(true, text); },
|
||||
function(){ flash(fallbackCopy(text), text); }
|
||||
);
|
||||
} else { flash(fallbackCopy(text), text); }
|
||||
});
|
||||
|
||||
setHint();
|
||||
setThemeIcon();
|
||||
update();
|
||||
})();
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
"""
|
||||
|
||||
|
||||
# --- browse-page layout: a "Proven & Professional" lead group, then super-groups ----------
|
||||
CLASSIC_GROUP = "Proven & Professional"
|
||||
LEAD_HUE = "#3d4f73" # a dignified slate for the professional lead group
|
||||
|
||||
# Super-group order for the shipped categories. Categories not listed (e.g. user-added
|
||||
# via --extra) render last under "More", alphabetically — so custom catalogs always show.
|
||||
CATEGORY_GROUPS = (
|
||||
("Structured & Analytical", ("structured", "deep")),
|
||||
("Creative & Generative", ("creative", "biomimetic", "cultural", "speculative_future", "quantum")),
|
||||
("Wild & Playful", ("wild", "absurdist", "theatrical", "constraint")),
|
||||
("Introspective & Personal", ("introspective_delight", "collaborative")),
|
||||
)
|
||||
|
||||
# Human labels for the `good_for` goal tags; this dict's order is the filter-bar order.
|
||||
GOAL_LABELS = {
|
||||
"feature": "Build a feature",
|
||||
"novel": "Novel concept",
|
||||
"strategy": "Strategy",
|
||||
"planning": "Planning",
|
||||
"diagnosis": "Diagnose",
|
||||
"personal": "Personal / life",
|
||||
"unstuck": "Get unstuck",
|
||||
}
|
||||
|
||||
|
||||
def _good_for_label(good: str) -> str:
|
||||
parts = [GOAL_LABELS.get(g, g) for g in good.split("|") if g]
|
||||
return ("Great for: " + " · ".join(parts)) if parts else ""
|
||||
|
||||
|
||||
def _svg(inner: str) -> str:
|
||||
return f'<svg class="ico" viewBox="0 0 44 44" xmlns="http://www.w3.org/2000/svg">{CHIP}{inner}</svg>'
|
||||
|
||||
|
||||
def _card(r: dict, lead: bool = False) -> str:
|
||||
"""One technique card. `lead=True` cards live in the cross-cutting professional group;
|
||||
they carry their own category hue (inline --c) and data-lead so selection can de-dupe."""
|
||||
name = html.escape(r["technique_name"])
|
||||
desc = html.escape(r["description"])
|
||||
hue, glyph = category_style(r["category"])
|
||||
disp_cat = html.escape(pretty(r["category"]))
|
||||
good = html.escape(r.get("good_for", ""))
|
||||
prov = html.escape(r.get("provenance", ""))
|
||||
style = f' style="--c:{hue}"' if lead else ""
|
||||
lead_attr = ' data-lead="1"' if lead else ""
|
||||
gf = _good_for_label(r.get("good_for", ""))
|
||||
gf_html = f'<span class="gf">{html.escape(gf)}</span>' if gf else ""
|
||||
return (
|
||||
f'<label class="tech"{style}><input type="checkbox" '
|
||||
f'data-name="{name}" data-cat="{disp_cat}" data-desc="{desc}" data-good="{good}" data-prov="{prov}"{lead_attr}>'
|
||||
f'<span class="ic2">{_svg(glyph)}{_svg(tech_icon(r["technique_name"]))}</span>'
|
||||
f'<span><span class="n">{name}</span><span class="d">{desc}</span>{gf_html}</span></label>'
|
||||
)
|
||||
|
||||
|
||||
def _invent_card(disp_cat: str, glyph: str) -> str:
|
||||
"""A dashed 'invent on the fly, in this category's spirit' card appended to each section."""
|
||||
return (
|
||||
f'<label class="tech invent"><input type="checkbox" data-invent="{disp_cat}">'
|
||||
f'<span class="ic2">{_svg(glyph)}</span>'
|
||||
f'<span><span class="n">✨ Invent a {disp_cat} technique</span>'
|
||||
f'<span class="d">Make up a brand-new technique on the fly, in the spirit of {disp_cat}</span></span></label>'
|
||||
)
|
||||
|
||||
|
||||
def html_doc(rows: list[dict]) -> str:
|
||||
"""Render the self-contained 'browse all techniques' selection page from the catalog.
|
||||
|
||||
Deterministic ordering so the shipped asset can be snapshot-tested against the CSV:
|
||||
a cross-cutting "Proven & Professional" lead group (every `classic`-tagged row), then
|
||||
the categories in fixed super-group order, then any unlisted/custom categories under
|
||||
"More" alphabetically. Techniques render in file order within a category. A `classic`
|
||||
row appears both in the lead group and its home category; the page de-dupes on select.
|
||||
"""
|
||||
groups: dict[str, list[dict]] = {}
|
||||
for r in rows:
|
||||
groups.setdefault(r["category"], []).append(r)
|
||||
|
||||
body: list[str] = []
|
||||
chips: list[str] = []
|
||||
|
||||
def add_section(cat: str) -> None:
|
||||
hue, glyph = category_style(cat)
|
||||
disp = html.escape(pretty(cat))
|
||||
cards = [_card(r) for r in groups[cat]]
|
||||
cards.append(_invent_card(disp, glyph))
|
||||
chips.append(f'<button type="button" class="chip" data-cat="{disp}" style="--cc:{hue}">{disp}</button>')
|
||||
body.append(
|
||||
f'<section data-cat="{disp}" style="--c:{hue}"><h2>{disp}<span class="cnt">{len(groups[cat])}</span></h2>'
|
||||
f'<div class="grid">{"".join(cards)}</div></section>'
|
||||
)
|
||||
|
||||
# 1) lead group — every classic-tagged technique, cross-category (no invent card here)
|
||||
classics = [r for r in rows if r.get("provenance", "").lower() == "classic"]
|
||||
if classics:
|
||||
disp = html.escape(CLASSIC_GROUP)
|
||||
lead_cards = "".join(_card(r, lead=True) for r in classics)
|
||||
chips.append(f'<button type="button" class="chip" data-cat="{disp}" style="--cc:{LEAD_HUE}">{disp}</button>')
|
||||
body.append(
|
||||
f'<section data-cat="{disp}" style="--c:{LEAD_HUE}"><h2>{disp}<span class="cnt">{len(classics)}</span></h2>'
|
||||
f'<div class="grid">{lead_cards}</div></section>'
|
||||
)
|
||||
|
||||
# 2) shipped categories, in super-group order
|
||||
placed = set()
|
||||
for group_title, cats in CATEGORY_GROUPS:
|
||||
present = [c for c in cats if c in groups]
|
||||
if not present:
|
||||
continue
|
||||
hue, _ = category_style(present[0])
|
||||
body.append(f'<h2 class="grouphdr" style="--c:{hue}">{html.escape(group_title)}</h2>')
|
||||
for c in present:
|
||||
add_section(c)
|
||||
placed.add(c)
|
||||
|
||||
# 3) leftover (custom / --extra) categories, alphabetically
|
||||
leftover = sorted(c for c in groups if c not in placed)
|
||||
if leftover:
|
||||
body.append('<h2 class="grouphdr" style="--c:#8a8f9e">More</h2>')
|
||||
for c in leftover:
|
||||
add_section(c)
|
||||
|
||||
# goal-affinity filter bar — only if the catalog actually carries good_for tags
|
||||
present_goals: set[str] = set()
|
||||
for r in rows:
|
||||
for g in (r.get("good_for", "") or "").split("|"):
|
||||
if g:
|
||||
present_goals.add(g)
|
||||
goalbar = ""
|
||||
if present_goals:
|
||||
ordered = [g for g in GOAL_LABELS if g in present_goals] + sorted(present_goals - set(GOAL_LABELS))
|
||||
gchips = "".join(
|
||||
f'<button type="button" class="goal" data-goal="{html.escape(g)}">{html.escape(GOAL_LABELS.get(g, g))}</button>'
|
||||
for g in ordered
|
||||
)
|
||||
goalbar = f'<div class="bar"><span class="glabel">Great for</span><div class="goals" id="goals">{gchips}</div></div>'
|
||||
|
||||
total = html.escape(f"{len(rows)} techniques across {len(groups)} categories.")
|
||||
return (
|
||||
SELECTOR_TEMPLATE.replace("{{BODY}}", "\n".join(body))
|
||||
.replace("{{CHIPS}}", "".join(chips))
|
||||
.replace("{{GOALBAR}}", goalbar)
|
||||
.replace("{{TOTAL}}", total)
|
||||
)
|
||||
|
||||
|
||||
def main(argv: list[str] | None = None) -> int:
|
||||
p = argparse.ArgumentParser(description=__doc__, formatter_class=argparse.RawDescriptionHelpFormatter)
|
||||
p.add_argument("--file", type=Path, default=DEFAULT_FILE, help="technique CSV (default: sibling assets/brain-methods.csv)")
|
||||
p.add_argument("--extra", type=Path, help="JSON overlay of additional techniques (customize.toml additional_techniques), merged into every command")
|
||||
p.add_argument("--json", action="store_true", help="emit structured JSON instead of lean text")
|
||||
sub = p.add_subparsers(dest="cmd", required=True)
|
||||
sub.add_parser("categories", help="list category names + counts")
|
||||
pl = sub.add_parser("list", help="the index: category/name/gist (needs --category or --all)")
|
||||
pl.add_argument("--category", action="append", help="filter to a category (repeatable)")
|
||||
pl.add_argument("--all", action="store_true", help="dump the entire catalog (deliberate; large)")
|
||||
ps = sub.add_parser("show", help="full gist + detail file for named techniques")
|
||||
ps.add_argument("names", nargs="+")
|
||||
pr = sub.add_parser("random", help="pick techniques at random")
|
||||
pr.add_argument("--category", action="append", help="restrict to a category (repeatable)")
|
||||
pr.add_argument("-n", type=int, default=1, help="how many (default 1)")
|
||||
ph = sub.add_parser("html", help="write the offline 'browse all' selection page")
|
||||
ph.add_argument("--out", help="file to write the page to (required; never prints the catalog)")
|
||||
args = p.parse_args(argv)
|
||||
|
||||
if not args.file.is_file():
|
||||
print(f"error: technique file not found: {args.file}", file=sys.stderr)
|
||||
return 2
|
||||
rows = load(args.file)
|
||||
if args.extra:
|
||||
if not args.extra.is_file():
|
||||
print(f"error: --extra file not found: {args.extra}", file=sys.stderr)
|
||||
return 2
|
||||
rows += load_extra(args.extra)
|
||||
csv_dir = args.file.resolve().parent
|
||||
|
||||
if args.cmd == "categories":
|
||||
print(fmt_categories(categories(rows), args.json))
|
||||
elif args.cmd == "list":
|
||||
if not args.category and not args.all:
|
||||
print(
|
||||
"error: `list` needs --category (one or more) — or --all to dump the whole "
|
||||
"catalog on purpose. Use `categories` for the cheap map, or `random` to draw blind.",
|
||||
file=sys.stderr,
|
||||
)
|
||||
return 2
|
||||
print(fmt_list(filter_cats(rows, args.category), args.json))
|
||||
elif args.cmd == "show":
|
||||
found, missing = find(rows, args.names)
|
||||
for m in missing:
|
||||
print(f"# not found: {m}", file=sys.stderr)
|
||||
if not found:
|
||||
return 1
|
||||
print(fmt_show(found, csv_dir, args.json))
|
||||
elif args.cmd == "random":
|
||||
pool = filter_cats(rows, args.category)
|
||||
if not pool:
|
||||
print("# no techniques match", file=sys.stderr)
|
||||
return 1
|
||||
n = max(0, min(args.n, len(pool))) # clamp: never crash on a negative or oversized -n
|
||||
print(fmt_list(random.sample(pool, n), args.json))
|
||||
elif args.cmd == "html":
|
||||
if not args.out:
|
||||
print(
|
||||
"error: `html` needs --out PATH — it writes the selection page to a file and "
|
||||
"never prints the catalog to stdout (which would defeat the point).",
|
||||
file=sys.stderr,
|
||||
)
|
||||
return 2
|
||||
out = Path(args.out)
|
||||
out.parent.mkdir(parents=True, exist_ok=True)
|
||||
out.write_text(html_doc(rows), encoding="utf-8")
|
||||
print(f"wrote {out} ({len(rows)} techniques, {len(categories(rows))} categories)")
|
||||
return 0
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
sys.exit(main())
|
||||
|
|
@ -0,0 +1,202 @@
|
|||
#!/usr/bin/env python3
|
||||
# /// script
|
||||
# requires-python = ">=3.10"
|
||||
# ///
|
||||
"""memlog — an append-only memory log: LLM-optimal working memory for a skill.
|
||||
|
||||
A memlog is the dense, chronological record of everything that mattered in a piece of
|
||||
work — every item the user generated or accepted — kept minimal like human memory: only
|
||||
what's important, never bloated. It persists ACROSS sessions, so a fresh session can
|
||||
load it and continue. It is NOT a deliverable; downstream artifacts (a brief, a PRD, a
|
||||
deck, a report) are *derived* from it on demand. The host skill supplies the vocabulary
|
||||
by how it calls `append` — the tool stays neutral.
|
||||
|
||||
It is a FLAT log: there are no sections or grouping. Every entry is one line, recorded
|
||||
at the END in the order it happened. The chronology itself is the structure — an event
|
||||
like "started technique X" is just another entry, same as an idea or an insight.
|
||||
|
||||
Two invariants make it trustworthy:
|
||||
|
||||
1. Append-only, chronological. Entries land at the end, in the order they happen.
|
||||
Nothing is ever inserted backward, reordered, or grouped.
|
||||
2. Write-only / blind. Every command is an atomic, context-free write and echoes the
|
||||
new state as JSON, so the caller never re-reads the file mid-session. The one time
|
||||
the file is read is on resume — and the caller reads it itself, not via this script.
|
||||
|
||||
The file shape (.memlog.md):
|
||||
|
||||
---
|
||||
topic: Onboarding flow for a budgeting app
|
||||
goal: lift week-1 retention
|
||||
status: active
|
||||
updated: 2026-05-30T14:22
|
||||
---
|
||||
|
||||
- (note) user picked techniques: SCAMPER, then Six Thinking Hats
|
||||
- (technique) started SCAMPER
|
||||
- (idea) skip the signup wall: let people try with sample data first
|
||||
- (idea) auto-import one bank account so the first screen shows real numbers
|
||||
- (question) is open-banking consent too heavy for step one?
|
||||
- (technique) started Six Thinking Hats
|
||||
- (idea) black-hat: imported transactions look scary before they're categorized
|
||||
- (insight) the "scary numbers" risk and the "real numbers" idea are one lever: show real data, pre-categorized
|
||||
- (direction) user wants to optimize for the anxious first-timer, not the power user
|
||||
- (decision) lead with one pre-categorized account; defer multi-account import
|
||||
|
||||
Each entry may carry an optional `--type` — what KIND it is (idea, insight, question,
|
||||
decision, technique, …) — and an optional `--by` naming who it came from (e.g. `user`,
|
||||
`coach`), for sessions where authorship matters. Both render into one short inline tag:
|
||||
`(idea)`, `(idea by user)`, `(by coach)`. Omit them for a plain note. The host skill
|
||||
names the vocabulary; the script does not.
|
||||
|
||||
Commands:
|
||||
init --workspace DIR [--field k=v ...] create the memlog (errors if it exists)
|
||||
append --workspace DIR --text STR [--type T] [--by W] append one entry at the end
|
||||
set --workspace DIR --key K --value V set/replace a frontmatter field
|
||||
|
||||
The workspace is the run folder; the memlog is always {workspace}/.memlog.md.
|
||||
"""
|
||||
import argparse
|
||||
import json
|
||||
import os
|
||||
import sys
|
||||
from datetime import datetime
|
||||
from pathlib import Path
|
||||
|
||||
MEMLOG = ".memlog.md"
|
||||
|
||||
|
||||
def now() -> str:
|
||||
return datetime.now().strftime("%Y-%m-%dT%H:%M")
|
||||
|
||||
|
||||
def memlog_path(workspace: str) -> Path:
|
||||
return Path(workspace) / MEMLOG
|
||||
|
||||
|
||||
def split(text: str) -> tuple[dict, str]:
|
||||
"""Return (frontmatter dict in source order, body str). Frontmatter is plain key: value.
|
||||
|
||||
The closing fence is the first line that is *exactly* `---`, so a `---` inside a
|
||||
field value (topic/goal are free user text) never truncates the frontmatter.
|
||||
"""
|
||||
lines = text.splitlines()
|
||||
if not lines or lines[0] != "---":
|
||||
raise ValueError(".memlog.md has no frontmatter")
|
||||
end = next((i for i in range(1, len(lines)) if lines[i] == "---"), None)
|
||||
if end is None:
|
||||
raise ValueError(".memlog.md frontmatter is not terminated")
|
||||
meta: dict[str, str] = {}
|
||||
for line in lines[1:end]:
|
||||
if ":" in line:
|
||||
k, v = line.split(":", 1)
|
||||
meta[k.strip()] = v.strip()
|
||||
return meta, "\n".join(lines[end + 1:]).lstrip("\n")
|
||||
|
||||
|
||||
def render(meta: dict, body: str) -> str:
|
||||
# Neutralize newlines in values so a multi-line field can't break the fence on re-read.
|
||||
fm = "\n".join(f"{k}: {' '.join(str(v).splitlines())}" for k, v in meta.items())
|
||||
return "---\n" + fm + "\n---\n\n" + body.rstrip("\n") + "\n"
|
||||
|
||||
|
||||
def touch(meta: dict) -> None:
|
||||
"""Stamp `updated` and keep it last so the field order stays predictable."""
|
||||
meta.pop("updated", None)
|
||||
meta["updated"] = now()
|
||||
|
||||
|
||||
def write_atomic(path: Path, text: str) -> None:
|
||||
tmp = path.with_suffix(path.suffix + ".tmp")
|
||||
tmp.write_text(text, encoding="utf-8")
|
||||
os.replace(tmp, path)
|
||||
|
||||
|
||||
def entry_count(body: str) -> int:
|
||||
return sum(1 for ln in body.splitlines() if ln.startswith("- "))
|
||||
|
||||
|
||||
def ack(path: Path, meta: dict, body: str) -> None:
|
||||
"""Echo new state so the caller never re-reads the file to know where it stands."""
|
||||
print(json.dumps({
|
||||
"ok": True,
|
||||
"memlog": str(path),
|
||||
"status": meta.get("status", ""),
|
||||
"entries": entry_count(body),
|
||||
}))
|
||||
|
||||
|
||||
def cmd_init(args) -> int:
|
||||
path = memlog_path(args.workspace)
|
||||
if path.exists():
|
||||
print(f"error: {path} already exists; use append/set to update it", file=sys.stderr)
|
||||
return 2
|
||||
path.parent.mkdir(parents=True, exist_ok=True)
|
||||
meta: dict[str, str] = {}
|
||||
for pair in args.field or []:
|
||||
if "=" not in pair:
|
||||
print(f"error: --field expects key=value, got {pair!r}", file=sys.stderr)
|
||||
return 2
|
||||
k, v = pair.split("=", 1)
|
||||
meta[k.strip()] = v.strip()
|
||||
meta.setdefault("status", "active")
|
||||
touch(meta)
|
||||
write_atomic(path, render(meta, ""))
|
||||
ack(path, meta, "")
|
||||
return 0
|
||||
|
||||
|
||||
def cmd_append(args) -> int:
|
||||
path = memlog_path(args.workspace)
|
||||
meta, body = split(path.read_text(encoding="utf-8"))
|
||||
text = " ".join(args.text.split()) # collapse newlines/runs → one-line entry, no prose bloat
|
||||
label = args.type or ""
|
||||
if args.by:
|
||||
label = f"{label} by {args.by}".strip() # attribution: "(idea by user)" / "(by coach)"
|
||||
tag = f"({label}) " if label else ""
|
||||
entry = f"- {tag}{text}"
|
||||
body = (body.rstrip("\n") + "\n" + entry) if body.strip() else entry # always at the end
|
||||
touch(meta)
|
||||
write_atomic(path, render(meta, body))
|
||||
ack(path, meta, body)
|
||||
return 0
|
||||
|
||||
|
||||
def cmd_set(args) -> int:
|
||||
path = memlog_path(args.workspace)
|
||||
meta, body = split(path.read_text(encoding="utf-8"))
|
||||
meta[args.key] = args.value
|
||||
touch(meta)
|
||||
write_atomic(path, render(meta, body))
|
||||
ack(path, meta, body)
|
||||
return 0
|
||||
|
||||
|
||||
def main(argv: list[str] | None = None) -> int:
|
||||
p = argparse.ArgumentParser(description=__doc__, formatter_class=argparse.RawDescriptionHelpFormatter)
|
||||
sub = p.add_subparsers(dest="cmd", required=True)
|
||||
|
||||
pi = sub.add_parser("init", help="create the memlog")
|
||||
pi.add_argument("--workspace", required=True)
|
||||
pi.add_argument("--field", action="append", metavar="KEY=VALUE", help="frontmatter field (repeatable)")
|
||||
pi.set_defaults(func=cmd_init)
|
||||
|
||||
pa = sub.add_parser("append", help="append one entry at the end")
|
||||
pa.add_argument("--workspace", required=True)
|
||||
pa.add_argument("--text", required=True)
|
||||
pa.add_argument("--type", help="entry kind, rendered as an inline tag")
|
||||
pa.add_argument("--by", help="who the entry came from (e.g. user, coach); rendered into the tag")
|
||||
pa.set_defaults(func=cmd_append)
|
||||
|
||||
pset = sub.add_parser("set", help="set a frontmatter field")
|
||||
pset.add_argument("--workspace", required=True)
|
||||
pset.add_argument("--key", required=True)
|
||||
pset.add_argument("--value", required=True)
|
||||
pset.set_defaults(func=cmd_set)
|
||||
|
||||
args = p.parse_args(argv)
|
||||
return args.func(args)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
sys.exit(main())
|
||||
|
|
@ -0,0 +1,217 @@
|
|||
# /// script
|
||||
# requires-python = ">=3.10"
|
||||
# dependencies = ["pytest>=8.0"]
|
||||
# ///
|
||||
"""Tests for brain.py. Run: uv run -m pytest scripts/tests/test_brain.py"""
|
||||
import sys
|
||||
from pathlib import Path
|
||||
|
||||
import pytest
|
||||
|
||||
sys.path.insert(0, str(Path(__file__).resolve().parent.parent))
|
||||
import brain # noqa: E402
|
||||
|
||||
CSV = """category,technique_name,description,detail
|
||||
collaborative,Yes And Building,Build on every idea with "yes and" to keep momentum,
|
||||
wild,Quantum Superposition,Hold contradictory ideas as simultaneously true,techniques/quantum.md
|
||||
structured,SCAMPER Method,Run the idea through seven transformation lenses,
|
||||
wild,Anti-Solution,Brainstorm how to make the problem worse then invert,
|
||||
"""
|
||||
|
||||
DETAIL = "# Quantum Superposition\nFull multi-step instructions for the complex technique."
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def lib(tmp_path):
|
||||
csv_path = tmp_path / "brain-methods.csv"
|
||||
csv_path.write_text(CSV, encoding="utf-8")
|
||||
(tmp_path / "techniques").mkdir()
|
||||
(tmp_path / "techniques" / "quantum.md").write_text(DETAIL, encoding="utf-8")
|
||||
return csv_path
|
||||
|
||||
|
||||
def test_load_normalizes_detail(lib):
|
||||
rows = brain.load(lib)
|
||||
assert len(rows) == 4
|
||||
assert rows[0]["detail"] == ""
|
||||
assert rows[1]["detail"] == "techniques/quantum.md"
|
||||
|
||||
|
||||
def test_categories_counts_sorted(lib):
|
||||
assert brain.categories(brain.load(lib)) == [("collaborative", 1), ("structured", 1), ("wild", 2)]
|
||||
|
||||
|
||||
def test_filter_is_case_insensitive(lib):
|
||||
rows = brain.filter_cats(brain.load(lib), ["WILD"])
|
||||
assert {r["technique_name"] for r in rows} == {"Quantum Superposition", "Anti-Solution"}
|
||||
|
||||
|
||||
def test_filter_none_returns_all(lib):
|
||||
assert len(brain.filter_cats(brain.load(lib), None)) == 4
|
||||
|
||||
|
||||
def test_find_hits_and_misses(lib):
|
||||
found, missing = brain.find(brain.load(lib), ["scamper method", "Nope"])
|
||||
assert [r["technique_name"] for r in found] == ["SCAMPER Method"]
|
||||
assert missing == ["Nope"]
|
||||
|
||||
|
||||
def test_resolve_detail_present(lib):
|
||||
row = next(r for r in brain.load(lib) if r["detail"])
|
||||
assert "multi-step instructions" in brain.resolve_detail(row, lib.parent)
|
||||
|
||||
|
||||
def test_resolve_detail_absent_is_none(lib):
|
||||
row = next(r for r in brain.load(lib) if not r["detail"])
|
||||
assert brain.resolve_detail(row, lib.parent) is None
|
||||
|
||||
|
||||
def test_resolve_detail_missing_file_warns_not_fatal(lib, capsys):
|
||||
rows = brain.load(lib)
|
||||
rows[1]["detail"] = "techniques/gone.md"
|
||||
assert brain.resolve_detail(rows[1], lib.parent) is None
|
||||
assert "not found" in capsys.readouterr().err
|
||||
|
||||
|
||||
def test_show_inlines_detail(lib, capsys):
|
||||
assert brain.main(["--file", str(lib), "show", "Quantum Superposition"]) == 0
|
||||
out = capsys.readouterr().out
|
||||
assert "multi-step instructions" in out and "[wild]" in out
|
||||
|
||||
|
||||
def test_show_simple_has_no_detail(lib, capsys):
|
||||
brain.main(["--file", str(lib), "show", "SCAMPER Method"])
|
||||
out = capsys.readouterr().out
|
||||
assert "transformation lenses" in out
|
||||
|
||||
|
||||
def test_show_all_missing_returns_1(lib):
|
||||
assert brain.main(["--file", str(lib), "show", "Ghost"]) == 1
|
||||
|
||||
|
||||
def test_list_filtered_text(lib, capsys):
|
||||
brain.main(["--file", str(lib), "list", "--category", "structured"])
|
||||
out = capsys.readouterr().out.strip().splitlines()
|
||||
assert len(out) == 1 and out[0].startswith("structured\tSCAMPER Method\t")
|
||||
|
||||
|
||||
def test_list_bare_is_refused(lib, capsys):
|
||||
# the footgun: bare `list` must NOT dump the catalog into context
|
||||
assert brain.main(["--file", str(lib), "list"]) == 2
|
||||
captured = capsys.readouterr()
|
||||
assert captured.out == "" # nothing leaked to stdout
|
||||
assert "--category" in captured.err and "--all" in captured.err
|
||||
|
||||
|
||||
def test_list_all_dumps_everything(lib, capsys):
|
||||
assert brain.main(["--file", str(lib), "list", "--all"]) == 0
|
||||
out = capsys.readouterr().out.strip().splitlines()
|
||||
assert len(out) == 4 # the deliberate full-catalog escape hatch
|
||||
|
||||
|
||||
def test_json_output(lib, capsys):
|
||||
import json
|
||||
brain.main(["--file", str(lib), "--json", "categories"])
|
||||
data = json.loads(capsys.readouterr().out)
|
||||
assert {"category": "wild", "count": 2} in data
|
||||
|
||||
|
||||
def test_random_respects_n_and_category(lib, capsys):
|
||||
brain.main(["--file", str(lib), "random", "--category", "wild", "-n", "5"])
|
||||
lines = capsys.readouterr().out.strip().splitlines()
|
||||
assert len(lines) == 2 # only 2 wild exist, n capped
|
||||
assert all(line.startswith("wild\t") for line in lines)
|
||||
|
||||
|
||||
def test_random_negative_n_does_not_crash(lib, capsys):
|
||||
# a negative -n is clamped to 0, not passed to random.sample (which would raise)
|
||||
assert brain.main(["--file", str(lib), "random", "-n", "-1"]) == 0
|
||||
assert capsys.readouterr().out.strip() == ""
|
||||
|
||||
|
||||
def test_missing_file_returns_2(tmp_path):
|
||||
assert brain.main(["--file", str(tmp_path / "nope.csv"), "categories"]) == 2
|
||||
|
||||
|
||||
# --- html selection page ------------------------------------------------
|
||||
|
||||
def test_html_requires_out(lib, capsys):
|
||||
# never dump the catalog to stdout — writing to a file is the whole point
|
||||
assert brain.main(["--file", str(lib), "html"]) == 2
|
||||
assert "--out" in capsys.readouterr().err
|
||||
|
||||
|
||||
def test_html_writes_selection_page(lib, tmp_path):
|
||||
out = tmp_path / "sel.html"
|
||||
assert brain.main(["--file", str(lib), "html", "--out", str(out)]) == 0
|
||||
doc = out.read_text(encoding="utf-8")
|
||||
assert doc.startswith("<!DOCTYPE html>")
|
||||
assert "BMad Method Brainstorming Selection" in doc
|
||||
for r in brain.load(lib):
|
||||
assert r["technique_name"] in doc # every technique is selectable
|
||||
assert ""yes and"" in doc # quotes in a description are escaped, not raw
|
||||
|
||||
|
||||
def test_html_creates_missing_parent(lib, tmp_path):
|
||||
out = tmp_path / "nested" / "deep" / "sel.html"
|
||||
assert brain.main(["--file", str(lib), "html", "--out", str(out)]) == 0
|
||||
assert out.is_file()
|
||||
|
||||
|
||||
# --- --extra overlay (customize.toml additional_techniques) -------------
|
||||
|
||||
EXTRA = (
|
||||
'[{"category": "domain-specific", "technique_name": "Regulatory Inversion", '
|
||||
'"description": "Start from the compliance constraint and brainstorm what it unlocks."}, '
|
||||
'{"category": "wild", "technique_name": "Extra Wild One", "description": "An added wild method."}]'
|
||||
)
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def extra(tmp_path):
|
||||
p = tmp_path / "extra.json"
|
||||
p.write_text(EXTRA, encoding="utf-8")
|
||||
return p
|
||||
|
||||
|
||||
def test_extra_merges_into_categories(lib, extra, capsys):
|
||||
brain.main(["--file", str(lib), "--extra", str(extra), "categories"])
|
||||
out = capsys.readouterr().out
|
||||
assert "domain-specific\t1" in out # a brand-new category appears
|
||||
assert "wild\t3" in out # the extra wild one is counted alongside the shipped two
|
||||
|
||||
|
||||
def test_extra_appears_in_list_and_random(lib, extra, capsys):
|
||||
brain.main(["--file", str(lib), "--extra", str(extra), "list", "--category", "domain-specific"])
|
||||
assert "Regulatory Inversion" in capsys.readouterr().out
|
||||
|
||||
|
||||
def test_extra_is_first_class_in_html(lib, extra, tmp_path):
|
||||
out = tmp_path / "sel.html"
|
||||
assert brain.main(["--file", str(lib), "--extra", str(extra), "html", "--out", str(out)]) == 0
|
||||
doc = out.read_text(encoding="utf-8")
|
||||
# custom technique is selectable and its new category renders without crashing (fallback glyph/hue)
|
||||
assert "Regulatory Inversion" in doc
|
||||
assert "Domain Specific" in doc
|
||||
|
||||
|
||||
def test_extra_missing_file_returns_2(lib, tmp_path):
|
||||
assert brain.main(["--file", str(lib), "--extra", str(tmp_path / "nope.json"), "categories"]) == 2
|
||||
|
||||
|
||||
def test_unknown_category_style_uses_fallback_glyph():
|
||||
hue, glyph = brain.category_style("totally-made-up-category")
|
||||
assert hue.startswith("#") and len(hue) == 7 # valid derived hex
|
||||
assert glyph == brain._FALLBACK_GLYPH
|
||||
|
||||
|
||||
def test_shipped_selector_is_in_sync_with_catalog():
|
||||
# foolproofing: if someone edits brain-methods.csv they must regenerate the page.
|
||||
# Regenerate with: python3 brain.py html --out assets/brain-selector.html
|
||||
asset = brain.DEFAULT_FILE.parent / "brain-selector.html"
|
||||
assert asset.is_file(), "missing assets/brain-selector.html — generate it"
|
||||
expected = brain.html_doc(brain.load(brain.DEFAULT_FILE))
|
||||
assert asset.read_text(encoding="utf-8") == expected, (
|
||||
"assets/brain-selector.html is stale; regenerate: "
|
||||
"python3 brain.py html --out assets/brain-selector.html"
|
||||
)
|
||||
|
|
@ -0,0 +1,265 @@
|
|||
# /// script
|
||||
# requires-python = ">=3.10"
|
||||
# dependencies = ["pytest>=8.0"]
|
||||
# ///
|
||||
"""Tests for memlog.py. Run: uv run --with pytest pytest scripts/tests/test_memlog.py
|
||||
|
||||
The spine under test is the flat, append-only, chronological invariant: every entry is
|
||||
one line recorded at the end in the order it happened — no sections, no grouping.
|
||||
"""
|
||||
import json
|
||||
import sys
|
||||
from pathlib import Path
|
||||
|
||||
import pytest
|
||||
|
||||
sys.path.insert(0, str(Path(__file__).resolve().parent.parent))
|
||||
import memlog # noqa: E402
|
||||
|
||||
MEMLOG = ".memlog.md"
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def ws(tmp_path):
|
||||
return str(tmp_path)
|
||||
|
||||
|
||||
def read(ws):
|
||||
return (Path(ws) / MEMLOG).read_text(encoding="utf-8")
|
||||
|
||||
|
||||
def body_of(ws):
|
||||
return memlog.split(read(ws))[1]
|
||||
|
||||
|
||||
def entries(ws):
|
||||
return [ln for ln in body_of(ws).splitlines() if ln.startswith("- ")]
|
||||
|
||||
|
||||
def init(ws, **fields):
|
||||
fields = fields or {"topic": "Reinvent the lunchbox", "goal": "ideas for a pitch"}
|
||||
argv = ["init", "--workspace", ws]
|
||||
for k, v in fields.items():
|
||||
argv += ["--field", f"{k}={v}"]
|
||||
assert memlog.main(argv) == 0
|
||||
|
||||
|
||||
def append(ws, text, entry_type=None, by=None):
|
||||
argv = ["append", "--workspace", ws, "--text", text]
|
||||
if entry_type:
|
||||
argv += ["--type", entry_type]
|
||||
if by:
|
||||
argv += ["--by", by]
|
||||
assert memlog.main(argv) == 0
|
||||
|
||||
|
||||
# --- init ---------------------------------------------------------------
|
||||
|
||||
def test_init_writes_frontmatter_fields(ws):
|
||||
init(ws)
|
||||
meta, body = memlog.split(read(ws))
|
||||
assert meta["topic"] == "Reinvent the lunchbox"
|
||||
assert meta["goal"] == "ideas for a pitch"
|
||||
assert meta["status"] == "active"
|
||||
assert "updated" in meta
|
||||
assert body.strip() == ""
|
||||
|
||||
|
||||
def test_init_arbitrary_fields(ws):
|
||||
init(ws, topic="T", audience="board")
|
||||
meta, _ = memlog.split(read(ws))
|
||||
assert meta["audience"] == "board"
|
||||
|
||||
|
||||
def test_init_refuses_overwrite(ws):
|
||||
init(ws)
|
||||
assert memlog.main(["init", "--workspace", ws, "--field", "topic=other"]) == 2
|
||||
|
||||
|
||||
def test_init_creates_missing_workspace(tmp_path):
|
||||
nested = str(tmp_path / "a" / "b")
|
||||
assert memlog.main(["init", "--workspace", nested, "--field", "topic=T"]) == 0
|
||||
assert (Path(nested) / MEMLOG).is_file()
|
||||
|
||||
|
||||
def test_init_rejects_malformed_field(ws):
|
||||
assert memlog.main(["init", "--workspace", ws, "--field", "noequals"]) == 2
|
||||
|
||||
|
||||
# --- append: flat chronological order is the whole point -----------------
|
||||
|
||||
def test_append_lands_at_end_in_order(ws):
|
||||
init(ws)
|
||||
append(ws, "first")
|
||||
append(ws, "second")
|
||||
append(ws, "third")
|
||||
assert entries(ws) == ["- first", "- second", "- third"]
|
||||
|
||||
|
||||
def test_no_sections_or_headings_ever(ws):
|
||||
init(ws)
|
||||
append(ws, "started foo", entry_type="technique")
|
||||
append(ws, "an idea", entry_type="idea")
|
||||
append(ws, "started bar", entry_type="technique")
|
||||
assert "## " not in body_of(ws) # the flat log never grows headings
|
||||
|
||||
|
||||
def test_type_renders_as_inline_tag(ws):
|
||||
init(ws)
|
||||
append(ws, "the earth revolves around the sun", entry_type="idea")
|
||||
append(ws, "how do we handle stampede?", entry_type="question")
|
||||
body = body_of(ws)
|
||||
assert "- (idea) the earth revolves around the sun" in body
|
||||
assert "- (question) how do we handle stampede?" in body
|
||||
|
||||
|
||||
def test_append_without_type_is_plain_note(ws):
|
||||
init(ws)
|
||||
append(ws, "bare entry")
|
||||
assert entries(ws) == ["- bare entry"]
|
||||
|
||||
|
||||
def test_append_collapses_newlines_into_one_line(ws):
|
||||
init(ws)
|
||||
append(ws, "line one\nline two\n spaced out")
|
||||
assert entries(ws) == ["- line one line two spaced out"]
|
||||
|
||||
|
||||
def test_revisited_technique_is_just_a_later_entry(ws):
|
||||
# the user's model: switching techniques is an entry, not a section to return to
|
||||
init(ws)
|
||||
append(ws, "started SCAMPER", entry_type="technique")
|
||||
append(ws, "magnetic latch", entry_type="idea")
|
||||
append(ws, "started Six Hats", entry_type="technique")
|
||||
append(ws, "stale data risk", entry_type="idea")
|
||||
append(ws, "started SCAMPER", entry_type="technique") # back to SCAMPER — just appended again
|
||||
append(ws, "stackable tiers", entry_type="idea")
|
||||
assert entries(ws) == [
|
||||
"- (technique) started SCAMPER",
|
||||
"- (idea) magnetic latch",
|
||||
"- (technique) started Six Hats",
|
||||
"- (idea) stale data risk",
|
||||
"- (technique) started SCAMPER",
|
||||
"- (idea) stackable tiers",
|
||||
]
|
||||
|
||||
|
||||
def test_by_renders_attribution_in_tag(ws):
|
||||
# Creative Partner mode must record whose idea each one was
|
||||
init(ws)
|
||||
append(ws, "magnetic latch lid", entry_type="idea", by="user")
|
||||
append(ws, "lid doubles as a plate", entry_type="idea", by="coach")
|
||||
body = body_of(ws)
|
||||
assert "- (idea by user) magnetic latch lid" in body
|
||||
assert "- (idea by coach) lid doubles as a plate" in body
|
||||
|
||||
|
||||
def test_by_without_type_renders_alone(ws):
|
||||
init(ws)
|
||||
append(ws, "off-the-cuff thought", by="coach")
|
||||
assert entries(ws) == ["- (by coach) off-the-cuff thought"]
|
||||
|
||||
|
||||
def test_heterogeneous_entry_types_coexist(ws):
|
||||
init(ws)
|
||||
append(ws, "an idea", entry_type="idea")
|
||||
append(ws, "an open question", entry_type="question")
|
||||
append(ws, "a decision we made", entry_type="decision")
|
||||
append(ws, "user wants mobile-first", entry_type="direction")
|
||||
body = body_of(ws)
|
||||
for tag in ("(idea)", "(question)", "(decision)", "(direction)"):
|
||||
assert tag in body
|
||||
|
||||
|
||||
# --- set ----------------------------------------------------------------
|
||||
|
||||
def test_set_flips_status(ws):
|
||||
init(ws)
|
||||
memlog.main(["set", "--workspace", ws, "--key", "status", "--value", "complete"])
|
||||
assert memlog.split(read(ws))[0]["status"] == "complete"
|
||||
|
||||
|
||||
def test_set_preserves_body(ws):
|
||||
init(ws)
|
||||
append(ws, "keep me", entry_type="idea")
|
||||
memlog.main(["set", "--workspace", ws, "--key", "status", "--value", "complete"])
|
||||
meta, body = memlog.split(read(ws))
|
||||
assert meta["status"] == "complete"
|
||||
assert "- (idea) keep me" in body
|
||||
|
||||
|
||||
def test_set_can_add_new_field(ws):
|
||||
init(ws)
|
||||
memlog.main(["set", "--workspace", ws, "--key", "owner", "--value", "BMad"])
|
||||
assert memlog.split(read(ws))[0]["owner"] == "BMad"
|
||||
|
||||
|
||||
def test_updated_stays_last(ws):
|
||||
init(ws)
|
||||
memlog.main(["set", "--workspace", ws, "--key", "owner", "--value", "BMad"])
|
||||
meta = memlog.split(read(ws))[0]
|
||||
assert list(meta)[-1] == "updated"
|
||||
|
||||
|
||||
# --- robustness ---------------------------------------------------------
|
||||
|
||||
def test_roundtrip_render_is_stable(ws):
|
||||
init(ws)
|
||||
append(ws, "one", entry_type="idea")
|
||||
first = read(ws)
|
||||
meta, body = memlog.split(first)
|
||||
assert memlog.render(meta, body) == first
|
||||
|
||||
|
||||
def test_commas_in_field_survive(ws):
|
||||
init(ws, topic="cars, trains, and planes")
|
||||
append(ws, "z", entry_type="idea")
|
||||
meta, _ = memlog.split(read(ws))
|
||||
assert meta["topic"] == "cars, trains, and planes"
|
||||
|
||||
|
||||
def test_triple_dash_in_field_does_not_corrupt_frontmatter(ws):
|
||||
# A `---` inside a value must NOT be read as the closing fence: topic stays intact,
|
||||
# status survives, and the body never leaks frontmatter text.
|
||||
init(ws, topic="Pricing --- tiers --- and add-ons")
|
||||
append(ws, "an idea", entry_type="idea")
|
||||
meta, body = memlog.split(read(ws))
|
||||
assert meta["topic"] == "Pricing --- tiers --- and add-ons"
|
||||
assert meta["status"] == "active"
|
||||
assert entries(ws) == ["- (idea) an idea"]
|
||||
assert "status:" not in body # frontmatter never bled into the body
|
||||
|
||||
|
||||
def test_triple_dash_status_survives_in_ack(ws, capsys):
|
||||
init(ws, topic="a --- b")
|
||||
append(ws, "x", entry_type="idea")
|
||||
out = json.loads(capsys.readouterr().out.strip().splitlines()[-1])
|
||||
assert out["status"] == "active" # not "" — frontmatter recovered cleanly
|
||||
|
||||
|
||||
def test_newline_in_field_is_neutralized(ws):
|
||||
# A value carrying a newline can't break the fence on the next round-trip.
|
||||
memlog.main(["init", "--workspace", ws, "--field", "topic=line one\nline two"])
|
||||
append(ws, "x", entry_type="idea")
|
||||
meta, _ = memlog.split(read(ws))
|
||||
assert "\n" not in meta["topic"]
|
||||
assert meta["status"] == "active"
|
||||
|
||||
|
||||
def test_append_emits_json_ack(ws, capsys):
|
||||
init(ws)
|
||||
append(ws, "x", entry_type="idea")
|
||||
out = json.loads(capsys.readouterr().out.strip().splitlines()[-1])
|
||||
assert out["ok"] is True
|
||||
assert out["status"] == "active"
|
||||
assert out["entries"] == 1
|
||||
assert out["memlog"].endswith(MEMLOG)
|
||||
assert "section" not in out # sections are gone
|
||||
|
||||
|
||||
def test_ack_entry_count_climbs(ws, capsys):
|
||||
init(ws)
|
||||
append(ws, "a")
|
||||
append(ws, "b")
|
||||
out = json.loads(capsys.readouterr().out.strip().splitlines()[-1])
|
||||
assert out["entries"] == 2
|
||||
|
|
@ -1,214 +0,0 @@
|
|||
# Step 1: Session Setup and Continuation Detection
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- 🛑 NEVER generate content without user input
|
||||
- ✅ ALWAYS treat this as collaborative facilitation
|
||||
- 📋 YOU ARE A FACILITATOR, not a content generator
|
||||
- 💬 FOCUS on session setup and continuation detection only
|
||||
- 🚪 DETECT existing workflow state and handle continuation properly
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Show your analysis before taking any action
|
||||
- 💾 Initialize document and update frontmatter
|
||||
- 📖 Set up frontmatter `stepsCompleted: [1]` before loading next step
|
||||
- 🚫 FORBIDDEN to load next step until setup is complete
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- Variables from workflow.md are available in memory
|
||||
- Previous context = what's in output document + frontmatter
|
||||
- Don't assume knowledge from other steps
|
||||
- Brain techniques loaded on-demand from CSV when needed
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Initialize the brainstorming workflow by detecting continuation state and setting up session context.
|
||||
|
||||
## INITIALIZATION SEQUENCE:
|
||||
|
||||
### 1. Check for Existing Sessions
|
||||
|
||||
First, check the brainstorming sessions folder for existing sessions:
|
||||
|
||||
- List all files in `{output_folder}/brainstorming/`
|
||||
- **DO NOT read any file contents** - only list filenames
|
||||
- If files exist, identify the most recent by date/time in the filename
|
||||
- If no files exist, this is a fresh workflow
|
||||
|
||||
### 2. Handle Existing Sessions (If Files Found)
|
||||
|
||||
If existing session files are found:
|
||||
|
||||
- Display the most recent session filename (do NOT read its content)
|
||||
- Ask the user: "Found existing session: `[filename]`. Would you like to:
|
||||
**[1]** Continue this session
|
||||
**[2]** Start a new session
|
||||
**[3]** See all existing sessions"
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
- If user selects **[1]** (continue): Set `{brainstorming_session_output_file}` to that file path and load `./step-01b-continue.md`
|
||||
- If user selects **[2]** (new): Generate new filename with current date/time and proceed to step 3
|
||||
- If user selects **[3]** (see all): List all session filenames and ask which to continue or if new
|
||||
|
||||
### 3. Fresh Workflow Setup (If No Files or User Chooses New)
|
||||
|
||||
If no document exists or no `stepsCompleted` in frontmatter:
|
||||
|
||||
#### A. Initialize Document
|
||||
|
||||
Create the brainstorming session document:
|
||||
|
||||
```bash
|
||||
# Create directory if needed
|
||||
mkdir -p "$(dirname "{brainstorming_session_output_file}")"
|
||||
|
||||
# Initialize from template
|
||||
cp "../template.md" "{brainstorming_session_output_file}"
|
||||
```
|
||||
|
||||
#### B. Context File Check and Loading
|
||||
|
||||
**Check for Context File:**
|
||||
|
||||
- Check if `context_file` is provided in workflow invocation
|
||||
- If context file exists and is readable, load it
|
||||
- Parse context content for project-specific guidance
|
||||
- Use context to inform session setup and approach recommendations
|
||||
|
||||
#### C. Session Context Gathering
|
||||
|
||||
"Welcome {{user_name}}! I'm excited to facilitate your brainstorming session. I'll guide you through proven creativity techniques to generate innovative ideas and breakthrough solutions.
|
||||
|
||||
**Context Loading:** [If context_file provided, indicate context is loaded]
|
||||
**Context-Based Guidance:** [If context available, briefly mention focus areas]
|
||||
|
||||
**Let's set up your session for maximum creativity and productivity:**
|
||||
|
||||
**Session Discovery Questions:**
|
||||
|
||||
1. **What are we brainstorming about?** (The central topic or challenge)
|
||||
2. **What specific outcomes are you hoping for?** (Types of ideas, solutions, or insights)"
|
||||
|
||||
#### D. Process User Responses
|
||||
|
||||
Wait for user responses, then:
|
||||
|
||||
**Session Analysis:**
|
||||
"Based on your responses, I understand we're focusing on **[summarized topic]** with goals around **[summarized objectives]**.
|
||||
|
||||
**Session Parameters:**
|
||||
|
||||
- **Topic Focus:** [Clear topic articulation]
|
||||
- **Primary Goals:** [Specific outcome objectives]
|
||||
|
||||
**Does this accurately capture what you want to achieve?**"
|
||||
|
||||
#### E. Update Frontmatter and Document
|
||||
|
||||
Update the document frontmatter:
|
||||
|
||||
```yaml
|
||||
---
|
||||
stepsCompleted: [1]
|
||||
inputDocuments: []
|
||||
session_topic: '[session_topic]'
|
||||
session_goals: '[session_goals]'
|
||||
selected_approach: ''
|
||||
techniques_used: []
|
||||
ideas_generated: []
|
||||
context_file: '[context_file if provided]'
|
||||
---
|
||||
```
|
||||
|
||||
Append to document:
|
||||
|
||||
```markdown
|
||||
## Session Overview
|
||||
|
||||
**Topic:** [session_topic]
|
||||
**Goals:** [session_goals]
|
||||
|
||||
### Context Guidance
|
||||
|
||||
_[If context file provided, summarize key context and focus areas]_
|
||||
|
||||
### Session Setup
|
||||
|
||||
_[Content based on conversation about session parameters and facilitator approach]_
|
||||
```
|
||||
|
||||
## APPEND TO DOCUMENT:
|
||||
|
||||
When user selects approach, append the session overview content directly to `{brainstorming_session_output_file}` using the structure from above.
|
||||
|
||||
### E. Continue to Technique Selection
|
||||
|
||||
"**Session setup complete!** I have a clear understanding of your goals and can select the perfect techniques for your brainstorming needs.
|
||||
|
||||
**Ready to explore technique approaches?**
|
||||
[1] User-Selected Techniques - Browse our complete technique library
|
||||
[2] AI-Recommended Techniques - Get customized suggestions based on your goals
|
||||
[3] Random Technique Selection - Discover unexpected creative methods
|
||||
[4] Progressive Technique Flow - Start broad, then systematically narrow focus
|
||||
|
||||
Which approach appeals to you most? (Enter 1-4)"
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
### 4. Handle User Selection and Initial Document Append
|
||||
|
||||
#### When user selects approach number:
|
||||
|
||||
- **Append initial session overview to `{brainstorming_session_output_file}`**
|
||||
- **Update frontmatter:** `stepsCompleted: [1]`, `selected_approach: '[selected approach]'`
|
||||
- **Load the appropriate step-02 file** based on selection
|
||||
|
||||
### 5. Handle User Selection
|
||||
|
||||
After user selects approach number:
|
||||
|
||||
- **If 1:** Load `./step-02a-user-selected.md`
|
||||
- **If 2:** Load `./step-02b-ai-recommended.md`
|
||||
- **If 3:** Load `./step-02c-random-selection.md`
|
||||
- **If 4:** Load `./step-02d-progressive-flow.md`
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ Existing sessions detected without reading file contents
|
||||
✅ User prompted to continue existing session or start new
|
||||
✅ Correct session file selected for continuation
|
||||
✅ Fresh workflow initialized with correct document structure
|
||||
✅ Session context gathered and understood clearly
|
||||
✅ User's approach selection captured and routed correctly
|
||||
✅ Frontmatter properly updated with session state
|
||||
✅ Document initialized with session overview section
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Reading file contents during session detection (wastes context)
|
||||
❌ Not asking user before continuing existing session
|
||||
❌ Not properly routing user's continue/new session selection
|
||||
❌ Missing continuation detection leading to duplicate work
|
||||
❌ Insufficient session context gathering
|
||||
❌ Not properly routing user's approach selection
|
||||
❌ Frontmatter not updated with session parameters
|
||||
|
||||
## SESSION SETUP PROTOCOLS:
|
||||
|
||||
- Always list sessions folder WITHOUT reading file contents
|
||||
- Ask user before continuing any existing session
|
||||
- Only load continue step after user confirms
|
||||
- Load brain techniques CSV only when needed for technique presentation
|
||||
- Use collaborative facilitation language throughout
|
||||
- Maintain psychological safety for creative exploration
|
||||
- Clear next-step routing based on user preferences
|
||||
|
||||
## NEXT STEPS:
|
||||
|
||||
Based on user's approach selection, load the appropriate step-02 file for technique selection and facilitation.
|
||||
|
||||
Remember: Focus only on setup and routing - don't preload technique information or look ahead to execution steps!
|
||||
|
|
@ -1,124 +0,0 @@
|
|||
# Step 1b: Workflow Continuation
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- ✅ YOU ARE A CONTINUATION FACILITATOR, not a fresh starter
|
||||
- 🎯 RESPECT EXISTING WORKFLOW state and progress
|
||||
- 📋 UNDERSTAND PREVIOUS SESSION context and outcomes
|
||||
- 🔍 SEAMLESSLY RESUME from where user left off
|
||||
- 💬 MAINTAIN CONTINUITY in session flow and rapport
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Load and analyze existing document thoroughly
|
||||
- 💾 Update frontmatter with continuation state
|
||||
- 📖 Present current status and next options clearly
|
||||
- 🚫 FORBIDDEN repeating completed work or asking same questions
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- Existing document with frontmatter is available
|
||||
- Previous steps completed indicate session progress
|
||||
- Brain techniques CSV loaded when needed for remaining steps
|
||||
- User may want to continue, modify, or restart
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Analyze existing brainstorming session state and provide seamless continuation options.
|
||||
|
||||
## CONTINUATION SEQUENCE:
|
||||
|
||||
### 1. Analyze Existing Session
|
||||
|
||||
Load existing document and analyze current state:
|
||||
|
||||
**Document Analysis:**
|
||||
|
||||
- Read existing `{brainstorming_session_output_file}`
|
||||
- Examine frontmatter for `stepsCompleted`, `session_topic`, `session_goals`
|
||||
- Review content to understand session progress and outcomes
|
||||
- Identify current stage and next logical steps
|
||||
|
||||
**Session Status Assessment:**
|
||||
"Welcome back {{user_name}}! I can see your brainstorming session on **[session_topic]** from **[date]**.
|
||||
|
||||
**Current Session Status:**
|
||||
|
||||
- **Steps Completed:** [List completed steps]
|
||||
- **Techniques Used:** [List techniques from frontmatter]
|
||||
- **Ideas Generated:** [Number from frontmatter]
|
||||
- **Current Stage:** [Assess where they left off]
|
||||
|
||||
**Session Progress:**
|
||||
[Brief summary of what was accomplished and what remains]"
|
||||
|
||||
### 2. Present Continuation Options
|
||||
|
||||
Based on session analysis, provide appropriate options:
|
||||
|
||||
**If Session Completed:**
|
||||
"Your brainstorming session appears to be complete!
|
||||
|
||||
**Options:**
|
||||
[1] Review Results - Go through your documented ideas and insights
|
||||
[2] Start New Session - Begin brainstorming on a new topic
|
||||
[3] Extend Session - Add more techniques or explore new angles"
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
**If Session In Progress:**
|
||||
"Let's continue where we left off!
|
||||
|
||||
**Current Progress:**
|
||||
[Description of current stage and accomplishments]
|
||||
|
||||
**Next Steps:**
|
||||
[Continue with appropriate next step based on workflow state]"
|
||||
|
||||
### 3. Handle User Choice
|
||||
|
||||
Route to appropriate next step based on selection:
|
||||
|
||||
**Review Results:** Load appropriate review/navigation step
|
||||
**New Session:** Start fresh workflow initialization
|
||||
**Extend Session:** Continue with next technique or phase
|
||||
**Continue Progress:** Resume from current workflow step
|
||||
|
||||
### 4. Update Session State
|
||||
|
||||
Update frontmatter to reflect continuation:
|
||||
|
||||
```yaml
|
||||
---
|
||||
stepsCompleted: [existing_steps]
|
||||
session_continued: true
|
||||
continuation_date: { { current_date } }
|
||||
---
|
||||
```
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ Existing session state accurately analyzed and understood
|
||||
✅ Seamless continuation without loss of context or rapport
|
||||
✅ Appropriate continuation options presented based on progress
|
||||
✅ User choice properly routed to next workflow step
|
||||
✅ Session continuity maintained throughout interaction
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Not properly analyzing existing document state
|
||||
❌ Asking user to repeat information already provided
|
||||
❌ Losing continuity in session flow or context
|
||||
❌ Not providing appropriate continuation options
|
||||
|
||||
## CONTINUATION PROTOCOLS:
|
||||
|
||||
- Always acknowledge previous work and progress
|
||||
- Maintain established rapport and session dynamics
|
||||
- Build upon existing ideas and insights rather than starting over
|
||||
- Respect user's time by avoiding repetitive questions
|
||||
|
||||
## NEXT STEP:
|
||||
|
||||
Route to appropriate workflow step based on user's continuation choice and current session state.
|
||||
|
|
@ -1,229 +0,0 @@
|
|||
# Step 2a: User-Selected Techniques
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- ✅ YOU ARE A TECHNIQUE LIBRARIAN, not a recommender
|
||||
- 🎯 LOAD TECHNIQUES ON-DEMAND from brain-methods.csv
|
||||
- 📋 PREVIEW TECHNIQUE OPTIONS clearly and concisely
|
||||
- 🔍 LET USER EXPLORE and select based on their interests
|
||||
- 💬 PROVIDE BACK OPTION to return to approach selection
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Load brain techniques CSV only when needed for presentation
|
||||
- ⚠️ Present [B] back option and [C] continue options
|
||||
- 💾 Update frontmatter with selected techniques
|
||||
- 📖 Route to technique execution after confirmation
|
||||
- 🚫 FORBIDDEN making recommendations or steering choices
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- Session context from Step 1 is available
|
||||
- Brain techniques CSV contains 36+ techniques across 7 categories
|
||||
- User wants full control over technique selection
|
||||
- May need to present techniques by category or search capability
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Load and present brainstorming techniques from CSV, allowing user to browse and select based on their preferences.
|
||||
|
||||
## USER SELECTION SEQUENCE:
|
||||
|
||||
### 1. Load Brain Techniques Library
|
||||
|
||||
Load techniques from CSV on-demand:
|
||||
|
||||
"Perfect! Let's explore our complete brainstorming techniques library. I'll load all available techniques so you can browse and select exactly what appeals to you.
|
||||
|
||||
**Loading Brain Techniques Library...**"
|
||||
|
||||
**Load CSV and parse:**
|
||||
|
||||
- Read `../brain-methods.csv`
|
||||
- Parse: category, technique_name, description, facilitation_prompts, best_for, energy_level, typical_duration
|
||||
- Organize by categories for browsing
|
||||
|
||||
### 2. Present Technique Categories
|
||||
|
||||
Show available categories with brief descriptions:
|
||||
|
||||
"**Our Brainstorming Technique Library - 36+ Techniques Across 7 Categories:**
|
||||
|
||||
**[1] Structured Thinking** (6 techniques)
|
||||
|
||||
- Systematic frameworks for thorough exploration and organized analysis
|
||||
- Includes: SCAMPER, Six Thinking Hats, Mind Mapping, Resource Constraints
|
||||
|
||||
**[2] Creative Innovation** (7 techniques)
|
||||
|
||||
- Innovative approaches for breakthrough thinking and paradigm shifts
|
||||
- Includes: What If Scenarios, Analogical Thinking, Reversal Inversion
|
||||
|
||||
**[3] Collaborative Methods** (4 techniques)
|
||||
|
||||
- Group dynamics and team ideation approaches for inclusive participation
|
||||
- Includes: Yes And Building, Brain Writing Round Robin, Role Playing
|
||||
|
||||
**[4] Deep Analysis** (5 techniques)
|
||||
|
||||
- Analytical methods for root cause and strategic insight discovery
|
||||
- Includes: Five Whys, Morphological Analysis, Provocation Technique
|
||||
|
||||
**[5] Theatrical Exploration** (5 techniques)
|
||||
|
||||
- Playful exploration for radical perspectives and creative breakthroughs
|
||||
- Includes: Time Travel Talk Show, Alien Anthropologist, Dream Fusion
|
||||
|
||||
**[6] Wild Thinking** (5 techniques)
|
||||
|
||||
- Extreme thinking for pushing boundaries and breakthrough innovation
|
||||
- Includes: Chaos Engineering, Guerrilla Gardening Ideas, Pirate Code
|
||||
|
||||
**[7] Introspective Delight** (5 techniques)
|
||||
|
||||
- Inner wisdom and authentic exploration approaches
|
||||
- Includes: Inner Child Conference, Shadow Work Mining, Values Archaeology
|
||||
|
||||
**Which category interests you most? Enter 1-7, or tell me what type of thinking you're drawn to.**"
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
### 3. Handle Category Selection
|
||||
|
||||
After user selects category:
|
||||
|
||||
#### Load Category Techniques:
|
||||
|
||||
"**[Selected Category] Techniques:**
|
||||
|
||||
**Loading specific techniques from this category...**"
|
||||
|
||||
**Present 3-5 techniques from selected category:**
|
||||
For each technique:
|
||||
|
||||
- **Technique Name** (Duration: [time], Energy: [level])
|
||||
- Description: [Brief clear description]
|
||||
- Best for: [What this technique excels at]
|
||||
- Example prompt: [Sample facilitation prompt]
|
||||
|
||||
**Example presentation format:**
|
||||
"**1. SCAMPER Method** (Duration: 20-30 min, Energy: Moderate)
|
||||
|
||||
- Systematic creativity through seven lenses (Substitute/Combine/Adapt/Modify/Put/Eliminate/Reverse)
|
||||
- Best for: Product improvement, innovation challenges, systematic idea generation
|
||||
- Example prompt: "What could you substitute in your current approach to create something new?"
|
||||
|
||||
**2. Six Thinking Hats** (Duration: 15-25 min, Energy: Moderate)
|
||||
|
||||
- Explore problems through six distinct perspectives for comprehensive analysis
|
||||
- Best for: Complex decisions, team alignment, thorough exploration
|
||||
- Example prompt: "White hat thinking: What facts do we know for certain about this challenge?"
|
||||
|
||||
### 4. Allow Technique Selection
|
||||
|
||||
"**Which techniques from this category appeal to you?**
|
||||
|
||||
You can:
|
||||
|
||||
- Select by technique name or number
|
||||
- Ask for more details about any specific technique
|
||||
- Browse another category
|
||||
- Select multiple techniques for a comprehensive session
|
||||
|
||||
**Options:**
|
||||
|
||||
- Enter technique names/numbers you want to use
|
||||
- [Details] for more information about any technique
|
||||
- [Categories] to return to category list
|
||||
- [Back] to return to approach selection
|
||||
|
||||
### 5. Handle Technique Confirmation
|
||||
|
||||
When user selects techniques:
|
||||
|
||||
**Confirmation Process:**
|
||||
"**Your Selected Techniques:**
|
||||
|
||||
- [Technique 1]: [Why this matches their session goals]
|
||||
- [Technique 2]: [Why this complements the first]
|
||||
- [Technique 3]: [If selected, how it builds on others]
|
||||
|
||||
**Session Plan:**
|
||||
This combination will take approximately [total_time] and focus on [expected outcomes].
|
||||
|
||||
**Confirm these choices?**
|
||||
[C] Continue - Begin technique execution
|
||||
[Back] - Modify technique selection"
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
### 6. Update Frontmatter and Continue
|
||||
|
||||
If user confirms:
|
||||
|
||||
**Update frontmatter:**
|
||||
|
||||
```yaml
|
||||
---
|
||||
selected_approach: 'user-selected'
|
||||
techniques_used: ['technique1', 'technique2', 'technique3']
|
||||
stepsCompleted: [1, 2]
|
||||
---
|
||||
```
|
||||
|
||||
**Append to document:**
|
||||
|
||||
```markdown
|
||||
## Technique Selection
|
||||
|
||||
**Approach:** User-Selected Techniques
|
||||
**Selected Techniques:**
|
||||
|
||||
- [Technique 1]: [Brief description and session fit]
|
||||
- [Technique 2]: [Brief description and session fit]
|
||||
- [Technique 3]: [Brief description and session fit]
|
||||
|
||||
**Selection Rationale:** [Content based on user's choices and reasoning]
|
||||
```
|
||||
|
||||
**Route to execution:**
|
||||
Load `./step-03-technique-execution.md`
|
||||
|
||||
### 7. Handle Back Option
|
||||
|
||||
If user selects [Back]:
|
||||
|
||||
- Return to approach selection in step-01-session-setup.md
|
||||
- Maintain session context and preferences
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ Brain techniques CSV loaded successfully on-demand
|
||||
✅ Technique categories presented clearly with helpful descriptions
|
||||
✅ User able to browse and select techniques based on interests
|
||||
✅ Selected techniques confirmed with session fit explanation
|
||||
✅ Frontmatter updated with technique selections
|
||||
✅ Proper routing to technique execution or back navigation
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Preloading all techniques instead of loading on-demand
|
||||
❌ Making recommendations instead of letting user explore
|
||||
❌ Not providing enough detail for informed selection
|
||||
❌ Missing back navigation option
|
||||
❌ Not updating frontmatter with technique selections
|
||||
|
||||
## USER SELECTION PROTOCOLS:
|
||||
|
||||
- Present techniques neutrally without steering or preference
|
||||
- Load CSV data only when needed for category/technique presentation
|
||||
- Provide sufficient detail for informed choices without overwhelming
|
||||
- Always maintain option to return to previous steps
|
||||
- Respect user's autonomy in technique selection
|
||||
|
||||
## NEXT STEP:
|
||||
|
||||
After technique confirmation, load `./step-03-technique-execution.md` to begin facilitating the selected brainstorming techniques.
|
||||
|
||||
Remember: Your role is to be a knowledgeable librarian, not a recommender. Let the user explore and choose based on their interests and intuition!
|
||||
|
|
@ -1,239 +0,0 @@
|
|||
# Step 2b: AI-Recommended Techniques
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- ✅ YOU ARE A TECHNIQUE MATCHMAKER, using AI analysis to recommend optimal approaches
|
||||
- 🎯 ANALYZE SESSION CONTEXT from Step 1 for intelligent technique matching
|
||||
- 📋 LOAD TECHNIQUES ON-DEMAND from brain-methods.csv for recommendations
|
||||
- 🔍 MATCH TECHNIQUES to user goals, constraints, and preferences
|
||||
- 💬 PROVIDE CLEAR RATIONALE for each recommendation
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Load brain techniques CSV only when needed for analysis
|
||||
- ⚠️ Present [B] back option and [C] continue options
|
||||
- 💾 Update frontmatter with recommended techniques
|
||||
- 📖 Route to technique execution after user confirmation
|
||||
- 🚫 FORBIDDEN generic recommendations without context analysis
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- Session context (`session_topic`, `session_goals`, constraints) from Step 1
|
||||
- Brain techniques CSV with 36+ techniques across 7 categories
|
||||
- User wants expert guidance in technique selection
|
||||
- Must analyze multiple factors for optimal matching
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Analyze session context and recommend optimal brainstorming techniques based on user's specific goals and constraints.
|
||||
|
||||
## AI RECOMMENDATION SEQUENCE:
|
||||
|
||||
### 1. Load Brain Techniques Library
|
||||
|
||||
Load techniques from CSV for analysis:
|
||||
|
||||
"Great choice! Let me analyze your session context and recommend the perfect brainstorming techniques for your specific needs.
|
||||
|
||||
**Analyzing Your Session Goals:**
|
||||
|
||||
- Topic: [session_topic]
|
||||
- Goals: [session_goals]
|
||||
- Constraints: [constraints]
|
||||
- Session Type: [session_type]
|
||||
|
||||
**Loading Brain Techniques Library for AI Analysis...**"
|
||||
|
||||
**Load CSV and parse:**
|
||||
|
||||
- Read `../brain-methods.csv`
|
||||
- Parse: category, technique_name, description, facilitation_prompts, best_for, energy_level, typical_duration
|
||||
|
||||
### 2. Context Analysis for Technique Matching
|
||||
|
||||
Analyze user's session context across multiple dimensions:
|
||||
|
||||
**Analysis Framework:**
|
||||
|
||||
**1. Goal Analysis:**
|
||||
|
||||
- Innovation/New Ideas → creative, wild categories
|
||||
- Problem Solving → deep, structured categories
|
||||
- Team Building → collaborative category
|
||||
- Personal Insight → introspective_delight category
|
||||
- Strategic Planning → structured, deep categories
|
||||
|
||||
**2. Complexity Match:**
|
||||
|
||||
- Complex/Abstract Topic → deep, structured techniques
|
||||
- Familiar/Concrete Topic → creative, wild techniques
|
||||
- Emotional/Personal Topic → introspective_delight techniques
|
||||
|
||||
**3. Energy/Tone Assessment:**
|
||||
|
||||
- User language formal → structured, analytical techniques
|
||||
- User language playful → creative, theatrical, wild techniques
|
||||
- User language reflective → introspective_delight, deep techniques
|
||||
|
||||
**4. Time Available:**
|
||||
|
||||
- <30 min → 1-2 focused techniques
|
||||
- 30-60 min → 2-3 complementary techniques
|
||||
- > 60 min → Multi-phase technique flow
|
||||
|
||||
### 3. Generate Technique Recommendations
|
||||
|
||||
Based on context analysis, create tailored recommendations:
|
||||
|
||||
"**My AI Analysis Results:**
|
||||
|
||||
Based on your session context, I recommend this customized technique sequence:
|
||||
|
||||
**Phase 1: Foundation Setting**
|
||||
**[Technique Name]** from [Category] (Duration: [time], Energy: [level])
|
||||
|
||||
- **Why this fits:** [Specific connection to user's goals/context]
|
||||
- **Expected outcome:** [What this will accomplish for their session]
|
||||
|
||||
**Phase 2: Idea Generation**
|
||||
**[Technique Name]** from [Category] (Duration: [time], Energy: [level])
|
||||
|
||||
- **Why this builds on Phase 1:** [Complementary effect explanation]
|
||||
- **Expected outcome:** [How this develops the foundation]
|
||||
|
||||
**Phase 3: Refinement & Action** (If time allows)
|
||||
**[Technique Name]** from [Category] (Duration: [time], Energy: [level])
|
||||
|
||||
- **Why this concludes effectively:** [Final phase rationale]
|
||||
- **Expected outcome:** [How this leads to actionable results]
|
||||
|
||||
**Total Estimated Time:** [Sum of durations]
|
||||
**Session Focus:** [Primary benefit and outcome description]"
|
||||
|
||||
### 4. Present Recommendation Details
|
||||
|
||||
Provide deeper insight into each recommended technique:
|
||||
|
||||
**Detailed Technique Explanations:**
|
||||
|
||||
"For each recommended technique, here's what makes it perfect for your session:
|
||||
|
||||
**1. [Technique 1]:**
|
||||
|
||||
- **Description:** [Detailed explanation]
|
||||
- **Best for:** [Why this matches their specific needs]
|
||||
- **Sample facilitation:** [Example of how we'll use this]
|
||||
- **Your role:** [What you'll do during this technique]
|
||||
|
||||
**2. [Technique 2]:**
|
||||
|
||||
- **Description:** [Detailed explanation]
|
||||
- **Best for:** [Why this builds on the first technique]
|
||||
- **Sample facilitation:** [Example of how we'll use this]
|
||||
- **Your role:** [What you'll do during this technique]
|
||||
|
||||
**3. [Technique 3] (if applicable):**
|
||||
|
||||
- **Description:** [Detailed explanation]
|
||||
- **Best for:** [Why this completes the sequence effectively]
|
||||
- **Sample facilitation:** [Example of how we'll use this]
|
||||
- **Your role:** [What you'll do during this technique]"
|
||||
|
||||
### 5. Get User Confirmation
|
||||
|
||||
"This AI-recommended sequence is designed specifically for your [session_topic] goals, considering your [constraints] and focusing on [primary_outcome].
|
||||
|
||||
**Does this approach sound perfect for your session?**
|
||||
|
||||
**Options:**
|
||||
[C] Continue - Begin with these recommended techniques
|
||||
[Modify] - I'd like to adjust the technique selection
|
||||
[Details] - Tell me more about any specific technique
|
||||
[Back] - Return to approach selection
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
### 6. Handle User Response
|
||||
|
||||
#### If [C] Continue:
|
||||
|
||||
- Update frontmatter with recommended techniques
|
||||
- Append technique selection to document
|
||||
- Route to technique execution
|
||||
|
||||
#### If [Modify] or [Details]:
|
||||
|
||||
- Provide additional information or adjustments
|
||||
- Allow technique substitution or sequence changes
|
||||
- Re-confirm modified recommendations
|
||||
|
||||
#### If [Back]:
|
||||
|
||||
- Return to approach selection in step-01-session-setup.md
|
||||
- Maintain session context and preferences
|
||||
|
||||
### 7. Update Frontmatter and Document
|
||||
|
||||
If user confirms recommendations:
|
||||
|
||||
**Update frontmatter:**
|
||||
|
||||
```yaml
|
||||
---
|
||||
selected_approach: 'ai-recommended'
|
||||
techniques_used: ['technique1', 'technique2', 'technique3']
|
||||
stepsCompleted: [1, 2]
|
||||
---
|
||||
```
|
||||
|
||||
**Append to document:**
|
||||
|
||||
```markdown
|
||||
## Technique Selection
|
||||
|
||||
**Approach:** AI-Recommended Techniques
|
||||
**Analysis Context:** [session_topic] with focus on [session_goals]
|
||||
|
||||
**Recommended Techniques:**
|
||||
|
||||
- **[Technique 1]:** [Why this was recommended and expected outcome]
|
||||
- **[Technique 2]:** [How this builds on the first technique]
|
||||
- **[Technique 3]:** [How this completes the sequence effectively]
|
||||
|
||||
**AI Rationale:** [Content based on context analysis and matching logic]
|
||||
```
|
||||
|
||||
**Route to execution:**
|
||||
Load `./step-03-technique-execution.md`
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ Session context analyzed thoroughly across multiple dimensions
|
||||
✅ Technique recommendations clearly matched to user's specific needs
|
||||
✅ Detailed explanations provided for each recommended technique
|
||||
✅ User confirmation obtained before proceeding to execution
|
||||
✅ Frontmatter updated with AI-recommended techniques
|
||||
✅ Proper routing to technique execution or back navigation
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Generic recommendations without specific context analysis
|
||||
❌ Not explaining rationale behind technique selections
|
||||
❌ Missing option for user to modify or question recommendations
|
||||
❌ Not loading techniques from CSV for accurate recommendations
|
||||
❌ Not updating frontmatter with selected techniques
|
||||
|
||||
## AI RECOMMENDATION PROTOCOLS:
|
||||
|
||||
- Analyze session context systematically across multiple factors
|
||||
- Provide clear rationale linking recommendations to user's goals
|
||||
- Allow user input and modification of recommendations
|
||||
- Load accurate technique data from CSV for informed analysis
|
||||
- Balance expertise with user autonomy in final selection
|
||||
|
||||
## NEXT STEP:
|
||||
|
||||
After user confirmation, load `./step-03-technique-execution.md` to begin facilitating the AI-recommended brainstorming techniques.
|
||||
|
||||
Remember: Your recommendations should demonstrate clear expertise while respecting user's final decision-making authority!
|
||||
|
|
@ -1,211 +0,0 @@
|
|||
# Step 2c: Random Technique Selection
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- ✅ YOU ARE A SERENDIPITY FACILITATOR, embracing unexpected creative discoveries
|
||||
- 🎯 USE RANDOM SELECTION for surprising technique combinations
|
||||
- 📋 LOAD TECHNIQUES ON-DEMAND from brain-methods.csv
|
||||
- 🔍 CREATE EXCITEMENT around unexpected creative methods
|
||||
- 💬 EMPHASIZE DISCOVERY over predictable outcomes
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Load brain techniques CSV only when needed for random selection
|
||||
- ⚠️ Present [B] back option and [C] continue options
|
||||
- 💾 Update frontmatter with randomly selected techniques
|
||||
- 📖 Route to technique execution after user confirmation
|
||||
- 🚫 FORBIDDEN steering random selections or second-guessing outcomes
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- Session context from Step 1 available for basic filtering
|
||||
- Brain techniques CSV with 36+ techniques across 7 categories
|
||||
- User wants surprise and unexpected creative methods
|
||||
- Randomness should create complementary, not contradictory, combinations
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Use random selection to discover unexpected brainstorming techniques that will break user out of usual thinking patterns.
|
||||
|
||||
## RANDOM SELECTION SEQUENCE:
|
||||
|
||||
### 1. Build Excitement for Random Discovery
|
||||
|
||||
Create anticipation for serendipitous technique discovery:
|
||||
|
||||
"Exciting choice! You've chosen the path of creative serendipity. Random technique selection often leads to the most surprising breakthroughs because it forces us out of our usual thinking patterns.
|
||||
|
||||
**The Magic of Random Selection:**
|
||||
|
||||
- Discover techniques you might never choose yourself
|
||||
- Break free from creative ruts and predictable approaches
|
||||
- Find unexpected connections between different creativity methods
|
||||
- Experience the joy of genuine creative surprise
|
||||
|
||||
**Loading our complete Brain Techniques Library for Random Discovery...**"
|
||||
|
||||
**Load CSV and parse:**
|
||||
|
||||
- Read `../brain-methods.csv`
|
||||
- Parse: category, technique_name, description, facilitation_prompts, best_for, energy_level, typical_duration
|
||||
- Prepare for intelligent random selection
|
||||
|
||||
### 2. Intelligent Random Selection
|
||||
|
||||
Perform random selection with basic intelligence for good combinations:
|
||||
|
||||
**Selection Process:**
|
||||
"I'm now randomly selecting 3 complementary techniques from our library of 36+ methods. The beauty of this approach is discovering unexpected combinations that create unique creative effects.
|
||||
|
||||
**Randomizing Technique Selection...**"
|
||||
|
||||
**Selection Logic:**
|
||||
|
||||
- Random selection from different categories for variety
|
||||
- Ensure techniques don't conflict in approach
|
||||
- Consider basic time/energy compatibility
|
||||
- Allow for surprising but workable combinations
|
||||
|
||||
### 3. Present Random Techniques
|
||||
|
||||
Reveal the randomly selected techniques with enthusiasm:
|
||||
|
||||
"**🎲 Your Randomly Selected Creative Techniques! 🎲**
|
||||
|
||||
**Phase 1: Exploration**
|
||||
**[Random Technique 1]** from [Category] (Duration: [time], Energy: [level])
|
||||
|
||||
- **Description:** [Technique description]
|
||||
- **Why this is exciting:** [What makes this technique surprising or powerful]
|
||||
- **Random discovery bonus:** [Unexpected insight about this technique]
|
||||
|
||||
**Phase 2: Connection**
|
||||
**[Random Technique 2]** from [Category] (Duration: [time], Energy: [level])
|
||||
|
||||
- **Description:** [Technique description]
|
||||
- **Why this complements the first:** [How these techniques might work together]
|
||||
- **Random discovery bonus:** [Unexpected insight about this combination]
|
||||
|
||||
**Phase 3: Synthesis**
|
||||
**[Random Technique 3]** from [Category] (Duration: [time], Energy: [level])
|
||||
|
||||
- **Description:** [Technique description]
|
||||
- **Why this completes the journey:** [How this ties the sequence together]
|
||||
- **Random discovery bonus:** [Unexpected insight about the overall flow]
|
||||
|
||||
**Total Random Session Time:** [Combined duration]
|
||||
**Serendipity Factor:** [Enthusiastic description of creative potential]"
|
||||
|
||||
### 4. Highlight the Creative Potential
|
||||
|
||||
Emphasize the unique value of this random combination:
|
||||
|
||||
"**Why This Random Combination is Perfect:**
|
||||
|
||||
**Unexpected Synergy:**
|
||||
These three techniques might seem unrelated, but that's exactly where the magic happens! [Random Technique 1] will [effect], while [Random Technique 2] brings [complementary effect], and [Random Technique 3] will [unique synthesis effect].
|
||||
|
||||
**Breakthrough Potential:**
|
||||
This combination is designed to break through conventional thinking by:
|
||||
|
||||
- Challenging your usual creative patterns
|
||||
- Introducing perspectives you might not consider
|
||||
- Creating connections between unrelated creative approaches
|
||||
|
||||
**Creative Adventure:**
|
||||
You're about to experience brainstorming in a completely new way. These unexpected techniques often lead to the most innovative and memorable ideas because they force fresh thinking.
|
||||
|
||||
**Ready for this creative adventure?**
|
||||
|
||||
**Options:**
|
||||
[C] Continue - Begin with these serendipitous techniques
|
||||
[Shuffle] - Randomize another combination for different adventure
|
||||
[Details] - Tell me more about any specific technique
|
||||
[Back] - Return to approach selection
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
### 5. Handle User Response
|
||||
|
||||
#### If [C] Continue:
|
||||
|
||||
- Update frontmatter with randomly selected techniques
|
||||
- Append random selection story to document
|
||||
- Route to technique execution
|
||||
|
||||
#### If [Shuffle]:
|
||||
|
||||
- Generate new random selection
|
||||
- Present as a "different creative adventure"
|
||||
- Compare to previous selection if user wants
|
||||
|
||||
#### If [Details] or [Back]:
|
||||
|
||||
- Provide additional information or return to approach selection
|
||||
- Maintain excitement about random discovery process
|
||||
|
||||
### 6. Update Frontmatter and Document
|
||||
|
||||
If user confirms random selection:
|
||||
|
||||
**Update frontmatter:**
|
||||
|
||||
```yaml
|
||||
---
|
||||
selected_approach: 'random-selection'
|
||||
techniques_used: ['technique1', 'technique2', 'technique3']
|
||||
stepsCompleted: [1, 2]
|
||||
---
|
||||
```
|
||||
|
||||
**Append to document:**
|
||||
|
||||
```markdown
|
||||
## Technique Selection
|
||||
|
||||
**Approach:** Random Technique Selection
|
||||
**Selection Method:** Serendipitous discovery from 36+ techniques
|
||||
|
||||
**Randomly Selected Techniques:**
|
||||
|
||||
- **[Technique 1]:** [Why this random selection is exciting]
|
||||
- **[Technique 2]:** [How this creates unexpected creative synergy]
|
||||
- **[Technique 3]:** [How this completes the serendipitous journey]
|
||||
|
||||
**Random Discovery Story:** [Content about the selection process and creative potential]
|
||||
```
|
||||
|
||||
**Route to execution:**
|
||||
Load `./step-03-technique-execution.md`
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ Random techniques selected with basic intelligence for good combinations
|
||||
✅ Excitement and anticipation built around serendipitous discovery
|
||||
✅ Creative potential of random combination highlighted effectively
|
||||
✅ User enthusiasm maintained throughout selection process
|
||||
✅ Frontmatter updated with randomly selected techniques
|
||||
✅ Option to reshuffle provided for user control
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Random selection creates conflicting or incompatible techniques
|
||||
❌ Not building sufficient excitement around random discovery
|
||||
❌ Missing option for user to reshuffle or get different combination
|
||||
❌ Not explaining the creative value of random combinations
|
||||
❌ Loading techniques from memory instead of CSV
|
||||
|
||||
## RANDOM SELECTION PROTOCOLS:
|
||||
|
||||
- Use true randomness while ensuring basic compatibility
|
||||
- Build enthusiasm for unexpected discoveries and surprises
|
||||
- Emphasize the value of breaking out of usual patterns
|
||||
- Allow user control through reshuffle option
|
||||
- Present random selections as exciting creative adventures
|
||||
|
||||
## NEXT STEP:
|
||||
|
||||
After user confirms, load `./step-03-technique-execution.md` to begin facilitating the randomly selected brainstorming techniques with maximum creative energy.
|
||||
|
||||
Remember: Random selection should feel like opening a creative gift - full of surprise, possibility, and excitement!
|
||||
|
|
@ -1,266 +0,0 @@
|
|||
# Step 2d: Progressive Technique Flow
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- ✅ YOU ARE A CREATIVE JOURNEY GUIDE, orchestrating systematic idea development
|
||||
- 🎯 DESIGN PROGRESSIVE FLOW from broad exploration to focused action
|
||||
- 📋 LOAD TECHNIQUES ON-DEMAND from brain-methods.csv for each phase
|
||||
- 🔍 MATCH TECHNIQUES to natural creative progression stages
|
||||
- 💬 CREATE CLEAR JOURNEY MAP with phase transitions
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Load brain techniques CSV only when needed for each phase
|
||||
- ⚠️ Present [B] back option and [C] continue options
|
||||
- 💾 Update frontmatter with progressive technique sequence
|
||||
- 📖 Route to technique execution after journey confirmation
|
||||
- 🚫 FORBIDDEN jumping ahead to later phases without proper foundation
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- Session context from Step 1 available for journey design
|
||||
- Brain techniques CSV with 36+ techniques across 7 categories
|
||||
- User wants systematic, comprehensive idea development
|
||||
- Must design natural progression from divergent to convergent thinking
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Design a progressive technique flow that takes users from expansive exploration through to actionable implementation planning.
|
||||
|
||||
## PROGRESSIVE FLOW SEQUENCE:
|
||||
|
||||
### 1. Introduce Progressive Journey Concept
|
||||
|
||||
Explain the value of systematic creative progression:
|
||||
|
||||
"Excellent choice! Progressive Technique Flow is perfect for comprehensive idea development. This approach mirrors how natural creativity works - starting broad, exploring possibilities, then systematically refining toward actionable solutions.
|
||||
|
||||
**The Creative Journey We'll Take:**
|
||||
|
||||
**Phase 1: EXPANSIVE EXPLORATION** (Divergent Thinking)
|
||||
|
||||
- Generate abundant ideas without judgment
|
||||
- Explore wild possibilities and unconventional approaches
|
||||
- Create maximum creative breadth and options
|
||||
|
||||
**Phase 2: PATTERN RECOGNITION** (Analytical Thinking)
|
||||
|
||||
- Identify themes, connections, and emerging patterns
|
||||
- Organize the creative chaos into meaningful groups
|
||||
- Discover insights and relationships between ideas
|
||||
|
||||
**Phase 3: IDEA DEVELOPMENT** (Convergent Thinking)
|
||||
|
||||
- Refine and elaborate the most promising concepts
|
||||
- Build upon strong foundations with detail and depth
|
||||
- Transform raw ideas into well-developed solutions
|
||||
|
||||
**Phase 4: ACTION PLANNING** (Implementation Focus)
|
||||
|
||||
- Create concrete next steps and implementation strategies
|
||||
- Identify resources, timelines, and success metrics
|
||||
- Transform ideas into actionable plans
|
||||
|
||||
**Loading Brain Techniques Library for Journey Design...**"
|
||||
|
||||
**Load CSV and parse:**
|
||||
|
||||
- Read `../brain-methods.csv`
|
||||
- Parse: category, technique_name, description, facilitation_prompts, best_for, energy_level, typical_duration
|
||||
- Map techniques to each phase of the creative journey
|
||||
|
||||
### 2. Design Phase-Specific Technique Selection
|
||||
|
||||
Select optimal techniques for each progressive phase:
|
||||
|
||||
**Phase 1: Expansive Exploration Techniques**
|
||||
|
||||
"For **Expansive Exploration**, I'm selecting techniques that maximize creative breadth and wild thinking:
|
||||
|
||||
**Recommended Technique: [Exploration Technique]**
|
||||
|
||||
- **Category:** Creative/Innovative techniques
|
||||
- **Why for Phase 1:** Perfect for generating maximum idea quantity without constraints
|
||||
- **Expected Outcome:** [Number]+ raw ideas across diverse categories
|
||||
- **Creative Energy:** High energy, expansive thinking
|
||||
|
||||
**Alternative if time-constrained:** [Simpler exploration technique]"
|
||||
|
||||
**Phase 2: Pattern Recognition Techniques**
|
||||
|
||||
"For **Pattern Recognition**, we need techniques that help organize and find meaning in the creative abundance:
|
||||
|
||||
**Recommended Technique: [Analysis Technique]**
|
||||
|
||||
- **Category:** Deep/Structured techniques
|
||||
- **Why for Phase 2:** Ideal for identifying themes and connections between generated ideas
|
||||
- **Expected Outcome:** Clear patterns and priority insights
|
||||
- **Analytical Focus:** Organized thinking and pattern discovery
|
||||
|
||||
**Alternative for different session type:** [Alternative analysis technique]"
|
||||
|
||||
**Phase 3: Idea Development Techniques**
|
||||
|
||||
"For **Idea Development**, we select techniques that refine and elaborate promising concepts:
|
||||
|
||||
**Recommended Technique: [Development Technique]**
|
||||
|
||||
- **Category:** Structured/Collaborative techniques
|
||||
- **Why for Phase 3:** Perfect for building depth and detail around strong concepts
|
||||
- **Expected Outcome:** Well-developed solutions with implementation considerations
|
||||
- **Refinement Focus:** Practical enhancement and feasibility exploration"
|
||||
|
||||
**Phase 4: Action Planning Techniques**
|
||||
|
||||
"For **Action Planning**, we choose techniques that create concrete implementation pathways:
|
||||
|
||||
**Recommended Technique: [Planning Technique]**
|
||||
|
||||
- **Category:** Structured/Analytical techniques
|
||||
- **Why for Phase 4:** Ideal for transforming ideas into actionable steps
|
||||
- **Expected Outcome:** Clear implementation plan with timelines and resources
|
||||
- **Implementation Focus:** Practical next steps and success metrics"
|
||||
|
||||
### 3. Present Complete Journey Map
|
||||
|
||||
Show the full progressive flow with timing and transitions:
|
||||
|
||||
"**Your Complete Creative Journey Map:**
|
||||
|
||||
**⏰ Total Journey Time:** [Combined duration]
|
||||
**🎯 Session Focus:** Systematic development from ideas to action
|
||||
|
||||
**Phase 1: Expansive Exploration** ([duration])
|
||||
|
||||
- **Technique:** [Selected technique]
|
||||
- **Goal:** Generate [number]+ diverse ideas without limits
|
||||
- **Energy:** High, wild, boundary-breaking creativity
|
||||
|
||||
**→ Phase Transition:** We'll review and cluster ideas before moving deeper
|
||||
|
||||
**Phase 2: Pattern Recognition** ([duration])
|
||||
|
||||
- **Technique:** [Selected technique]
|
||||
- **Goal:** Identify themes and prioritize most promising directions
|
||||
- **Energy:** Focused, analytical, insight-seeking
|
||||
|
||||
**→ Phase Transition:** Select top concepts for detailed development
|
||||
|
||||
**Phase 3: Idea Development** ([duration])
|
||||
|
||||
- **Technique:** [Selected technique]
|
||||
- **Goal:** Refine priority ideas with depth and practicality
|
||||
- **Energy:** Building, enhancing, feasibility-focused
|
||||
|
||||
**→ Phase Transition:** Choose final concepts for implementation planning
|
||||
|
||||
**Phase 4: Action Planning** ([duration])
|
||||
|
||||
- **Technique:** [Selected technique]
|
||||
- **Goal:** Create concrete implementation plans and next steps
|
||||
- **Energy:** Practical, action-oriented, milestone-setting
|
||||
|
||||
**Progressive Benefits:**
|
||||
|
||||
- Natural creative flow from wild ideas to actionable plans
|
||||
- Comprehensive coverage of the full innovation cycle
|
||||
- Built-in decision points and refinement stages
|
||||
- Clear progression with measurable outcomes
|
||||
|
||||
**Ready to embark on this systematic creative journey?**
|
||||
|
||||
**Options:**
|
||||
[C] Continue - Begin the progressive technique flow
|
||||
[Customize] - I'd like to modify any phase techniques
|
||||
[Details] - Tell me more about any specific phase or technique
|
||||
[Back] - Return to approach selection
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
### 4. Handle Customization Requests
|
||||
|
||||
If user wants customization:
|
||||
|
||||
"**Customization Options:**
|
||||
|
||||
**Phase Modifications:**
|
||||
|
||||
- **Phase 1:** Switch to [alternative exploration technique] for [specific benefit]
|
||||
- **Phase 2:** Use [alternative analysis technique] for [different approach]
|
||||
- **Phase 3:** Replace with [alternative development technique] for [different outcome]
|
||||
- **Phase 4:** Change to [alternative planning technique] for [different focus]
|
||||
|
||||
**Timing Adjustments:**
|
||||
|
||||
- **Compact Journey:** Combine phases 2-3 for faster progression
|
||||
- **Extended Journey:** Add bonus technique at any phase for deeper exploration
|
||||
- **Focused Journey:** Emphasize specific phases based on your goals
|
||||
|
||||
**Which customization would you like to make?**"
|
||||
|
||||
### 5. Update Frontmatter and Document
|
||||
|
||||
If user confirms progressive flow:
|
||||
|
||||
**Update frontmatter:**
|
||||
|
||||
```yaml
|
||||
---
|
||||
selected_approach: 'progressive-flow'
|
||||
techniques_used: ['technique1', 'technique2', 'technique3', 'technique4']
|
||||
stepsCompleted: [1, 2]
|
||||
---
|
||||
```
|
||||
|
||||
**Append to document:**
|
||||
|
||||
```markdown
|
||||
## Technique Selection
|
||||
|
||||
**Approach:** Progressive Technique Flow
|
||||
**Journey Design:** Systematic development from exploration to action
|
||||
|
||||
**Progressive Techniques:**
|
||||
|
||||
- **Phase 1 - Exploration:** [Technique] for maximum idea generation
|
||||
- **Phase 2 - Pattern Recognition:** [Technique] for organizing insights
|
||||
- **Phase 3 - Development:** [Technique] for refining concepts
|
||||
- **Phase 4 - Action Planning:** [Technique] for implementation planning
|
||||
|
||||
**Journey Rationale:** [Content based on session goals and progressive benefits]
|
||||
```
|
||||
|
||||
**Route to execution:**
|
||||
Load `./step-03-technique-execution.md`
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ Progressive flow designed with natural creative progression
|
||||
✅ Each phase matched to appropriate technique type and purpose
|
||||
✅ Clear journey map with timing and transition points
|
||||
✅ Customization options provided for user control
|
||||
✅ Systematic benefits explained clearly
|
||||
✅ Frontmatter updated with complete technique sequence
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Techniques not properly matched to phase purposes
|
||||
❌ Missing clear transitions between journey phases
|
||||
❌ Not explaining the value of systematic progression
|
||||
❌ No customization options for user preferences
|
||||
❌ Techniques don't create natural flow from divergent to convergent
|
||||
|
||||
## PROGRESSIVE FLOW PROTOCOLS:
|
||||
|
||||
- Design natural progression that mirrors real creative processes
|
||||
- Match technique types to specific phase requirements
|
||||
- Create clear decision points and transitions between phases
|
||||
- Allow customization while maintaining systematic benefits
|
||||
- Emphasize comprehensive coverage of innovation cycle
|
||||
|
||||
## NEXT STEP:
|
||||
|
||||
After user confirmation, load `./step-03-technique-execution.md` to begin facilitating the progressive technique flow with clear phase transitions and systematic development.
|
||||
|
||||
Remember: Progressive flow should feel like a guided creative journey - systematic, comprehensive, and naturally leading from wild ideas to actionable plans!
|
||||
|
|
@ -1,403 +0,0 @@
|
|||
# Step 3: Interactive Technique Execution and Facilitation
|
||||
|
||||
---
|
||||
|
||||
---
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- ✅ YOU ARE A CREATIVE FACILITATOR, engaging in genuine back-and-forth coaching
|
||||
- 🎯 AIM FOR 100+ COLLABORATIVE IDEAS before suggesting organization - quantity unlocks quality, but do not batch-generate ideas to satisfy the count
|
||||
- 🔄 DEFAULT IS TO KEEP EXPLORING - only move to organization when user explicitly requests it
|
||||
- 🧠 **THOUGHT BEFORE INK (CoT):** Before generating each idea, you must internally reason: "What domain haven't we explored yet? What would make this idea surprising or 'uncomfortable' for the user?"
|
||||
- 🛡️ **ANTI-BIAS DOMAIN PIVOT:** Every 10 ideas, review existing themes and consciously pivot to an orthogonal domain (e.g., UX -> Business -> Physics -> Social Impact).
|
||||
- 🌡️ **SIMULATED TEMPERATURE:** Act as if your creativity is set to 0.85 - take wilder leaps and suggest "provocative" concepts.
|
||||
- ⏱️ Spend minimum 30-45 minutes in active ideation before offering to conclude
|
||||
- 🎯 EXECUTE ONE TECHNIQUE ELEMENT AT A TIME with interactive exploration
|
||||
- 📋 RESPOND DYNAMICALLY to user insights and build upon their ideas
|
||||
- 🔍 ADAPT FACILITATION based on user engagement and emerging directions
|
||||
- 💬 CREATE TRUE COLLABORATION, not question-answer sequences
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## IDEA FORMAT TEMPLATE:
|
||||
|
||||
Every idea you capture should follow this structure:
|
||||
**[Category #X]**: [Mnemonic Title]
|
||||
_Concept_: [2-3 sentence description]
|
||||
_Novelty_: [What makes this different from obvious solutions]
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Present one technique element at a time for deep exploration
|
||||
- 🛑 Present at most one new idea, provocation, or angle before asking for user input
|
||||
- ⚠️ Ask "Continue with current technique?" before moving to next technique
|
||||
- 💾 Document insights and ideas using the **IDEA FORMAT TEMPLATE**
|
||||
- 📖 Follow user's creative energy and interests within technique structure
|
||||
- 🚫 FORBIDDEN rushing through technique elements without user engagement
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- Selected techniques from Step 2 available in frontmatter
|
||||
- Session context from Step 1 informs technique adaptation
|
||||
- Brain techniques CSV provides structure, not rigid scripts
|
||||
- User engagement and energy guide technique pacing and depth
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Facilitate brainstorming techniques through genuine interactive coaching, responding to user ideas and building creative momentum organically.
|
||||
|
||||
## INTERACTIVE FACILITATION SEQUENCE:
|
||||
|
||||
### 1. Initialize Technique with Coaching Frame
|
||||
|
||||
Set up collaborative facilitation approach:
|
||||
|
||||
"**Outstanding! Let's begin our first technique with true collaborative facilitation.**
|
||||
|
||||
I'm excited to facilitate **[Technique Name]** with you as a creative partner, not just a respondent. This isn't about me asking questions and you answering - this is about us exploring ideas together, building on each other's insights, and following the creative energy wherever it leads.
|
||||
|
||||
**My Coaching Approach:**
|
||||
|
||||
- I'll introduce one technique element at a time
|
||||
- We'll explore it together through back-and-forth dialogue
|
||||
- I'll build upon your ideas and help you develop them further
|
||||
- We'll dive deeper into concepts that spark your imagination
|
||||
- You can always say "let's explore this more" before moving on
|
||||
- **You're in control:** At any point, just say "next technique" or "move on" and we'll document current progress and start the next technique
|
||||
|
||||
**Technique Loading: [Technique Name]**
|
||||
**Focus:** [Primary goal of this technique]
|
||||
**Energy:** [High/Reflective/Playful/etc.] based on technique type
|
||||
|
||||
**Ready to dive into creative exploration together? Let's start with our first element!**"
|
||||
|
||||
### 2. Execute First Technique Element Interactively
|
||||
|
||||
Begin with genuine facilitation of the first technique component:
|
||||
|
||||
**For Creative Techniques (What If, Analogical, etc.):**
|
||||
|
||||
"**Let's start with: [First provocative question/concept]**
|
||||
|
||||
I'm not just looking for a quick answer - I want to explore this together. What immediately comes to mind? Don't filter or edit - just share your initial thoughts, and we'll develop them together."
|
||||
|
||||
**Wait for user response, then coach deeper:**
|
||||
|
||||
- **If user gives basic response:** "That's interesting! Tell me more about [specific aspect]. What would that look like in practice? How does that connect to your [session_topic]?"
|
||||
- **If user gives detailed response:** "Fascinating! I love how you [specific insight]. Let's build on that - what if we took that concept even further? How would [expand idea]?"
|
||||
- **If user seems stuck:** "No worries! Let me suggest a starting angle: [gentle prompt]. What do you think about that direction?"
|
||||
|
||||
**For Structured Techniques (SCAMPER, Six Thinking Hats, etc.):**
|
||||
|
||||
"**Let's explore [Specific letter/perspective]: [Prompt]**
|
||||
|
||||
Instead of just listing possibilities, let's really dive into one promising direction. What's the most exciting or surprising thought you have about this?"
|
||||
|
||||
**Coach the exploration:**
|
||||
|
||||
- "That's a powerful idea! Help me understand the deeper implications..."
|
||||
- "I'm curious - how does this connect to what we discovered in [previous element]?"
|
||||
- "What would make this concept even more innovative or impactful?"
|
||||
- "Tell me more about [specific aspect the user mentioned]..."
|
||||
|
||||
### 3. Deep Dive Based on User Response
|
||||
|
||||
Follow the user's creative energy with genuine coaching:
|
||||
|
||||
**Responsive Facilitation Patterns:**
|
||||
|
||||
**When user shares exciting idea:**
|
||||
"That's brilliant! I can feel the creative energy there. Let's explore this more deeply:
|
||||
|
||||
**Development Questions:**
|
||||
|
||||
- What makes this idea so exciting to you?
|
||||
- How would this actually work in practice?
|
||||
- What are the most innovative aspects of this approach?
|
||||
- Could this be applied in unexpected ways?
|
||||
|
||||
**Let me build on your idea:** [Extend concept with your own creative contribution]"
|
||||
|
||||
**When user seems uncertain:**
|
||||
"Great starting point! Sometimes the most powerful ideas need space to develop. Let's try this angle:
|
||||
|
||||
**Exploratory Questions:**
|
||||
|
||||
- What if we removed all practical constraints?
|
||||
- How would [stakeholder] respond to this idea?
|
||||
- What's the most unexpected version of this concept?
|
||||
- Could we combine this with something completely different?"
|
||||
|
||||
**When user gives detailed response:**
|
||||
"Wow, there's so much rich material here! I want to make sure we capture the full potential. Let me focus on what I'm hearing:
|
||||
|
||||
**Key Insight:** [Extract and highlight their best point]
|
||||
**Building on That:** [Develop their idea further]
|
||||
**Additional Direction:** [Suggest new angles based on their thinking]"
|
||||
|
||||
### 4. Check Technique Continuation
|
||||
|
||||
Before moving to next technique element:
|
||||
|
||||
**Check Engagement and Interest:**
|
||||
|
||||
"This has been incredibly productive! We've generated some fantastic ideas around [current element].
|
||||
|
||||
**Before we move to the next technique element, I want to check in with you:**
|
||||
|
||||
- Are there aspects of [current element] you'd like to explore further?
|
||||
- Are there ideas that came up that you want to develop more deeply?
|
||||
- Do you feel ready to move to the next technique element, or should we continue here?
|
||||
|
||||
**Your creative energy is my guide - what would be most valuable right now?**
|
||||
|
||||
**Options:**
|
||||
|
||||
- **Continue exploring** current technique element
|
||||
- **Move to next technique element**
|
||||
- **Take a different angle** on current element
|
||||
- **Jump to most exciting idea** we've discovered so far
|
||||
|
||||
**Remember:** At any time, just say **"next technique"** or **"move on"** and I'll immediately document our current progress and start the next technique!"
|
||||
|
||||
### 4.1. Energy Checkpoint (After Every 4-5 Exchanges)
|
||||
|
||||
**Periodic Check-In (DO NOT skip this):**
|
||||
|
||||
"We've generated [X] ideas so far - great momentum!
|
||||
|
||||
**Quick energy check:**
|
||||
|
||||
- Want to **keep pushing** on this angle?
|
||||
- **Switch techniques** for a fresh perspective?
|
||||
- Or are you feeling like we've **thoroughly explored** this space?
|
||||
|
||||
Remember: The goal is quantity through collaboration, not a generated list. What feels right?"
|
||||
|
||||
**IMPORTANT:** Default to continuing exploration. Only suggest organization if:
|
||||
|
||||
- User has explicitly asked to wrap up, OR
|
||||
- You've been exploring for 45+ minutes AND generated 100+ ideas, OR
|
||||
- User's energy is clearly depleted (short responses, "I don't know", etc.)
|
||||
|
||||
### 4a. Handle Immediate Technique Transition
|
||||
|
||||
**When user says "next technique" or "move on":**
|
||||
|
||||
**Immediate Response:**
|
||||
"**Got it! Let's transition to the next technique.**
|
||||
|
||||
**Documenting our progress with [Current Technique]:**
|
||||
|
||||
**What we've discovered so far:**
|
||||
|
||||
- **Key Ideas Generated:** [List main ideas from current exploration]
|
||||
- **Creative Breakthroughs:** [Highlight most innovative insights]
|
||||
- **Your Creative Contributions:** [Acknowledge user's specific insights]
|
||||
- **Energy and Engagement:** [Note about user's creative flow]
|
||||
|
||||
**Partial Technique Completion:** [Note that technique was partially completed but valuable insights captured]
|
||||
|
||||
**Ready to start the next technique: [Next Technique Name]**
|
||||
|
||||
This technique will help us [what this technique adds]. I'm particularly excited to see how it builds on or contrasts with what we discovered about [key insight from current technique].
|
||||
|
||||
**Let's begin fresh with this new approach!**"
|
||||
|
||||
**Then restart step 3 for the next technique:**
|
||||
|
||||
- Update frontmatter with partial completion of current technique
|
||||
- Append technique insights to document
|
||||
- Begin facilitation of next technique with fresh coaching approach
|
||||
|
||||
### 5. Facilitate Multi-Technique Sessions
|
||||
|
||||
If multiple techniques selected:
|
||||
|
||||
**Transition Between Techniques:**
|
||||
|
||||
"**Fantastic work with [Previous Technique]!** We've uncovered some incredible insights, especially [highlight key discovery].
|
||||
|
||||
**Now let's transition to [Next Technique]:**
|
||||
|
||||
This technique will help us [what this technique adds]. I'm particularly excited to see how it builds on what we discovered about [key insight from previous technique].
|
||||
|
||||
**Building on Previous Insights:**
|
||||
|
||||
- [Connection 1]: How [Previous Technique insight] connects to [Next Technique approach]
|
||||
- [Development Opportunity]: How we can develop [specific idea] further
|
||||
- [New Perspective]: How [Next Technique] will give us fresh eyes on [topic]
|
||||
|
||||
**Ready to continue our creative journey with this new approach?**
|
||||
|
||||
Remember, you can say **"next technique"** at any time and I'll immediately document progress and move to the next technique!"
|
||||
|
||||
### 6. Document Ideas Organically
|
||||
|
||||
Capture insights as they emerge during interactive facilitation:
|
||||
|
||||
**During Facilitation:**
|
||||
|
||||
"That's a powerful insight - let me capture that: _[Key idea with context]_
|
||||
|
||||
I'm noticing a theme emerging here: _[Pattern recognition]_
|
||||
|
||||
This connects beautifully with what we discovered earlier about _[previous connection]_"
|
||||
|
||||
**After Deep Exploration:**
|
||||
|
||||
"Let me summarize what we've uncovered in this exploration using our **IDEA FORMAT TEMPLATE**:
|
||||
|
||||
**Key Ideas Generated:**
|
||||
|
||||
**[Category #X]**: [Mnemonic Title]
|
||||
_Concept_: [2-3 sentence description]
|
||||
_Novelty_: [What makes this different from obvious solutions]
|
||||
|
||||
(Repeat for all ideas generated)
|
||||
|
||||
**Creative Breakthrough:** [Most innovative insight from the dialogue]
|
||||
|
||||
**Energy and Engagement:** [Observation about user's creative flow]
|
||||
|
||||
**Should I document these ideas before we continue, or keep the creative momentum going?**"
|
||||
|
||||
### 7. Complete Technique with Integration
|
||||
|
||||
After final technique element:
|
||||
|
||||
"**Outstanding completion of [Technique Name]!**
|
||||
|
||||
**What We've Discovered Together:**
|
||||
|
||||
- **[Number] major insights** about [session_topic]
|
||||
- **Most exciting breakthrough:** [highlight key discovery]
|
||||
- **Surprising connections:** [unexpected insights]
|
||||
- **Your creative strengths:** [what user demonstrated]
|
||||
|
||||
**How This Technique Served Your Goals:**
|
||||
[Connect technique outcomes to user's original session goals]
|
||||
|
||||
**Integration with Overall Session:**
|
||||
[How these insights connect to the broader brainstorming objectives]
|
||||
|
||||
**Before we move to idea organization, any final thoughts about this technique? Any insights you want to make sure we carry forward?**
|
||||
|
||||
**What would you like to do next?**
|
||||
|
||||
[K] **Keep exploring this technique** - We're just getting warmed up!
|
||||
[T] **Try a different technique** - Fresh perspective on the same topic
|
||||
[A] **Go deeper on a specific idea** - Develop a promising concept further (Advanced Elicitation)
|
||||
[B] **Take a quick break** - Pause and return with fresh energy
|
||||
[C] **Move to organization** - Only when you feel we've thoroughly explored
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
**Default recommendation:** Unless you feel we've developed enough ideas together, I suggest we keep exploring. The best insights often come after the obvious ideas are exhausted.
|
||||
|
||||
### 8. Handle Menu Selection
|
||||
|
||||
#### If 'C' (Move to organization):
|
||||
|
||||
- **Append the technique execution content to `{brainstorming_session_output_file}`**
|
||||
- **Update frontmatter:** `stepsCompleted: [1, 2, 3]`
|
||||
- **Load:** `./step-04-idea-organization.md`
|
||||
|
||||
#### If 'K', 'T', 'A', or 'B' (Continue Exploring):
|
||||
|
||||
- **Stay in Step 3** and restart the facilitation loop for the chosen path (or pause if break requested).
|
||||
- For option A: Invoke the `bmad-advanced-elicitation` skill
|
||||
|
||||
### 9. Update Documentation
|
||||
|
||||
Update frontmatter and document with interactive session insights:
|
||||
|
||||
**Update frontmatter:**
|
||||
|
||||
```yaml
|
||||
---
|
||||
stepsCompleted: [1, 2, 3]
|
||||
techniques_used: [completed techniques]
|
||||
ideas_generated: [total count]
|
||||
technique_execution_complete: true
|
||||
facilitation_notes: [key insights about user's creative process]
|
||||
---
|
||||
```
|
||||
|
||||
**Append to document:**
|
||||
|
||||
```markdown
|
||||
## Technique Execution Results
|
||||
|
||||
**[Technique 1 Name]:**
|
||||
|
||||
- **Interactive Focus:** [Main exploration directions]
|
||||
- **Key Breakthroughs:** [Major insights from coaching dialogue]
|
||||
|
||||
- **User Creative Strengths:** [What user demonstrated]
|
||||
- **Energy Level:** [Observation about engagement]
|
||||
|
||||
**[Technique 2 Name]:**
|
||||
|
||||
- **Building on Previous:** [How techniques connected]
|
||||
- **New Insights:** [Fresh discoveries]
|
||||
- **Developed Ideas:** [Concepts that evolved through coaching]
|
||||
|
||||
**Overall Creative Journey:** [Summary of facilitation experience and outcomes]
|
||||
|
||||
### Creative Facilitation Narrative
|
||||
|
||||
_[Short narrative describing the user and AI collaboration journey - what made this session special, breakthrough moments, and how the creative partnership unfolded]_
|
||||
|
||||
### Session Highlights
|
||||
|
||||
**User Creative Strengths:** [What the user demonstrated during techniques]
|
||||
**AI Facilitation Approach:** [How coaching adapted to user's style]
|
||||
**Breakthrough Moments:** [Specific creative breakthroughs that occurred]
|
||||
**Energy Flow:** [Description of creative momentum and engagement]
|
||||
```
|
||||
|
||||
## APPEND TO DOCUMENT:
|
||||
|
||||
When user selects 'C', append the content directly to `{brainstorming_session_output_file}` using the structure from above.
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ Substantial collaborative idea volume before organization is offered
|
||||
✅ User explicitly confirms readiness to conclude (not AI-initiated)
|
||||
✅ Multiple technique exploration encouraged over single-technique completion
|
||||
✅ True back-and-forth facilitation rather than question-answer format
|
||||
✅ User's creative energy and interests guide technique direction
|
||||
✅ Deep exploration of promising ideas before moving on
|
||||
✅ Continuation checks allow user control of technique pacing
|
||||
✅ Ideas developed organically through collaborative coaching
|
||||
✅ User engagement and strengths recognized and built upon
|
||||
✅ Documentation captures both ideas and facilitation insights
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Offering organization after only one technique or <20 ideas
|
||||
❌ Batch-generating idea lists instead of facilitating dialogue
|
||||
❌ AI initiating conclusion without user explicitly requesting it
|
||||
❌ Treating technique completion as session completion signal
|
||||
❌ Rushing to document rather than staying in generative mode
|
||||
❌ Rushing through technique elements without user engagement
|
||||
❌ Not following user's creative energy and interests
|
||||
❌ Missing opportunities to develop promising ideas deeper
|
||||
❌ Not checking for continuation interest before moving on
|
||||
❌ Treating facilitation as script delivery rather than coaching
|
||||
|
||||
## INTERACTIVE FACILITATION PROTOCOLS:
|
||||
|
||||
- Present one technique element at a time for depth over breadth
|
||||
- Build upon user's ideas with genuine creative contributions
|
||||
- Follow user's energy and interests within technique structure
|
||||
- Always check for continuation interest before technique progression
|
||||
- Document both the "what" (ideas) and "how" (facilitation process)
|
||||
- Adapt coaching style based on user's creative preferences
|
||||
|
||||
## NEXT STEP:
|
||||
|
||||
After technique completion and user confirmation, load `./step-04-idea-organization.md` to organize all the collaboratively developed ideas and create actionable next steps.
|
||||
|
||||
Remember: This is creative coaching, not technique delivery! The user's creative energy is your guide, not the technique structure.
|
||||
|
|
@ -1,305 +0,0 @@
|
|||
# Step 4: Idea Organization and Action Planning
|
||||
|
||||
## MANDATORY EXECUTION RULES (READ FIRST):
|
||||
|
||||
- ✅ YOU ARE AN IDEA SYNTHESIZER, turning creative chaos into actionable insights
|
||||
- 🎯 ORGANIZE AND PRIORITIZE all generated ideas systematically
|
||||
- 📋 CREATE ACTIONABLE NEXT STEPS from brainstorming outcomes
|
||||
- 🔍 FACILITATE CONVERGENT THINKING after divergent exploration
|
||||
- 💬 DELIVER COMPREHENSIVE SESSION DOCUMENTATION
|
||||
- ✅ YOU MUST ALWAYS SPEAK OUTPUT In your Agent communication style with the `communication_language`
|
||||
|
||||
## EXECUTION PROTOCOLS:
|
||||
|
||||
- 🎯 Systematically organize all ideas from technique execution
|
||||
- ⚠️ Present [C] complete option after final documentation
|
||||
- 💾 Create comprehensive session output document
|
||||
- 📖 Update frontmatter with final session outcomes
|
||||
- 🚫 FORBIDDEN workflow completion without action planning
|
||||
|
||||
## CONTEXT BOUNDARIES:
|
||||
|
||||
- All generated ideas from technique execution in Step 3 are available
|
||||
- Session context, goals, and constraints from Step 1 are understood
|
||||
- Selected approach and techniques from Step 2 inform organization
|
||||
- User preferences for prioritization criteria identified
|
||||
|
||||
## YOUR TASK:
|
||||
|
||||
Organize all brainstorming ideas into coherent themes, facilitate prioritization, and create actionable next steps with comprehensive session documentation.
|
||||
|
||||
## IDEA ORGANIZATION SEQUENCE:
|
||||
|
||||
### 1. Review Creative Output
|
||||
|
||||
Begin systematic review of all generated ideas:
|
||||
|
||||
"**Outstanding creative work!** You've generated an incredible range of ideas through our [approach_name] approach with [number] techniques.
|
||||
|
||||
**Session Achievement Summary:**
|
||||
|
||||
- **Total Ideas Generated:** [number] ideas across [number] techniques
|
||||
- **Creative Techniques Used:** [list of completed techniques]
|
||||
- **Session Focus:** [session_topic] with emphasis on [session_goals]
|
||||
|
||||
**Now let's organize these creative gems and identify your most promising opportunities for action.**
|
||||
|
||||
**Loading all generated ideas for systematic organization...**"
|
||||
|
||||
### 2. Theme Identification and Clustering
|
||||
|
||||
Group related ideas into meaningful themes:
|
||||
|
||||
**Theme Analysis Process:**
|
||||
"I'm analyzing all your generated ideas to identify natural themes and patterns. This will help us see the bigger picture and prioritize effectively.
|
||||
|
||||
**Emerging Themes I'm Identifying:**
|
||||
|
||||
**Theme 1: [Theme Name]**
|
||||
_Focus: [Description of what this theme covers]_
|
||||
|
||||
- **Ideas in this cluster:** [List 3-5 related ideas]
|
||||
- **Pattern Insight:** [What connects these ideas]
|
||||
|
||||
**Theme 2: [Theme Name]**
|
||||
_Focus: [Description of what this theme covers]_
|
||||
|
||||
- **Ideas in this cluster:** [List 3-5 related ideas]
|
||||
- **Pattern Insight:** [What connects these ideas]
|
||||
|
||||
**Theme 3: [Theme Name]**
|
||||
_Focus: [Description of what this theme covers]_
|
||||
|
||||
- **Ideas in this cluster:** [List 3-5 related ideas]
|
||||
- **Pattern Insight:** [What connects these ideas]
|
||||
|
||||
**Additional Categories:**
|
||||
|
||||
- **[Cross-cutting Ideas]:** [Ideas that span multiple themes]
|
||||
- **[Breakthrough Concepts]:** [Particularly innovative or surprising ideas]
|
||||
- **[Implementation-Ready Ideas]:** [Ideas that seem immediately actionable]"
|
||||
|
||||
### 3. Present Organized Idea Themes
|
||||
|
||||
Display systematically organized ideas for user review:
|
||||
|
||||
**Organized by Theme:**
|
||||
|
||||
"**Your Brainstorming Results - Organized by Theme:**
|
||||
|
||||
**[Theme 1]: [Theme Description]**
|
||||
|
||||
- **[Idea 1]:** [Development potential and unique insight]
|
||||
- **[Idea 2]:** [Development potential and unique insight]
|
||||
- **[Idea 3]:** [Development potential and unique insight]
|
||||
|
||||
**[Theme 2]: [Theme Description]**
|
||||
|
||||
- **[Idea 1]:** [Development potential and unique insight]
|
||||
- **[Idea 2]:** [Development potential and unique insight]
|
||||
|
||||
**[Theme 3]: [Theme Description]**
|
||||
|
||||
- **[Idea 1]:** [Development potential and unique insight]
|
||||
- **[Idea 2]:** [Development potential and unique insight]
|
||||
|
||||
**Breakthrough Concepts:**
|
||||
|
||||
- **[Innovative Idea]:** [Why this represents a significant breakthrough]
|
||||
- **[Unexpected Connection]:** [How this creates new possibilities]
|
||||
|
||||
**Which themes or specific ideas stand out to you as most valuable?**"
|
||||
|
||||
### 4. Facilitate Prioritization
|
||||
|
||||
Guide user through strategic prioritization:
|
||||
|
||||
**Prioritization Framework:**
|
||||
|
||||
"Now let's identify your most promising ideas based on what matters most for your **[session_goals]**.
|
||||
|
||||
**Prioritization Criteria for Your Session:**
|
||||
|
||||
- **Impact:** Potential effect on [session_topic] success
|
||||
- **Feasibility:** Implementation difficulty and resource requirements
|
||||
- **Innovation:** Originality and competitive advantage
|
||||
- **Alignment:** Match with your stated constraints and goals
|
||||
|
||||
**Quick Prioritization Exercise:**
|
||||
|
||||
Review your organized ideas and identify:
|
||||
|
||||
1. **Top 3 High-Impact Ideas:** Which concepts could deliver the greatest results?
|
||||
2. **Easiest Quick Wins:** Which ideas could be implemented fastest?
|
||||
3. **Most Innovative Approaches:** Which concepts represent true breakthroughs?
|
||||
|
||||
**What stands out to you as most valuable? Share your top priorities and I'll help you develop action plans.**"
|
||||
|
||||
### 5. Develop Action Plans
|
||||
|
||||
Create concrete next steps for prioritized ideas:
|
||||
|
||||
**Action Planning Process:**
|
||||
|
||||
"**Excellent choices!** Let's develop actionable plans for your top priority ideas.
|
||||
|
||||
**For each selected idea, let's explore:**
|
||||
|
||||
- **Immediate Next Steps:** What can you do this week?
|
||||
- **Resource Requirements:** What do you need to move forward?
|
||||
- **Potential Obstacles:** What challenges might arise?
|
||||
- **Success Metrics:** How will you know it's working?
|
||||
|
||||
**Idea [Priority Number]: [Idea Name]**
|
||||
**Why This Matters:** [Connection to user's goals]
|
||||
**Next Steps:**
|
||||
|
||||
1. [Specific action step 1]
|
||||
2. [Specific action step 2]
|
||||
3. [Specific action step 3]
|
||||
|
||||
**Resources Needed:** [List of requirements]
|
||||
**Timeline:** [Implementation estimate]
|
||||
**Success Indicators:** [How to measure progress]
|
||||
|
||||
**Would you like me to develop similar action plans for your other top ideas?**"
|
||||
|
||||
### 6. Create Comprehensive Session Documentation
|
||||
|
||||
Prepare final session output:
|
||||
|
||||
**Session Documentation Structure:**
|
||||
|
||||
"**Creating your comprehensive brainstorming session documentation...**
|
||||
|
||||
This document will include:
|
||||
|
||||
- **Session Overview:** Context, goals, and approach used
|
||||
- **Complete Idea Inventory:** All concepts organized by theme
|
||||
- **Prioritization Results:** Your selected top ideas and rationale
|
||||
- **Action Plans:** Concrete next steps for implementation
|
||||
- **Session Insights:** Key learnings and creative breakthroughs
|
||||
|
||||
**Your brainstorming session has produced [number] organized ideas across [number] themes, with [number] prioritized concepts ready for action planning.**"
|
||||
|
||||
**Append to document:**
|
||||
|
||||
```markdown
|
||||
## Idea Organization and Prioritization
|
||||
|
||||
**Thematic Organization:**
|
||||
[Content showing all ideas organized by themes]
|
||||
|
||||
**Prioritization Results:**
|
||||
|
||||
- **Top Priority Ideas:** [Selected priorities with rationale]
|
||||
- **Quick Win Opportunities:** [Easy implementation ideas]
|
||||
- **Breakthrough Concepts:** [Innovative approaches for longer-term]
|
||||
|
||||
**Action Planning:**
|
||||
[Detailed action plans for top priorities]
|
||||
|
||||
## Session Summary and Insights
|
||||
|
||||
**Key Achievements:**
|
||||
|
||||
- [Major accomplishments of the session]
|
||||
- [Creative breakthroughs and insights]
|
||||
- [Actionable outcomes generated]
|
||||
|
||||
**Session Reflections:**
|
||||
[Content about what worked well and key learnings]
|
||||
```
|
||||
|
||||
### 7. Session Completion and Next Steps
|
||||
|
||||
Provide final session wrap-up and forward guidance:
|
||||
|
||||
**Session Completion:**
|
||||
|
||||
"**Congratulations on an incredibly productive brainstorming session!**
|
||||
|
||||
**Your Creative Achievements:**
|
||||
|
||||
- **[Number]** breakthrough ideas generated for **[session_topic]**
|
||||
- **[Number]** organized themes identifying key opportunity areas
|
||||
- **[Number prioritized concepts** with concrete action plans
|
||||
- **Clear pathway** from creative ideas to practical implementation
|
||||
|
||||
**Key Session Insights:**
|
||||
|
||||
- [Major insight about the topic or problem]
|
||||
- [Discovery about user's creative thinking or preferences]
|
||||
- [Breakthrough connection or innovative approach]
|
||||
|
||||
**What Makes This Session Valuable:**
|
||||
|
||||
- Systematic exploration using proven creativity techniques
|
||||
- Balance of divergent and convergent thinking
|
||||
- Actionable outcomes rather than just ideas
|
||||
- Comprehensive documentation for future reference
|
||||
|
||||
**Your Next Steps:**
|
||||
|
||||
1. **Review** your session document when you receive it
|
||||
2. **Begin** with your top priority action steps this week
|
||||
3. **Share** promising concepts with stakeholders if relevant
|
||||
4. **Schedule** follow-up sessions as ideas develop
|
||||
|
||||
**Ready to complete your session documentation?**
|
||||
[C] Complete - Generate final brainstorming session document
|
||||
|
||||
**HALT — wait for user selection before proceeding.**
|
||||
|
||||
### 8. Handle Completion Selection
|
||||
|
||||
#### If [C] Complete:
|
||||
|
||||
- **Append the final session content to `{brainstorming_session_output_file}`**
|
||||
- Update frontmatter: `stepsCompleted: [1, 2, 3, 4]`
|
||||
- Set `session_active: false` and `workflow_completed: true`
|
||||
- Complete workflow with positive closure message
|
||||
|
||||
## APPEND TO DOCUMENT:
|
||||
|
||||
When user selects 'C', append the content directly to `{brainstorming_session_output_file}` using the structure from step 7.
|
||||
|
||||
## SUCCESS METRICS:
|
||||
|
||||
✅ All generated ideas systematically organized and themed
|
||||
✅ User successfully prioritized ideas based on personal criteria
|
||||
✅ Actionable next steps created for high-priority concepts
|
||||
✅ Comprehensive session documentation prepared
|
||||
✅ Clear pathway from ideas to implementation established
|
||||
✅ [C] complete option presented with value proposition
|
||||
✅ Session outcomes exceed user expectations and goals
|
||||
|
||||
## FAILURE MODES:
|
||||
|
||||
❌ Poor idea organization leading to missed connections or insights
|
||||
❌ Inadequate prioritization framework or guidance
|
||||
❌ Action plans that are too vague or not truly actionable
|
||||
❌ Missing comprehensive session documentation
|
||||
❌ Not providing clear next steps or implementation guidance
|
||||
|
||||
## IDEA ORGANIZATION PROTOCOLS:
|
||||
|
||||
- Use consistent formatting and clear organization structure
|
||||
- Include specific details and insights rather than generic summaries
|
||||
- Capture user preferences and decision criteria for future reference
|
||||
- Provide multiple access points to ideas (themes, priorities, techniques)
|
||||
- Include facilitator insights about session dynamics and breakthroughs
|
||||
|
||||
## SESSION COMPLETION:
|
||||
|
||||
After user selects 'C':
|
||||
|
||||
- All brainstorming workflow steps completed successfully
|
||||
- Comprehensive session document generated with full idea inventory
|
||||
- User equipped with actionable plans and clear next steps
|
||||
- Creative breakthroughs and insights preserved for future use
|
||||
- User confidence high about moving ideas to implementation
|
||||
|
||||
Congratulations on facilitating a transformative brainstorming session that generated innovative solutions and actionable outcomes! 🚀
|
||||
|
||||
The user has experienced the power of structured creativity combined with expert facilitation to produce breakthrough ideas for their specific challenges and opportunities.
|
||||
|
|
@ -1,15 +0,0 @@
|
|||
---
|
||||
stepsCompleted: []
|
||||
inputDocuments: []
|
||||
session_topic: ''
|
||||
session_goals: ''
|
||||
selected_approach: ''
|
||||
techniques_used: []
|
||||
ideas_generated: []
|
||||
context_file: ''
|
||||
---
|
||||
|
||||
# Brainstorming Session Results
|
||||
|
||||
**Facilitator:** {{user_name}}
|
||||
**Date:** {{date}}
|
||||
|
|
@ -1,53 +0,0 @@
|
|||
---
|
||||
context_file: '' # Optional context file path for project-specific guidance
|
||||
---
|
||||
|
||||
# Brainstorming Session Workflow
|
||||
|
||||
**Goal:** Facilitate interactive brainstorming sessions using diverse creative techniques and ideation methods
|
||||
|
||||
**Your Role:** You are a brainstorming facilitator and creative thinking guide. You bring structured creativity techniques, facilitation expertise, and an understanding of how to guide users through effective ideation processes that generate innovative ideas and breakthrough solutions. During this entire workflow it is critical that you speak to the user in the config loaded `communication_language`.
|
||||
|
||||
**Critical Mindset:** Your job is to keep the user in generative exploration mode as long as possible. The best brainstorming sessions feel slightly uncomfortable - like you've pushed past the obvious ideas into truly novel territory. Resist the urge to organize or conclude. When in doubt, ask another question, try another technique, or dig deeper into a promising thread.
|
||||
|
||||
**Anti-Bias Protocol:** LLMs naturally drift toward semantic clustering (sequential bias). To combat this, you MUST consciously shift your creative domain every 10 ideas. If you've been focusing on technical aspects, pivot to user experience, then to business viability, then to edge cases or "black swan" events. Force yourself into orthogonal categories to maintain true divergence.
|
||||
|
||||
**Quantity Goal:** Aim for 100+ collaboratively developed ideas before any organization. This is a session goal, not a request to generate a large list. Ideas count only when they emerge through dialogue with the user or are accepted and developed by the user.
|
||||
|
||||
---
|
||||
|
||||
## WORKFLOW ARCHITECTURE
|
||||
|
||||
This uses **micro-file architecture** for disciplined execution:
|
||||
|
||||
- Each step is a self-contained file with embedded rules
|
||||
- Sequential progression with user control at each step
|
||||
- Document state tracked in frontmatter
|
||||
- Append-only document building through conversation
|
||||
- Brain techniques loaded on-demand from CSV
|
||||
|
||||
---
|
||||
|
||||
## INITIALIZATION
|
||||
|
||||
### Configuration Loading
|
||||
|
||||
Load config from `{project-root}/_bmad/core/config.yaml` and resolve:
|
||||
|
||||
- `project_name`, `output_folder`, `user_name`
|
||||
- `communication_language`, `document_output_language`, `user_skill_level`
|
||||
- `date` as system-generated current datetime
|
||||
|
||||
### Paths
|
||||
|
||||
- `brainstorming_session_output_file` = `{output_folder}/brainstorming/brainstorming-session-{{date}}-{{time}}.md` (evaluated once at workflow start)
|
||||
|
||||
All steps MUST reference `{brainstorming_session_output_file}` instead of the full path pattern.
|
||||
- `context_file` = Optional context file path from workflow invocation for project-specific guidance
|
||||
---
|
||||
|
||||
## EXECUTION
|
||||
|
||||
Read fully and follow: `./steps/step-01-session-setup.md` to begin the workflow.
|
||||
|
||||
**Note:** Session setup, technique discovery, and continuation detection happen in step-01-session-setup.md.
|
||||
|
|
@ -94,53 +94,78 @@ export default defineConfig({
|
|||
sidebar: [
|
||||
{
|
||||
label: 'Welcome',
|
||||
translations: { 'vi-VN': 'Chào mừng', 'zh-CN': '欢迎', 'fr-FR': 'Bienvenue', 'cs-CZ': 'Vítejte' },
|
||||
translations: { 'ko-KR': '환영합니다', 'vi-VN': 'Chào mừng', 'zh-CN': '欢迎', 'fr-FR': 'Bienvenue', 'cs-CZ': 'Vítejte' },
|
||||
slug: 'index',
|
||||
},
|
||||
{
|
||||
label: 'Roadmap',
|
||||
translations: { 'vi-VN': 'Lộ trình', 'zh-CN': '路线图', 'fr-FR': 'Feuille de route', 'cs-CZ': 'Plán rozvoje' },
|
||||
translations: { 'ko-KR': '로드맵', 'vi-VN': 'Lộ trình', 'zh-CN': '路线图', 'fr-FR': 'Feuille de route', 'cs-CZ': 'Plán rozvoje' },
|
||||
slug: 'roadmap',
|
||||
},
|
||||
{
|
||||
label: 'Tutorials',
|
||||
translations: { 'vi-VN': 'Hướng dẫn nhập môn', 'zh-CN': '教程', 'fr-FR': 'Tutoriels', 'cs-CZ': 'Tutoriály' },
|
||||
translations: { 'ko-KR': '튜토리얼', 'vi-VN': 'Hướng dẫn nhập môn', 'zh-CN': '教程', 'fr-FR': 'Tutoriels', 'cs-CZ': 'Tutoriály' },
|
||||
collapsed: false,
|
||||
autogenerate: { directory: 'tutorials' },
|
||||
},
|
||||
{
|
||||
label: 'How-To Guides',
|
||||
translations: { 'vi-VN': 'Hướng dẫn tác vụ', 'zh-CN': '操作指南', 'fr-FR': 'Guides pratiques', 'cs-CZ': 'Praktické návody' },
|
||||
translations: {
|
||||
'ko-KR': '사용 가이드',
|
||||
'vi-VN': 'Hướng dẫn tác vụ',
|
||||
'zh-CN': '操作指南',
|
||||
'fr-FR': 'Guides pratiques',
|
||||
'cs-CZ': 'Praktické návody',
|
||||
},
|
||||
collapsed: true,
|
||||
autogenerate: { directory: 'how-to' },
|
||||
},
|
||||
{
|
||||
label: 'Explanation',
|
||||
translations: { 'vi-VN': 'Giải thích', 'zh-CN': '概念说明', 'fr-FR': 'Explications', 'cs-CZ': 'Vysvětlení' },
|
||||
translations: {
|
||||
'ko-KR': '개념 설명',
|
||||
'vi-VN': 'Giải thích',
|
||||
'zh-CN': '概念说明',
|
||||
'fr-FR': 'Explications',
|
||||
'cs-CZ': 'Vysvětlení',
|
||||
},
|
||||
collapsed: true,
|
||||
autogenerate: { directory: 'explanation' },
|
||||
},
|
||||
{
|
||||
label: 'Reference',
|
||||
translations: { 'vi-VN': 'Tham chiếu', 'zh-CN': '参考', 'fr-FR': 'Référence', 'cs-CZ': 'Reference' },
|
||||
translations: { 'ko-KR': '참조', 'vi-VN': 'Tham chiếu', 'zh-CN': '参考', 'fr-FR': 'Référence', 'cs-CZ': 'Reference' },
|
||||
collapsed: true,
|
||||
autogenerate: { directory: 'reference' },
|
||||
},
|
||||
// TEA docs moved to standalone module site; keep BMM sidebar focused.
|
||||
{
|
||||
label: 'BMad Ecosystem',
|
||||
translations: { 'vi-VN': 'Hệ sinh thái BMad', 'zh-CN': 'BMad 生态系统', 'fr-FR': 'Écosystème BMad', 'cs-CZ': 'Ekosystém BMad' },
|
||||
translations: {
|
||||
'ko-KR': 'BMad 생태계',
|
||||
'vi-VN': 'Hệ sinh thái BMad',
|
||||
'zh-CN': 'BMad 生态系统',
|
||||
'fr-FR': 'Écosystème BMad',
|
||||
'cs-CZ': 'Ekosystém BMad',
|
||||
},
|
||||
collapsed: false,
|
||||
items: [
|
||||
{
|
||||
label: 'BMad Builder',
|
||||
translations: { 'vi-VN': 'BMad Builder', 'zh-CN': 'BMad 构建器', 'fr-FR': 'BMad Builder', 'cs-CZ': 'BMad Builder' },
|
||||
translations: {
|
||||
'ko-KR': 'BMad Builder',
|
||||
'vi-VN': 'BMad Builder',
|
||||
'zh-CN': 'BMad 构建器',
|
||||
'fr-FR': 'BMad Builder',
|
||||
'cs-CZ': 'BMad Builder',
|
||||
},
|
||||
link: 'https://bmad-builder-docs.bmad-method.org/',
|
||||
attrs: { target: '_blank' },
|
||||
},
|
||||
{
|
||||
label: 'Creative Intelligence Suite',
|
||||
translations: {
|
||||
'ko-KR': '창의적 지능 제품군',
|
||||
'vi-VN': 'Bộ công cụ Trí tuệ Sáng tạo',
|
||||
'zh-CN': '创意智能套件',
|
||||
'fr-FR': "Suite d'Intelligence Créative",
|
||||
|
|
@ -152,6 +177,7 @@ export default defineConfig({
|
|||
{
|
||||
label: 'Game Dev Studio',
|
||||
translations: {
|
||||
'ko-KR': '게임 개발 스튜디오',
|
||||
'vi-VN': 'Xưởng phát triển Game',
|
||||
'zh-CN': '游戏开发工作室',
|
||||
'fr-FR': 'Studio de Développement de Jeux',
|
||||
|
|
@ -163,6 +189,7 @@ export default defineConfig({
|
|||
{
|
||||
label: 'Test Architect (TEA)',
|
||||
translations: {
|
||||
'ko-KR': '테스트 설계자(TEA)',
|
||||
'vi-VN': 'Kiến trúc sư Kiểm thử (TEA)',
|
||||
'zh-CN': '测试架构师 (TEA)',
|
||||
'fr-FR': 'Architecte de Tests (TEA)',
|
||||
|
|
|
|||
|
|
@ -0,0 +1,644 @@
|
|||
<!doctype html>
|
||||
<html lang="ko-KR">
|
||||
<head>
|
||||
<meta charset="UTF-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<title>BMad Method 워크플로 맵</title>
|
||||
<style>
|
||||
:root {
|
||||
--analysis: #0ea5e9;
|
||||
--planning: #22c55e;
|
||||
--solutioning: #eab308;
|
||||
--implementation: #ef4444;
|
||||
--quickflow: #64748b;
|
||||
--bg: #0f172a;
|
||||
--card: #1e293b;
|
||||
--text: #f8fafc;
|
||||
--text-muted: #94a3b8;
|
||||
--border: #334155;
|
||||
--success: #10b981;
|
||||
--arrow: #f59e0b;
|
||||
}
|
||||
* {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
body {
|
||||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
|
||||
background: var(--bg);
|
||||
color: var(--text);
|
||||
line-height: 1.4;
|
||||
padding: 12px;
|
||||
}
|
||||
.header {
|
||||
text-align: center;
|
||||
margin-bottom: 16px;
|
||||
}
|
||||
.header-badge {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: 6px;
|
||||
background: linear-gradient(135deg, var(--analysis), var(--planning));
|
||||
padding: 4px 12px;
|
||||
border-radius: 20px;
|
||||
font-size: 0.75rem;
|
||||
font-weight: 600;
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
h1 {
|
||||
font-size: 1.5rem;
|
||||
font-weight: 700;
|
||||
}
|
||||
.subtitle {
|
||||
color: var(--text-muted);
|
||||
font-size: 0.8rem;
|
||||
}
|
||||
|
||||
.flow-legend {
|
||||
background: rgba(245, 158, 11, 0.1);
|
||||
border: 1px solid rgba(245, 158, 11, 0.3);
|
||||
border-radius: 8px;
|
||||
padding: 8px 12px;
|
||||
margin-bottom: 16px;
|
||||
text-align: center;
|
||||
font-size: 0.7rem;
|
||||
color: var(--arrow);
|
||||
}
|
||||
|
||||
.flow-grid {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
|
||||
gap: 8px;
|
||||
margin-bottom: 16px;
|
||||
}
|
||||
|
||||
.phase {
|
||||
background: var(--card);
|
||||
border-radius: 10px;
|
||||
border: 1px solid var(--border);
|
||||
border-top: 3px solid;
|
||||
}
|
||||
.phase.analysis {
|
||||
border-top-color: var(--analysis);
|
||||
}
|
||||
.phase.planning {
|
||||
border-top-color: var(--planning);
|
||||
}
|
||||
.phase.solutioning {
|
||||
border-top-color: var(--solutioning);
|
||||
}
|
||||
.phase.implementation {
|
||||
border-top-color: var(--implementation);
|
||||
}
|
||||
|
||||
.phase-header {
|
||||
padding: 10px 12px 8px;
|
||||
border-bottom: 1px solid var(--border);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
}
|
||||
.phase-num {
|
||||
width: 22px;
|
||||
height: 22px;
|
||||
border-radius: 6px;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
font-size: 0.75rem;
|
||||
font-weight: 700;
|
||||
}
|
||||
.analysis .phase-num {
|
||||
background: var(--analysis);
|
||||
}
|
||||
.planning .phase-num {
|
||||
background: var(--planning);
|
||||
}
|
||||
.solutioning .phase-num {
|
||||
background: var(--solutioning);
|
||||
color: #000;
|
||||
}
|
||||
.implementation .phase-num {
|
||||
background: var(--implementation);
|
||||
}
|
||||
.phase-title {
|
||||
font-size: 0.95rem;
|
||||
font-weight: 700;
|
||||
}
|
||||
.phase-opt {
|
||||
font-size: 0.6rem;
|
||||
padding: 2px 6px;
|
||||
border-radius: 4px;
|
||||
background: rgba(14, 165, 233, 0.2);
|
||||
color: #7dd3fc;
|
||||
}
|
||||
|
||||
.workflows {
|
||||
padding: 8px 10px;
|
||||
}
|
||||
|
||||
.workflow {
|
||||
background: rgba(255, 255, 255, 0.03);
|
||||
border-radius: 6px;
|
||||
padding: 8px;
|
||||
margin-bottom: 6px;
|
||||
font-size: 0.7rem;
|
||||
}
|
||||
.workflow-header {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
margin-bottom: 4px;
|
||||
}
|
||||
.workflow-name {
|
||||
font-family: monospace;
|
||||
color: var(--success);
|
||||
background: rgba(16, 185, 129, 0.1);
|
||||
padding: 2px 6px;
|
||||
border-radius: 3px;
|
||||
font-size: 0.65rem;
|
||||
}
|
||||
.workflow-meta {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
}
|
||||
.agent {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 4px;
|
||||
}
|
||||
.agent-icon {
|
||||
width: 14px;
|
||||
height: 14px;
|
||||
border-radius: 3px;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
font-size: 0.55rem;
|
||||
font-weight: 700;
|
||||
}
|
||||
.agent-icon.mary {
|
||||
background: linear-gradient(135deg, #f472b6, #ec4899);
|
||||
}
|
||||
.agent-icon.john {
|
||||
background: linear-gradient(135deg, #60a5fa, #3b82f6);
|
||||
}
|
||||
.agent-icon.sally {
|
||||
background: linear-gradient(135deg, #fbbf24, #f59e0b);
|
||||
color: #000;
|
||||
}
|
||||
.agent-icon.winston {
|
||||
background: linear-gradient(135deg, #a78bfa, #8b5cf6);
|
||||
}
|
||||
.agent-icon.amelia {
|
||||
background: linear-gradient(135deg, #fb7185, #ef4444);
|
||||
}
|
||||
|
||||
.agent-name {
|
||||
font-size: 0.65rem;
|
||||
}
|
||||
.output {
|
||||
color: var(--success);
|
||||
font-family: monospace;
|
||||
font-size: 0.6rem;
|
||||
}
|
||||
.badge {
|
||||
font-size: 0.55rem;
|
||||
padding: 1px 4px;
|
||||
border-radius: 3px;
|
||||
}
|
||||
.badge.opt {
|
||||
background: rgba(251, 191, 36, 0.15);
|
||||
color: #fbbf24;
|
||||
}
|
||||
.badge.iffy {
|
||||
background: rgba(168, 85, 247, 0.15);
|
||||
color: #a855f7;
|
||||
}
|
||||
.badge.adhoc {
|
||||
background: rgba(59, 130, 246, 0.15);
|
||||
color: #3b82f6;
|
||||
}
|
||||
|
||||
.arrow {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
color: var(--arrow);
|
||||
font-size: 0.9rem;
|
||||
margin: 6px 0;
|
||||
}
|
||||
|
||||
.decision {
|
||||
background: linear-gradient(135deg, #a855f7, #9333ea);
|
||||
padding: 4px 8px;
|
||||
border-radius: 4px;
|
||||
text-align: center;
|
||||
font-size: 0.65rem;
|
||||
font-weight: 600;
|
||||
margin: 6px 0;
|
||||
}
|
||||
|
||||
.quickflow {
|
||||
background: rgba(100, 116, 139, 0.2);
|
||||
border: 2px dashed var(--quickflow);
|
||||
border-radius: 10px;
|
||||
padding: 12px;
|
||||
margin-bottom: 16px;
|
||||
}
|
||||
.quickflow-header {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
.quickflow-header h2 {
|
||||
font-size: 0.95rem;
|
||||
}
|
||||
.quickflow-header span {
|
||||
font-size: 0.7rem;
|
||||
color: var(--text-muted);
|
||||
}
|
||||
.quickflow-body {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 12px;
|
||||
}
|
||||
.quickflow-item {
|
||||
flex: 1;
|
||||
background: rgba(255, 255, 255, 0.03);
|
||||
border-radius: 8px;
|
||||
padding: 10px;
|
||||
}
|
||||
.quickflow-item code {
|
||||
font-family: monospace;
|
||||
color: var(--success);
|
||||
background: rgba(16, 185, 129, 0.1);
|
||||
padding: 2px 6px;
|
||||
border-radius: 3px;
|
||||
font-size: 0.7rem;
|
||||
}
|
||||
|
||||
.context {
|
||||
background: rgba(14, 165, 233, 0.08);
|
||||
border-radius: 10px;
|
||||
padding: 12px;
|
||||
font-size: 0.75rem;
|
||||
}
|
||||
.context-header {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
margin-bottom: 6px;
|
||||
font-weight: 600;
|
||||
}
|
||||
.context-items {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: 6px;
|
||||
}
|
||||
.context-items code {
|
||||
font-family: monospace;
|
||||
color: var(--success);
|
||||
background: rgba(16, 185, 129, 0.1);
|
||||
padding: 2px 5px;
|
||||
border-radius: 3px;
|
||||
font-size: 0.65rem;
|
||||
}
|
||||
.context-items span {
|
||||
color: var(--text-muted);
|
||||
}
|
||||
|
||||
.legend {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
gap: 12px;
|
||||
flex-wrap: wrap;
|
||||
font-size: 0.7rem;
|
||||
margin-top: 12px;
|
||||
}
|
||||
.legend-item {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 4px;
|
||||
}
|
||||
.legend-dot {
|
||||
width: 12px;
|
||||
height: 3px;
|
||||
border-radius: 2px;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="header">
|
||||
<div class="header-badge">⚡ 워크플로 맵 V6</div>
|
||||
<h1>BMad Method</h1>
|
||||
<p class="subtitle">AI 기반 개발을 위한 컨텍스트 엔지니어링</p>
|
||||
</div>
|
||||
|
||||
<div class="flow-legend">→ 화살표는 워크플로 간 산출물 흐름을 나타냅니다</div>
|
||||
|
||||
<div class="flow-grid">
|
||||
<!-- Phase 1: Analysis -->
|
||||
<div class="phase analysis">
|
||||
<div class="phase-header">
|
||||
<div class="phase-num">1</div>
|
||||
<div class="phase-title">분석</div>
|
||||
<span class="phase-opt">선택 사항</span>
|
||||
</div>
|
||||
<div class="workflows">
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">brainstorm</span>
|
||||
<span class="badge opt">선택</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon mary">M</div>
|
||||
<span class="agent-name">Mary</span>
|
||||
</div>
|
||||
<span class="output">brainstorming-report.md</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">research</span>
|
||||
<span class="badge opt">선택</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon mary">M</div>
|
||||
<span class="agent-name">Mary</span>
|
||||
</div>
|
||||
<span class="output">리서치 결과</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">product-brief</span>
|
||||
<span class="badge opt">또는 ↓</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon mary">M</div>
|
||||
<span class="agent-name">Mary</span>
|
||||
</div>
|
||||
<span class="output">product-brief.md →</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">prfaq</span>
|
||||
<span class="badge opt">또는 ↑</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon mary">M</div>
|
||||
<span class="agent-name">Mary</span>
|
||||
</div>
|
||||
<span class="output">prfaq.md →</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="arrow">→</div>
|
||||
</div>
|
||||
|
||||
<!-- Phase 2: Planning -->
|
||||
<div class="phase planning">
|
||||
<div class="phase-header">
|
||||
<div class="phase-num">2</div>
|
||||
<div class="phase-title">계획</div>
|
||||
</div>
|
||||
<div class="workflows">
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">prd</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon john">J</div>
|
||||
<span class="agent-name">Any</span>
|
||||
</div>
|
||||
<span class="output">prd.md →</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="decision">UI가 있나요?</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">create-ux-design</span>
|
||||
<span class="badge iffy">예</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon sally">S</div>
|
||||
<span class="agent-name">Sally</span>
|
||||
</div>
|
||||
<span class="output">ux-spec.md →</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="arrow">→</div>
|
||||
</div>
|
||||
|
||||
<!-- Phase 3: Solutioning -->
|
||||
<div class="phase solutioning">
|
||||
<div class="phase-header">
|
||||
<div class="phase-num">3</div>
|
||||
<div class="phase-title">솔루션 설계</div>
|
||||
</div>
|
||||
<div class="workflows">
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">create-architecture</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon winston">W</div>
|
||||
<span class="agent-name">Winston</span>
|
||||
</div>
|
||||
<span class="output">architecture.md →</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">create-epics-and-stories</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon john">J</div>
|
||||
<span class="agent-name">John</span>
|
||||
</div>
|
||||
<span class="output">epics.md →</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">check-implementation-readiness</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon john">J</div>
|
||||
<span class="agent-name">John</span>
|
||||
</div>
|
||||
<span class="output">구현 착수 전 준비도 점검</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="arrow">→</div>
|
||||
</div>
|
||||
|
||||
<!-- Phase 4: Implementation -->
|
||||
<div class="phase implementation">
|
||||
<div class="phase-header">
|
||||
<div class="phase-num">4</div>
|
||||
<div class="phase-title">구현</div>
|
||||
</div>
|
||||
<div class="workflows">
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">sprint-planning</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon amelia">A</div>
|
||||
<span class="agent-name">Amelia</span>
|
||||
</div>
|
||||
<span class="output">sprint-status.yaml →</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">create-story</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon amelia">A</div>
|
||||
<span class="agent-name">Amelia</span>
|
||||
</div>
|
||||
<span class="output">story-[slug].md →</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">dev-story</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon amelia">A</div>
|
||||
<span class="agent-name">Amelia</span>
|
||||
</div>
|
||||
<span class="output">코드 →</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">code-review</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon amelia">A</div>
|
||||
<span class="agent-name">Amelia</span>
|
||||
</div>
|
||||
<span class="output">승인</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">correct-course</span>
|
||||
<span class="badge adhoc">필요 시</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon john">J</div>
|
||||
<span class="agent-name">John</span>
|
||||
</div>
|
||||
<span class="output">계획 업데이트</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">retrospective</span>
|
||||
<span class="badge adhoc">에픽 별</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon amelia">A</div>
|
||||
<span class="agent-name">Amelia</span>
|
||||
</div>
|
||||
<span class="output">배운 점</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="workflow">
|
||||
<div class="workflow-header">
|
||||
<span class="workflow-name">investigate</span>
|
||||
<span class="badge adhoc">언제든지</span>
|
||||
</div>
|
||||
<div class="workflow-meta">
|
||||
<div class="agent">
|
||||
<div class="agent-icon amelia">A</div>
|
||||
<span class="agent-name">Amelia</span>
|
||||
</div>
|
||||
<span class="output">사례 파일</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="quickflow">
|
||||
<div class="quickflow-header">
|
||||
<span>⚡</span>
|
||||
<div>
|
||||
<h2>Quick Flow (병렬 트랙)</h2>
|
||||
<span>범위가 작고 명확한 변경에 사용됩니다 — 1~3단계를 건너뜁니다</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="quickflow-body">
|
||||
<div class="quickflow-item">
|
||||
<div class="agent">
|
||||
<div class="agent-icon amelia">A</div>
|
||||
<span class="agent-name">Amelia</span>
|
||||
</div>
|
||||
<code>quick-dev</code>
|
||||
<div style="font-size: 0.65rem; color: var(--text-muted); margin-top: 4px">의도 → 기술 명세 → 동작하는 코드</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="context">
|
||||
<div class="context-header">📚 컨텍스트 흐름</div>
|
||||
<p style="margin-bottom: 8px; color: var(--text-muted)">각 문서는 다음 단계의 컨텍스트가 됩니다.</p>
|
||||
<div class="context-items">
|
||||
<span><code>create-story</code> <span>에픽, PRD, 아키텍처, UX를 로드</span></span>
|
||||
<span><code>dev-story</code> <span>스토리 파일을 로드</span></span>
|
||||
<span><code>code-review</code> <span>아키텍처와 스토리를 로드</span></span>
|
||||
<span><code>quick-dev</code> <span>명확화, 계획, 구현, 리뷰</span></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="legend">
|
||||
<div class="legend-item">
|
||||
<div class="legend-dot" style="background: var(--analysis)"></div>
|
||||
분석
|
||||
</div>
|
||||
<div class="legend-item">
|
||||
<div class="legend-dot" style="background: var(--planning)"></div>
|
||||
계획
|
||||
</div>
|
||||
<div class="legend-item">
|
||||
<div class="legend-dot" style="background: var(--solutioning)"></div>
|
||||
솔루션 설계
|
||||
</div>
|
||||
<div class="legend-item">
|
||||
<div class="legend-dot" style="background: var(--implementation)"></div>
|
||||
구현
|
||||
</div>
|
||||
<div class="legend-item">
|
||||
<div class="legend-dot" style="background: var(--quickflow)"></div>
|
||||
빠른 흐름
|
||||
</div>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
|
|
@ -2,13 +2,102 @@
|
|||
import { getSiteUrl } from '../lib/site-url.mjs';
|
||||
|
||||
const llmsFullUrl = `${getSiteUrl()}/llms-full.txt`;
|
||||
const bannerCopy = {
|
||||
root: {
|
||||
aiLabel: 'AI documentation notice',
|
||||
aiPrefix: 'Consolidated, AI-optimized BMAD docs:',
|
||||
aiLinkGap: ' ',
|
||||
aiSuffix: 'Fetch this plain text file for complete context.',
|
||||
announceLabel: 'BMad Builder announcement',
|
||||
announcePrefix: 'Build your own BMad modules and share them with the community!',
|
||||
announceLinkGap: ' ',
|
||||
getStarted: 'Get started',
|
||||
connectorBefore: ' ',
|
||||
connector: 'or',
|
||||
connectorAfter: ' ',
|
||||
submit: 'submit to the marketplace',
|
||||
},
|
||||
'ko-kr': {
|
||||
aiLabel: 'AI 문서 안내',
|
||||
aiPrefix: 'AI에 최적화된 통합 BMAD 문서:',
|
||||
aiLinkGap: ' ',
|
||||
aiSuffix: '전체 컨텍스트가 필요하면 이 일반 텍스트 파일을 가져오세요.',
|
||||
announceLabel: 'BMad Builder 공지',
|
||||
announcePrefix: '나만의 BMad 모듈을 만들고 커뮤니티와 공유하세요!',
|
||||
announceLinkGap: ' ',
|
||||
getStarted: '시작하기',
|
||||
connectorBefore: ' ',
|
||||
connector: '또는',
|
||||
connectorAfter: ' ',
|
||||
submit: '마켓플레이스에 제출하기',
|
||||
},
|
||||
'vi-vn': {
|
||||
aiLabel: 'Thông báo tài liệu AI',
|
||||
aiPrefix: 'Tài liệu BMAD hợp nhất, tối ưu cho AI:',
|
||||
aiLinkGap: ' ',
|
||||
aiSuffix: 'Lấy tệp văn bản thuần này để có đầy đủ ngữ cảnh.',
|
||||
announceLabel: 'Thông báo BMad Builder',
|
||||
announcePrefix: 'Xây dựng các mô-đun BMad của riêng bạn và chia sẻ với cộng đồng!',
|
||||
announceLinkGap: ' ',
|
||||
getStarted: 'Bắt đầu',
|
||||
connectorBefore: ' ',
|
||||
connector: 'hoặc',
|
||||
connectorAfter: ' ',
|
||||
submit: 'gửi lên marketplace',
|
||||
},
|
||||
'zh-cn': {
|
||||
aiLabel: 'AI 文档提示',
|
||||
aiPrefix: '整合的 AI 优化 BMAD 文档:',
|
||||
aiLinkGap: '',
|
||||
aiSuffix: '获取此纯文本文件以获得完整上下文。',
|
||||
announceLabel: 'BMad Builder 公告',
|
||||
announcePrefix: '构建你自己的 BMad 模块并与社区分享!',
|
||||
announceLinkGap: '',
|
||||
getStarted: '开始使用',
|
||||
connectorBefore: '',
|
||||
connector: '或',
|
||||
connectorAfter: '',
|
||||
submit: '提交到 marketplace',
|
||||
},
|
||||
fr: {
|
||||
aiLabel: 'Avis sur la documentation IA',
|
||||
aiPrefix: 'Documentation BMAD consolidée et optimisée pour l’IA :',
|
||||
aiLinkGap: ' ',
|
||||
aiSuffix: 'Récupérez ce fichier texte brut pour obtenir le contexte complet.',
|
||||
announceLabel: 'Annonce BMad Builder',
|
||||
announcePrefix: 'Créez vos propres modules BMad et partagez-les avec la communauté !',
|
||||
announceLinkGap: ' ',
|
||||
getStarted: 'Commencer',
|
||||
connectorBefore: ' ',
|
||||
connector: 'ou',
|
||||
connectorAfter: ' ',
|
||||
submit: 'soumettre au marketplace',
|
||||
},
|
||||
cs: {
|
||||
aiLabel: 'Upozornění k dokumentaci pro AI',
|
||||
aiPrefix: 'Konsolidovaná dokumentace BMAD optimalizovaná pro AI:',
|
||||
aiLinkGap: ' ',
|
||||
aiSuffix: 'Stáhněte si tento prostý textový soubor pro úplný kontext.',
|
||||
announceLabel: 'Oznámení BMad Builder',
|
||||
announcePrefix: 'Vytvářejte vlastní moduly BMad a sdílejte je s komunitou!',
|
||||
announceLinkGap: ' ',
|
||||
getStarted: 'Začít',
|
||||
connectorBefore: ' ',
|
||||
connector: 'nebo',
|
||||
connectorAfter: ' ',
|
||||
submit: 'odeslat na marketplace',
|
||||
},
|
||||
};
|
||||
const pathSegments = Astro.url.pathname.split('/').filter(Boolean);
|
||||
const locale = pathSegments.find((segment) => segment in bannerCopy) ?? 'root';
|
||||
const copy = bannerCopy[locale] ?? bannerCopy.root;
|
||||
---
|
||||
|
||||
<div class="ai-banner" role="note" aria-label="AI documentation notice">
|
||||
<span>🤖 Consolidated, AI-optimized BMAD docs: <a href={llmsFullUrl}>llms-full.txt</a>. Fetch this plain text file for complete context.</span>
|
||||
<div class="ai-banner" role="note" aria-label={copy.aiLabel}>
|
||||
<span>🤖 {copy.aiPrefix}{copy.aiLinkGap}<a href={llmsFullUrl}>llms-full.txt</a>. {copy.aiSuffix}</span>
|
||||
</div>
|
||||
<div class="announce-banner" role="note" aria-label="BMad Builder announcement">
|
||||
<span>🚀 Build your own BMad modules and share them with the community! <a href="https://bmad-builder-docs.bmad-method.org/tutorials/build-your-first-module/">Get started</a> or <a href="https://bmad-builder-docs.bmad-method.org/how-to/distribute-your-module/">submit to the marketplace</a>.</span>
|
||||
<div class="announce-banner" role="note" aria-label={copy.announceLabel}>
|
||||
<span>🚀 {copy.announcePrefix}{copy.announceLinkGap}<a href="https://bmad-builder-docs.bmad-method.org/tutorials/build-your-first-module/">{copy.getStarted}</a>{copy.connectorBefore}{copy.connector}{copy.connectorAfter}<a href="https://bmad-builder-docs.bmad-method.org/how-to/distribute-your-module/">{copy.submit}</a>.</span>
|
||||
</div>
|
||||
|
||||
<style>
|
||||
|
|
|
|||
|
|
@ -0,0 +1,28 @@
|
|||
{
|
||||
"skipLink.label": "본문으로 건너뛰기",
|
||||
"search.label": "검색",
|
||||
"search.ctrlKey": "Ctrl",
|
||||
"search.cancelLabel": "취소",
|
||||
"themeSelect.accessibleLabel": "테마 선택",
|
||||
"themeSelect.dark": "어둡게",
|
||||
"themeSelect.light": "밝게",
|
||||
"themeSelect.auto": "자동",
|
||||
"languageSelect.accessibleLabel": "언어 선택",
|
||||
"menuButton.accessibleLabel": "메뉴",
|
||||
"sidebarNav.accessibleLabel": "기본 탐색",
|
||||
"tableOfContents.onThisPage": "이 페이지에서",
|
||||
"tableOfContents.overview": "개요",
|
||||
"i18n.untranslatedContent": "이 콘텐츠는 아직 한국어로 제공되지 않습니다.",
|
||||
"page.editLink": "이 페이지 편집",
|
||||
"page.lastUpdated": "마지막 업데이트:",
|
||||
"page.previousLink": "이전 페이지",
|
||||
"page.nextLink": "다음 페이지",
|
||||
"page.draft": "이 콘텐츠는 초안 상태이며 공식 빌드에는 표시되지 않습니다.",
|
||||
"404.text": "페이지를 찾을 수 없습니다. 주소를 확인하거나 검색을 사용하세요.",
|
||||
"aside.note": "참고",
|
||||
"aside.tip": "팁",
|
||||
"aside.caution": "주의",
|
||||
"aside.danger": "경고",
|
||||
"fileTree.directory": "디렉터리",
|
||||
"builtWithStarlight.label": "Starlight로 제작"
|
||||
}
|
||||
|
|
@ -15,6 +15,10 @@ export const locales = {
|
|||
label: 'English',
|
||||
lang: 'en',
|
||||
},
|
||||
'ko-kr': {
|
||||
label: '한국어',
|
||||
lang: 'ko-KR',
|
||||
},
|
||||
'vi-vn': {
|
||||
label: 'Tiếng Việt',
|
||||
lang: 'vi-VN',
|
||||
|
|
|
|||
Loading…
Reference in New Issue