maskweaver 0.8.16 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.ko.md +640 -657
- package/README.md +672 -689
- package/assets/commands/meta/commands.json +254 -0
- package/assets/commands/weave-agents.md +62 -0
- package/assets/commands/weave-approve.md +61 -0
- package/assets/commands/weave-build.md +99 -0
- package/assets/commands/weave-help.md +112 -158
- package/assets/commands/weave-interview.md +121 -0
- package/assets/commands/weave-map.md +109 -0
- package/assets/commands/weave-troubleshoot.md +57 -0
- package/dist/plugin/index.d.ts +5 -1
- package/dist/plugin/index.d.ts.map +1 -1
- package/dist/plugin/index.js +20 -17
- package/dist/plugin/index.js.map +1 -1
- package/dist/plugin/tools/command-registry.d.ts +51 -0
- package/dist/plugin/tools/command-registry.d.ts.map +1 -0
- package/dist/plugin/tools/command-registry.js +348 -0
- package/dist/plugin/tools/command-registry.js.map +1 -0
- package/dist/plugin/tools/slashcommand.d.ts +1 -1
- package/dist/plugin/tools/slashcommand.d.ts.map +1 -1
- package/dist/plugin/tools/slashcommand.js +47 -193
- package/dist/plugin/tools/slashcommand.js.map +1 -1
- package/dist/plugin/tools/weave.d.ts +14 -35
- package/dist/plugin/tools/weave.d.ts.map +1 -1
- package/dist/plugin/tools/weave.js +247 -213
- package/dist/plugin/tools/weave.js.map +1 -1
- package/package.json +142 -142
- package/assets/commands/weave-approve-plan.md +0 -57
- package/assets/commands/weave-design.md +0 -296
- package/assets/commands/weave-flow.md +0 -48
- package/assets/commands/weave-plan.md +0 -15
- package/assets/commands/weave-research.md +0 -51
- package/assets/commands/weave-spec.md +0 -227
- package/assets/commands/weave-switch.md +0 -170
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: 문서 + 워크스페이스 맥락을 깊게 조사해 research.md 생성
|
|
3
|
-
---
|
|
4
|
-
|
|
5
|
-
# /weave-research - 리서치 아티팩트 생성
|
|
6
|
-
|
|
7
|
-
## 개요
|
|
8
|
-
|
|
9
|
-
`/weave-research`는 요구사항 문서와 현재 워크스페이스를 함께 조사해, 리뷰 가능한 리서치 문서를 생성합니다.
|
|
10
|
-
|
|
11
|
-
- 입력 문서를 분석해 핵심 기능/기술 신호를 추출
|
|
12
|
-
- 워크스페이스에서 관련 구현/중복 신호/재사용 후보를 조사
|
|
13
|
-
- 문제 재현 흐름(가능한 범위)과 전/후 맥락을 정리
|
|
14
|
-
- 열려 있는 질문과 환경 리스크를 정리
|
|
15
|
-
- `tasks/research.md`에 영속 아티팩트로 저장
|
|
16
|
-
|
|
17
|
-
> 구현 전에 리서치를 먼저 고정해두면, 이후 plan 품질과 수정 비용이 크게 줄어듭니다.
|
|
18
|
-
|
|
19
|
-
---
|
|
20
|
-
|
|
21
|
-
## 사용법
|
|
22
|
-
|
|
23
|
-
```txt
|
|
24
|
-
/weave-research $ARGUMENTS
|
|
25
|
-
```
|
|
26
|
-
|
|
27
|
-
`$ARGUMENTS`는 문서 경로입니다.
|
|
28
|
-
|
|
29
|
-
예시:
|
|
30
|
-
- `/weave-research docs/`
|
|
31
|
-
- `/weave-research wiki/spec.md`
|
|
32
|
-
|
|
33
|
-
---
|
|
34
|
-
|
|
35
|
-
## 내부 호출
|
|
36
|
-
|
|
37
|
-
```txt
|
|
38
|
-
weave command=research docsPath="$ARGUMENTS"
|
|
39
|
-
```
|
|
40
|
-
|
|
41
|
-
---
|
|
42
|
-
|
|
43
|
-
## 다음 단계
|
|
44
|
-
|
|
45
|
-
리서치 완료 후 권장 순서:
|
|
46
|
-
|
|
47
|
-
```txt
|
|
48
|
-
weave command=prepare docsPath="$ARGUMENTS"
|
|
49
|
-
weave command=approve-plan
|
|
50
|
-
weave command=craft
|
|
51
|
-
```
|
|
@@ -1,227 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: 요구사항 정제 및 검증 기준 추출
|
|
3
|
-
---
|
|
4
|
-
|
|
5
|
-
# /weave-spec - 요구사항 정제
|
|
6
|
-
|
|
7
|
-
## 개요
|
|
8
|
-
|
|
9
|
-
기획 문서나 자연어 요구사항을 **구조화된 명세**로 정제합니다.
|
|
10
|
-
각 요구사항에서 **검증 기준(Acceptance Criteria)**을 추출하여, 이후 구현 완료의 성공 판정 기준으로 사용합니다.
|
|
11
|
-
|
|
12
|
-
**입력 방식**: `/weave-design`과 동일
|
|
13
|
-
- 정확한 경로: `docs/`, `wiki/spec.md`
|
|
14
|
-
- 자연어 힌트: `기획 폴더`, `README`
|
|
15
|
-
|
|
16
|
-
> 이 커맨드는 **선택 사항**입니다. `/weave-design`을 바로 실행해도 됩니다.
|
|
17
|
-
> 요구사항이 복잡하거나, 구현 완료 기준을 명확히 하고 싶을 때 사용합니다.
|
|
18
|
-
|
|
19
|
-
---
|
|
20
|
-
|
|
21
|
-
## 실행
|
|
22
|
-
|
|
23
|
-
```txt
|
|
24
|
-
weave command=spec docsPath="$ARGUMENTS"
|
|
25
|
-
```
|
|
26
|
-
|
|
27
|
-
---
|
|
28
|
-
|
|
29
|
-
## 사전 조건
|
|
30
|
-
|
|
31
|
-
`/weave-init`이 실행되어 있어야 합니다.
|
|
32
|
-
실행되지 않았다면 자동으로 init을 먼저 수행합니다.
|
|
33
|
-
|
|
34
|
-
---
|
|
35
|
-
|
|
36
|
-
## 실행 흐름
|
|
37
|
-
|
|
38
|
-
```
|
|
39
|
-
0. INIT CHECK
|
|
40
|
-
↓
|
|
41
|
-
1. RESOLVE (입력 해석 → 실제 경로 찾기)
|
|
42
|
-
↓
|
|
43
|
-
2. ANALYZE (문서에서 요구사항 추출)
|
|
44
|
-
↓
|
|
45
|
-
3. STRUCTURE (요구사항 분류 + 검증 기준 도출)
|
|
46
|
-
↓
|
|
47
|
-
4. REVIEW (유저에게 제시 → 피드백)
|
|
48
|
-
↓
|
|
49
|
-
5. SAVE (스펙 파일 생성)
|
|
50
|
-
```
|
|
51
|
-
|
|
52
|
-
---
|
|
53
|
-
|
|
54
|
-
## 단계별 상세
|
|
55
|
-
|
|
56
|
-
### Step 0: INIT CHECK
|
|
57
|
-
|
|
58
|
-
`.opencode/weave/state.yaml` 존재 확인. 없으면 `/weave-init` 자동 실행.
|
|
59
|
-
|
|
60
|
-
### Step 1: RESOLVE
|
|
61
|
-
|
|
62
|
-
`/weave-design`과 동일한 경로 해석 로직. (정확한 경로, 디렉토리 힌트, 시간 힌트, 내용 힌트 등)
|
|
63
|
-
|
|
64
|
-
### Step 2: ANALYZE
|
|
65
|
-
|
|
66
|
-
**수행 작업**:
|
|
67
|
-
1. 해석된 경로의 모든 문서 읽기
|
|
68
|
-
2. 기능 요구사항과 비기능 요구사항 분리
|
|
69
|
-
3. 암묵적 요구사항 식별 (명시되지 않았지만 당연히 필요한 것)
|
|
70
|
-
4. 요구사항 간 의존관계 파악
|
|
71
|
-
5. 과거 유사 프로젝트 검색 (Memory 시스템)
|
|
72
|
-
|
|
73
|
-
### Step 3: STRUCTURE
|
|
74
|
-
|
|
75
|
-
각 요구사항을 정제하고, **검증 기준**을 도출합니다.
|
|
76
|
-
|
|
77
|
-
#### 요구사항 분류
|
|
78
|
-
|
|
79
|
-
| 분류 | 설명 | 예시 |
|
|
80
|
-
|------|------|------|
|
|
81
|
-
| `functional` | 시스템이 해야 하는 동작 | 사용자가 로그인할 수 있다 |
|
|
82
|
-
| `constraint` | 기술적/비즈니스 제약 | 데이터를 외부 서버로 전송하지 않는다 |
|
|
83
|
-
| `performance` | 성능 요구 | 목록 로딩 2초 이내 |
|
|
84
|
-
| `ux` | 사용성/접근성 요구 | 모바일에서도 사용 가능해야 한다 |
|
|
85
|
-
|
|
86
|
-
#### 우선순위 (MoSCoW)
|
|
87
|
-
|
|
88
|
-
| 값 | 의미 |
|
|
89
|
-
|----|------|
|
|
90
|
-
| `must` | 없으면 출시 불가 |
|
|
91
|
-
| `should` | 강력히 권장, 가능하면 포함 |
|
|
92
|
-
| `could` | 있으면 좋지만 없어도 됨 |
|
|
93
|
-
| `wont` | 이번 범위에서 명시적으로 제외 |
|
|
94
|
-
|
|
95
|
-
#### 검증 기준 유형
|
|
96
|
-
|
|
97
|
-
| type | 의미 | 실행 방법 |
|
|
98
|
-
|------|------|----------|
|
|
99
|
-
| `e2e` | 브라우저/UI 시나리오 테스트 | Playwright, Cypress 등 |
|
|
100
|
-
| `integration` | API/서비스 간 통합 테스트 | supertest, httpx, curl 등 |
|
|
101
|
-
| `script` | CLI/스크립트 실행 결과 확인 | shell script, node script |
|
|
102
|
-
| `performance` | 성능 기준 충족 | benchmark, lighthouse 등 |
|
|
103
|
-
| `manual` | 자동화 불가, 사용자 확인 | 체크리스트로 유저 핸드오프에 포함 |
|
|
104
|
-
|
|
105
|
-
#### 검증 기준 작성 원칙
|
|
106
|
-
|
|
107
|
-
- **모호하지 않을 것**: "잘 동작한다" ✗ → "저장 후 목록에서 확인 가능" ✓
|
|
108
|
-
- **실행 가능할 것**: 구체적인 입력과 기대 결과를 명시
|
|
109
|
-
- **독립적일 것**: 하나의 기준이 하나의 시나리오만 검증
|
|
110
|
-
- **유형은 정직하게**: E2E가 불가능한 것은 `manual`로. 억지로 자동화하지 않음
|
|
111
|
-
|
|
112
|
-
### Step 4: REVIEW
|
|
113
|
-
|
|
114
|
-
구조화된 명세를 유저에게 제시합니다:
|
|
115
|
-
|
|
116
|
-
```markdown
|
|
117
|
-
## 요구사항 명세
|
|
118
|
-
|
|
119
|
-
**스펙 이름**: `emotion-diary` (변경 가능)
|
|
120
|
-
|
|
121
|
-
### 기능 요구사항 (Functional)
|
|
122
|
-
|
|
123
|
-
**R1** [must]: 사용자가 감정을 선택하고 일기를 저장할 수 있다
|
|
124
|
-
- [e2e] 감정 선택 → 텍스트 입력 → 저장 → 목록에서 확인
|
|
125
|
-
- [e2e] 빈 텍스트로 저장 시도 → 에러 메시지 표시
|
|
126
|
-
|
|
127
|
-
**R2** [must]: 저장된 일기 목록을 조회할 수 있다
|
|
128
|
-
- [e2e] 저장된 일기 3개가 목록에 최신순으로 표시
|
|
129
|
-
|
|
130
|
-
### 비기능 요구사항
|
|
131
|
-
|
|
132
|
-
**R3** [should]: 일기 목록이 2초 이내에 로딩된다
|
|
133
|
-
- [performance] 100개 일기 기준 로딩 시간 < 2000ms
|
|
134
|
-
|
|
135
|
-
**R4** [could]: 오프라인에서도 저장된 일기를 조회할 수 있다
|
|
136
|
-
- [manual] 네트워크 차단 후 기존 일기 목록 접근 가능
|
|
137
|
-
|
|
138
|
-
---
|
|
139
|
-
빠진 요구사항이 있거나, 검증 기준을 수정하고 싶으면 말씀해주세요.
|
|
140
|
-
```
|
|
141
|
-
|
|
142
|
-
### Step 5: SAVE
|
|
143
|
-
|
|
144
|
-
유저 승인 시 스펙 파일을 생성합니다.
|
|
145
|
-
|
|
146
|
-
**파일 경로**: `.opencode/weave/specs/{spec-name}.yaml`
|
|
147
|
-
|
|
148
|
-
```yaml
|
|
149
|
-
spec_name: "emotion-diary"
|
|
150
|
-
project_name: "감정 일기 앱"
|
|
151
|
-
created_at: "2026-02-06"
|
|
152
|
-
source_docs:
|
|
153
|
-
- "docs/requirements.md"
|
|
154
|
-
|
|
155
|
-
requirements:
|
|
156
|
-
- id: R1
|
|
157
|
-
description: "사용자가 감정을 선택하고 일기를 저장할 수 있다"
|
|
158
|
-
category: functional
|
|
159
|
-
priority: must
|
|
160
|
-
acceptance:
|
|
161
|
-
- id: AC-R1-1
|
|
162
|
-
scenario: "감정 선택 → 텍스트 입력 → 저장 → 목록에서 확인"
|
|
163
|
-
type: e2e
|
|
164
|
-
- id: AC-R1-2
|
|
165
|
-
scenario: "빈 텍스트로 저장 시도 → 에러 메시지 표시"
|
|
166
|
-
type: e2e
|
|
167
|
-
|
|
168
|
-
- id: R2
|
|
169
|
-
description: "저장된 일기 목록을 조회할 수 있다"
|
|
170
|
-
category: functional
|
|
171
|
-
priority: must
|
|
172
|
-
acceptance:
|
|
173
|
-
- id: AC-R2-1
|
|
174
|
-
scenario: "저장된 일기 3개가 목록에 최신순으로 표시"
|
|
175
|
-
type: e2e
|
|
176
|
-
|
|
177
|
-
- id: R3
|
|
178
|
-
description: "일기 목록이 2초 이내에 로딩된다"
|
|
179
|
-
category: performance
|
|
180
|
-
priority: should
|
|
181
|
-
acceptance:
|
|
182
|
-
- id: AC-R3-1
|
|
183
|
-
scenario: "100개 일기 기준 로딩 시간 < 2000ms"
|
|
184
|
-
type: performance
|
|
185
|
-
|
|
186
|
-
- id: R4
|
|
187
|
-
description: "오프라인에서도 저장된 일기를 조회할 수 있다"
|
|
188
|
-
category: constraint
|
|
189
|
-
priority: could
|
|
190
|
-
acceptance:
|
|
191
|
-
- id: AC-R4-1
|
|
192
|
-
scenario: "네트워크 차단 후 기존 일기 목록 접근 가능"
|
|
193
|
-
type: manual
|
|
194
|
-
```
|
|
195
|
-
|
|
196
|
-
**완료 메시지**:
|
|
197
|
-
```markdown
|
|
198
|
-
## 요구사항 명세가 생성되었습니다
|
|
199
|
-
|
|
200
|
-
📁 파일: `.opencode/weave/specs/emotion-diary.yaml`
|
|
201
|
-
📊 요구사항: 4개 (functional 2, performance 1, constraint 1)
|
|
202
|
-
🎯 검증 기준: 5개 (e2e 3, performance 1, manual 1)
|
|
203
|
-
|
|
204
|
-
### 다음 단계
|
|
205
|
-
이 명세를 기반으로 실행 계획을 세우려면:
|
|
206
|
-
`/weave-design emotion-diary`
|
|
207
|
-
```
|
|
208
|
-
|
|
209
|
-
---
|
|
210
|
-
|
|
211
|
-
## 완료 후 검증 (필수)
|
|
212
|
-
|
|
213
|
-
스펙 파일 생성 후, 반드시 다음을 확인합니다:
|
|
214
|
-
|
|
215
|
-
1. **스펙 파일 존재 확인**: `.opencode/weave/specs/{spec-name}.yaml` 존재 검증
|
|
216
|
-
2. **YAML 파싱 가능 확인**: 파일 내용이 유효한 YAML인지 검증
|
|
217
|
-
3. **검증 실패 시**: 유저에게 오류를 알리고 재생성 시도
|
|
218
|
-
|
|
219
|
-
---
|
|
220
|
-
|
|
221
|
-
## 핵심 원칙
|
|
222
|
-
|
|
223
|
-
1. **명세만 수립, 계획/구현 금지**: Phase 분할이나 코드 구현은 하지 않음
|
|
224
|
-
2. **검증 기준은 구체적으로**: 입력 → 기대결과 형태로 작성
|
|
225
|
-
3. **유형은 정직하게**: 자동화 불가능하면 `manual`. 억지로 끼워맞추지 않음
|
|
226
|
-
4. **스펙 이름은 kebab-case**: 이후 `/weave-design`의 플랜 이름으로 사용됨
|
|
227
|
-
5. **wont도 기록**: 명시적으로 제외한 것을 기록해야 나중에 "왜 안 했어?"를 방지
|
|
@@ -1,170 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: 활성 플랜 전환, 목록 조회, 아카이브
|
|
3
|
-
---
|
|
4
|
-
|
|
5
|
-
# /weave-switch - 플랜 전환
|
|
6
|
-
|
|
7
|
-
## 개요
|
|
8
|
-
|
|
9
|
-
멀티 플랜 환경에서 활성 플랜을 전환하거나, 플랜을 관리합니다.
|
|
10
|
-
|
|
11
|
-
**사용법**:
|
|
12
|
-
- `/weave-switch` — 전체 플랜 목록 표시 (선택 UI)
|
|
13
|
-
- `/weave-switch $ARGUMENTS`
|
|
14
|
-
- `$ARGUMENTS` = 플랜 이름 → 해당 플랜으로 전환
|
|
15
|
-
- `$ARGUMENTS` = `archive {plan-name}` → 플랜 아카이브
|
|
16
|
-
- `$ARGUMENTS` = `unarchive {plan-name}` → 아카이브 해제
|
|
17
|
-
|
|
18
|
-
---
|
|
19
|
-
|
|
20
|
-
## 데이터 로드
|
|
21
|
-
|
|
22
|
-
```
|
|
23
|
-
1. .opencode/weave/state.yaml 읽기 → active_plan 확인
|
|
24
|
-
2. .opencode/weave/plans/ 내 모든 .yaml 파일 읽기
|
|
25
|
-
3. 각 플랜의 plan_name, project_name, status, phases 집계
|
|
26
|
-
```
|
|
27
|
-
|
|
28
|
-
---
|
|
29
|
-
|
|
30
|
-
## 플랜 목록 (`/weave-switch` 인자 없음)
|
|
31
|
-
|
|
32
|
-
```markdown
|
|
33
|
-
## 🔀 플랜 전환
|
|
34
|
-
|
|
35
|
-
### 활성 플랜
|
|
36
|
-
📌 `emotion-diary` — 감정 일기 앱 (P2 진행 중, 40%)
|
|
37
|
-
|
|
38
|
-
### 전환 가능한 플랜
|
|
39
|
-
| # | 플랜 | 프로젝트 | 상태 | 진행률 |
|
|
40
|
-
|---|------|---------|------|--------|
|
|
41
|
-
| 1 | `todo-app` | Todo 앱 | paused | 60% |
|
|
42
|
-
| 2 | `auth-module` | 인증 모듈 | completed | 100% |
|
|
43
|
-
|
|
44
|
-
### 아카이브된 플랜
|
|
45
|
-
| 플랜 | 프로젝트 | 완료일 |
|
|
46
|
-
|------|---------|--------|
|
|
47
|
-
| `old-prototype` | 프로토타입 v1 | 2026-01-15 |
|
|
48
|
-
|
|
49
|
-
전환하려면: `/weave-switch todo-app`
|
|
50
|
-
아카이브 해제: `/weave-switch unarchive old-prototype`
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
---
|
|
54
|
-
|
|
55
|
-
## 플랜 전환 (`/weave-switch {plan-name}`)
|
|
56
|
-
|
|
57
|
-
### 수행 작업
|
|
58
|
-
|
|
59
|
-
1. `.opencode/weave/plans/{plan-name}.yaml` 존재 여부 확인
|
|
60
|
-
2. 현재 활성 플랜의 상태를 `paused`로 변경 (active였던 경우)
|
|
61
|
-
3. 대상 플랜의 상태를 `active`로 변경
|
|
62
|
-
4. `state.yaml`의 `active_plan`을 업데이트
|
|
63
|
-
|
|
64
|
-
### 출력
|
|
65
|
-
|
|
66
|
-
```markdown
|
|
67
|
-
## ✅ 플랜이 전환되었습니다
|
|
68
|
-
|
|
69
|
-
📌 `emotion-diary` → `todo-app`
|
|
70
|
-
|
|
71
|
-
**이전 플랜**: `emotion-diary` (P2 진행 중) → paused
|
|
72
|
-
**현재 플랜**: `todo-app` (P4 대기 중) → active
|
|
73
|
-
|
|
74
|
-
### 현재 상태
|
|
75
|
-
[████████████░░░░░░░░] 3/5
|
|
76
|
-
|
|
77
|
-
다음 Phase: `/weave-craft P4`
|
|
78
|
-
돌아가려면: `/weave-switch emotion-diary`
|
|
79
|
-
```
|
|
80
|
-
|
|
81
|
-
### 에러 케이스
|
|
82
|
-
|
|
83
|
-
**존재하지 않는 플랜**:
|
|
84
|
-
```markdown
|
|
85
|
-
❌ 플랜 `xyz`를 찾을 수 없습니다.
|
|
86
|
-
|
|
87
|
-
사용 가능한 플랜:
|
|
88
|
-
- `emotion-diary` (active)
|
|
89
|
-
- `todo-app` (paused)
|
|
90
|
-
|
|
91
|
-
전체 목록: `/weave-switch`
|
|
92
|
-
```
|
|
93
|
-
|
|
94
|
-
**이미 활성 플랜인 경우**:
|
|
95
|
-
```markdown
|
|
96
|
-
ℹ️ `emotion-diary`는 이미 활성 플랜입니다.
|
|
97
|
-
|
|
98
|
-
상태 확인: `/weave-status`
|
|
99
|
-
```
|
|
100
|
-
|
|
101
|
-
---
|
|
102
|
-
|
|
103
|
-
## 플랜 아카이브 (`/weave-switch archive {plan-name}`)
|
|
104
|
-
|
|
105
|
-
### 수행 작업
|
|
106
|
-
|
|
107
|
-
1. 대상 플랜의 `status`를 `archived`로 변경
|
|
108
|
-
2. 활성 플랜이 아카이브되면 → `state.yaml`의 `active_plan`을 `null`로
|
|
109
|
-
|
|
110
|
-
### 출력
|
|
111
|
-
|
|
112
|
-
```markdown
|
|
113
|
-
## 📦 플랜이 아카이브되었습니다
|
|
114
|
-
|
|
115
|
-
`old-prototype` → archived
|
|
116
|
-
|
|
117
|
-
아카이브된 플랜은 `/weave-status`에서 숨겨집니다.
|
|
118
|
-
복원하려면: `/weave-switch unarchive old-prototype`
|
|
119
|
-
```
|
|
120
|
-
|
|
121
|
-
### 활성 플랜을 아카이브하려는 경우
|
|
122
|
-
|
|
123
|
-
```markdown
|
|
124
|
-
⚠️ `emotion-diary`는 현재 활성 플랜입니다.
|
|
125
|
-
|
|
126
|
-
아카이브하면 활성 플랜이 없어집니다.
|
|
127
|
-
계속할까요? (예/아니오)
|
|
128
|
-
```
|
|
129
|
-
|
|
130
|
-
---
|
|
131
|
-
|
|
132
|
-
## 플랜 아카이브 해제 (`/weave-switch unarchive {plan-name}`)
|
|
133
|
-
|
|
134
|
-
### 수행 작업
|
|
135
|
-
|
|
136
|
-
1. 대상 플랜의 `status`를 `paused`로 변경
|
|
137
|
-
2. 활성 플랜으로 자동 전환하지는 않음 (명시적으로 switch 필요)
|
|
138
|
-
|
|
139
|
-
### 출력
|
|
140
|
-
|
|
141
|
-
```markdown
|
|
142
|
-
## 📦 아카이브가 해제되었습니다
|
|
143
|
-
|
|
144
|
-
`old-prototype` → paused
|
|
145
|
-
|
|
146
|
-
활성 플랜으로 전환하려면: `/weave-switch old-prototype`
|
|
147
|
-
```
|
|
148
|
-
|
|
149
|
-
---
|
|
150
|
-
|
|
151
|
-
## state.yaml 변경 예시
|
|
152
|
-
|
|
153
|
-
전환 전:
|
|
154
|
-
```yaml
|
|
155
|
-
active_plan: "emotion-diary"
|
|
156
|
-
```
|
|
157
|
-
|
|
158
|
-
전환 후:
|
|
159
|
-
```yaml
|
|
160
|
-
active_plan: "todo-app"
|
|
161
|
-
```
|
|
162
|
-
|
|
163
|
-
플랜 파일 변경:
|
|
164
|
-
```yaml
|
|
165
|
-
# plans/emotion-diary.yaml
|
|
166
|
-
status: "paused" # active → paused
|
|
167
|
-
|
|
168
|
-
# plans/todo-app.yaml
|
|
169
|
-
status: "active" # paused → active
|
|
170
|
-
```
|