create-ax-project 1.0.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.
Files changed (258) hide show
  1. package/README.md +374 -0
  2. package/bin/create.js +193 -0
  3. package/package.json +38 -0
  4. package/template/.claude/CLAUDE.md +7 -0
  5. package/template/.claude/commands/CLAUDE.md +0 -0
  6. package/template/.claude/commands/benchmark.md +103 -0
  7. package/template/.claude/commands/brainstorm.md +67 -0
  8. package/template/.claude/commands/checkpoint.md +93 -0
  9. package/template/.claude/commands/codex.md +107 -0
  10. package/template/.claude/commands/collaborate.md +85 -0
  11. package/template/.claude/commands/context.md +154 -0
  12. package/template/.claude/commands/deploy.md +102 -0
  13. package/template/.claude/commands/fork.md +142 -0
  14. package/template/.claude/commands/gemini.md +84 -0
  15. package/template/.claude/commands/handoff.md +80 -0
  16. package/template/.claude/commands/implement.md +82 -0
  17. package/template/.claude/commands/init-project.md +49 -0
  18. package/template/.claude/commands/next.md +125 -0
  19. package/template/.claude/commands/planning.md +69 -0
  20. package/template/.claude/commands/qa.md +81 -0
  21. package/template/.claude/commands/refactor.md +95 -0
  22. package/template/.claude/commands/research.md +60 -0
  23. package/template/.claude/commands/restore.md +113 -0
  24. package/template/.claude/commands/run-stage.md +78 -0
  25. package/template/.claude/commands/stages.md +109 -0
  26. package/template/.claude/commands/status.md +73 -0
  27. package/template/.claude/commands/tasks.md +80 -0
  28. package/template/.claude/commands/test.md +93 -0
  29. package/template/.claude/commands/ui-ux.md +61 -0
  30. package/template/.claude/commands/validate.md +174 -0
  31. package/template/.claude/hooks/CLAUDE.md +0 -0
  32. package/template/.claude/hooks/ai-selector.sh +223 -0
  33. package/template/.claude/hooks/auto-checkpoint.sh +187 -0
  34. package/template/.claude/hooks/output-validator.sh +289 -0
  35. package/template/.claude/hooks/post-stage.sh +123 -0
  36. package/template/.claude/hooks/pre-stage.sh +186 -0
  37. package/template/.claude/hooks/session-start.sh +90 -0
  38. package/template/.claude/hooks/statusline.sh +115 -0
  39. package/template/.claude/hooks/stop.sh +104 -0
  40. package/template/.claude/settings.json +149 -0
  41. package/template/.claude/skills/ai-collaboration/CLAUDE.md +0 -0
  42. package/template/.claude/skills/ai-collaboration/README.md +61 -0
  43. package/template/.claude/skills/ai-collaboration/debate.md +148 -0
  44. package/template/.claude/skills/ai-collaboration/parallel.md +96 -0
  45. package/template/.claude/skills/ai-collaboration/prompts/CLAUDE.md +107 -0
  46. package/template/.claude/skills/auto-checkpoint/CLAUDE.md +0 -0
  47. package/template/.claude/skills/auto-checkpoint/README.md +77 -0
  48. package/template/.claude/skills/auto-checkpoint/prompts/CLAUDE.md +113 -0
  49. package/template/.claude/skills/auto-checkpoint/rollback.md +152 -0
  50. package/template/.claude/skills/auto-checkpoint/trigger.md +122 -0
  51. package/template/.claude/skills/context-compression/CLAUDE.md +0 -0
  52. package/template/.claude/skills/context-compression/README.md +121 -0
  53. package/template/.claude/skills/context-compression/analyze.md +114 -0
  54. package/template/.claude/skills/context-compression/compress.md +175 -0
  55. package/template/.claude/skills/context-compression/prompts/CLAUDE.md +0 -0
  56. package/template/.claude/skills/context-compression/prompts/compression.md +172 -0
  57. package/template/.claude/skills/output-validator/CLAUDE.md +0 -0
  58. package/template/.claude/skills/output-validator/README.md +86 -0
  59. package/template/.claude/skills/output-validator/prompts/CLAUDE.md +119 -0
  60. package/template/.claude/skills/output-validator/validate.md +182 -0
  61. package/template/.claude/skills/smart-handoff/CLAUDE.md +0 -0
  62. package/template/.claude/skills/smart-handoff/README.md +59 -0
  63. package/template/.claude/skills/smart-handoff/extract.md +76 -0
  64. package/template/.claude/skills/smart-handoff/prompts/CLAUDE.md +86 -0
  65. package/template/.claude/skills/smart-handoff/summarize.md +94 -0
  66. package/template/.claude/skills/stage-transition/CLAUDE.md +0 -0
  67. package/template/.claude/skills/stage-transition/README.md +84 -0
  68. package/template/.claude/skills/stage-transition/handoff-gen.md +160 -0
  69. package/template/.claude/skills/stage-transition/prompts/CLAUDE.md +0 -0
  70. package/template/.claude/skills/stage-transition/prompts/transition.md +145 -0
  71. package/template/.claude/skills/stage-transition/validate.md +108 -0
  72. package/template/CLAUDE.md +528 -0
  73. package/template/config/CLAUDE.md +0 -0
  74. package/template/config/ai_benchmarking.yaml +184 -0
  75. package/template/config/ai_collaboration.yaml +159 -0
  76. package/template/config/ai_logging.yaml +129 -0
  77. package/template/config/auto_checkpoint.yaml +189 -0
  78. package/template/config/context.yaml +78 -0
  79. package/template/config/git.yaml +161 -0
  80. package/template/config/handoff_intelligence.yaml +229 -0
  81. package/template/config/implementation.yaml.template +181 -0
  82. package/template/config/mcp_fallbacks.yaml +252 -0
  83. package/template/config/memory_integration.yaml +200 -0
  84. package/template/config/model_enforcement.yaml +141 -0
  85. package/template/config/models.yaml +242 -0
  86. package/template/config/output_validation.yaml +352 -0
  87. package/template/config/pipeline.yaml +357 -0
  88. package/template/config/pipeline_forking.yaml +236 -0
  89. package/template/config/qa_logging.yaml +166 -0
  90. package/template/config/smart_rollback.yaml +209 -0
  91. package/template/config/stage_personas.yaml +354 -0
  92. package/template/config/workflow.yaml +54 -0
  93. package/template/scripts/CLAUDE.md +0 -0
  94. package/template/scripts/ai-benchmark.sh +272 -0
  95. package/template/scripts/codex-wrapper.sh +97 -0
  96. package/template/scripts/context-manager.sh +528 -0
  97. package/template/scripts/create-checkpoint.sh +116 -0
  98. package/template/scripts/gemini-wrapper.sh +96 -0
  99. package/template/scripts/init-project.sh +109 -0
  100. package/template/scripts/list-stages.sh +245 -0
  101. package/template/scripts/next-stage.sh +228 -0
  102. package/template/scripts/output-validate.sh +12 -0
  103. package/template/scripts/pipeline-fork.sh +293 -0
  104. package/template/scripts/pre-run-check.sh +361 -0
  105. package/template/scripts/restore-checkpoint.sh +247 -0
  106. package/template/scripts/run-stage.sh +139 -0
  107. package/template/scripts/show-status.sh +185 -0
  108. package/template/scripts/smart-handoff.sh +254 -0
  109. package/template/stages/01-brainstorm/CLAUDE.md +103 -0
  110. package/template/stages/01-brainstorm/HANDOFF.md +110 -0
  111. package/template/stages/01-brainstorm/HANDOFF.md.template +112 -0
  112. package/template/stages/01-brainstorm/README.md +97 -0
  113. package/template/stages/01-brainstorm/config.yaml +92 -0
  114. package/template/stages/01-brainstorm/inputs/.gitkeep +0 -0
  115. package/template/stages/01-brainstorm/inputs/CLAUDE.md +0 -0
  116. package/template/stages/01-brainstorm/inputs/project_brief.md +40 -0
  117. package/template/stages/01-brainstorm/outputs/.gitkeep +0 -0
  118. package/template/stages/01-brainstorm/outputs/CLAUDE.md +0 -0
  119. package/template/stages/01-brainstorm/outputs/ideas.md +159 -0
  120. package/template/stages/01-brainstorm/outputs/requirements_analysis.md +222 -0
  121. package/template/stages/01-brainstorm/prompts/CLAUDE.md +0 -0
  122. package/template/stages/01-brainstorm/prompts/collaboration.md +46 -0
  123. package/template/stages/01-brainstorm/prompts/ideation.md +62 -0
  124. package/template/stages/01-brainstorm/prompts/persona.md +73 -0
  125. package/template/stages/01-brainstorm/prompts/requirements.md +73 -0
  126. package/template/stages/01-brainstorm/prompts/validation.md +50 -0
  127. package/template/stages/01-brainstorm/templates/CLAUDE.md +0 -0
  128. package/template/stages/01-brainstorm/templates/ideas.md +91 -0
  129. package/template/stages/01-brainstorm/templates/requirements_analysis.md +129 -0
  130. package/template/stages/02-research/CLAUDE.md +101 -0
  131. package/template/stages/02-research/HANDOFF.md +158 -0
  132. package/template/stages/02-research/HANDOFF.md.template +102 -0
  133. package/template/stages/02-research/config.yaml +68 -0
  134. package/template/stages/02-research/inputs/.gitkeep +0 -0
  135. package/template/stages/02-research/outputs/.gitkeep +0 -0
  136. package/template/stages/02-research/outputs/CLAUDE.md +0 -0
  137. package/template/stages/02-research/outputs/feasibility_report.md +176 -0
  138. package/template/stages/02-research/outputs/tech_research.md +403 -0
  139. package/template/stages/02-research/prompts/CLAUDE.md +0 -0
  140. package/template/stages/02-research/prompts/collaboration.md +51 -0
  141. package/template/stages/02-research/prompts/feasibility.md +73 -0
  142. package/template/stages/02-research/prompts/market_analysis.md +58 -0
  143. package/template/stages/02-research/prompts/tech_stack.md +60 -0
  144. package/template/stages/02-research/prompts/validation.md +51 -0
  145. package/template/stages/02-research/templates/.gitkeep +0 -0
  146. package/template/stages/03-planning/CLAUDE.md +98 -0
  147. package/template/stages/03-planning/HANDOFF.md +168 -0
  148. package/template/stages/03-planning/HANDOFF.md.template +91 -0
  149. package/template/stages/03-planning/config.yaml +64 -0
  150. package/template/stages/03-planning/inputs/.gitkeep +0 -0
  151. package/template/stages/03-planning/outputs/.gitkeep +0 -0
  152. package/template/stages/03-planning/outputs/CLAUDE.md +0 -0
  153. package/template/stages/03-planning/outputs/architecture.md +400 -0
  154. package/template/stages/03-planning/outputs/implementation.yaml +209 -0
  155. package/template/stages/03-planning/outputs/project_plan.md +204 -0
  156. package/template/stages/03-planning/outputs/tech_stack.md +176 -0
  157. package/template/stages/03-planning/prompts/CLAUDE.md +0 -0
  158. package/template/stages/03-planning/prompts/architecture.md +62 -0
  159. package/template/stages/03-planning/prompts/collaboration.md +57 -0
  160. package/template/stages/03-planning/prompts/validation.md +59 -0
  161. package/template/stages/03-planning/templates/.gitkeep +0 -0
  162. package/template/stages/04-ui-ux/CLAUDE.md +88 -0
  163. package/template/stages/04-ui-ux/HANDOFF.md +165 -0
  164. package/template/stages/04-ui-ux/HANDOFF.md.template +92 -0
  165. package/template/stages/04-ui-ux/config.yaml +57 -0
  166. package/template/stages/04-ui-ux/inputs/.gitkeep +0 -0
  167. package/template/stages/04-ui-ux/outputs/.gitkeep +0 -0
  168. package/template/stages/04-ui-ux/outputs/CLAUDE.md +0 -0
  169. package/template/stages/04-ui-ux/outputs/design_system.md +449 -0
  170. package/template/stages/04-ui-ux/outputs/user_flows.md +321 -0
  171. package/template/stages/04-ui-ux/outputs/wireframes.md +241 -0
  172. package/template/stages/04-ui-ux/prompts/.gitkeep +0 -0
  173. package/template/stages/04-ui-ux/prompts/CLAUDE.md +0 -0
  174. package/template/stages/04-ui-ux/prompts/collaboration.md +56 -0
  175. package/template/stages/04-ui-ux/prompts/validation.md +54 -0
  176. package/template/stages/04-ui-ux/templates/.gitkeep +0 -0
  177. package/template/stages/05-task-management/CLAUDE.md +105 -0
  178. package/template/stages/05-task-management/HANDOFF.md +187 -0
  179. package/template/stages/05-task-management/HANDOFF.md.template +97 -0
  180. package/template/stages/05-task-management/config.yaml +81 -0
  181. package/template/stages/05-task-management/inputs/.gitkeep +0 -0
  182. package/template/stages/05-task-management/outputs/.gitkeep +0 -0
  183. package/template/stages/05-task-management/outputs/CLAUDE.md +0 -0
  184. package/template/stages/05-task-management/outputs/milestones.md +253 -0
  185. package/template/stages/05-task-management/outputs/sprint_plan.md +203 -0
  186. package/template/stages/05-task-management/outputs/tasks.md +402 -0
  187. package/template/stages/05-task-management/prompts/.gitkeep +0 -0
  188. package/template/stages/05-task-management/prompts/CLAUDE.md +0 -0
  189. package/template/stages/05-task-management/prompts/collaboration.md +54 -0
  190. package/template/stages/05-task-management/prompts/validation.md +66 -0
  191. package/template/stages/05-task-management/templates/CLAUDE.md +0 -0
  192. package/template/stages/05-task-management/templates/notion_integration.md +176 -0
  193. package/template/stages/05-task-management/templates/parallel_groups.yaml +153 -0
  194. package/template/stages/05-task-management/templates/task_schema.yaml +154 -0
  195. package/template/stages/06-implementation/CLAUDE.md +163 -0
  196. package/template/stages/06-implementation/HANDOFF.md +184 -0
  197. package/template/stages/06-implementation/HANDOFF.md.template +192 -0
  198. package/template/stages/06-implementation/config.yaml +62 -0
  199. package/template/stages/06-implementation/inputs/.gitkeep +0 -0
  200. package/template/stages/06-implementation/outputs/.gitkeep +0 -0
  201. package/template/stages/06-implementation/prompts/.gitkeep +0 -0
  202. package/template/stages/06-implementation/prompts/CLAUDE.md +0 -0
  203. package/template/stages/06-implementation/prompts/collaboration.md +64 -0
  204. package/template/stages/06-implementation/prompts/validation.md +65 -0
  205. package/template/stages/06-implementation/templates/.gitkeep +0 -0
  206. package/template/stages/07-refactoring/CLAUDE.md +180 -0
  207. package/template/stages/07-refactoring/HANDOFF.md +82 -0
  208. package/template/stages/07-refactoring/HANDOFF.md.template +97 -0
  209. package/template/stages/07-refactoring/config.yaml +68 -0
  210. package/template/stages/07-refactoring/inputs/.gitkeep +0 -0
  211. package/template/stages/07-refactoring/outputs/.gitkeep +0 -0
  212. package/template/stages/07-refactoring/outputs/refactoring_report.md +102 -0
  213. package/template/stages/07-refactoring/prompts/.gitkeep +0 -0
  214. package/template/stages/07-refactoring/prompts/CLAUDE.md +0 -0
  215. package/template/stages/07-refactoring/prompts/collaboration.md +71 -0
  216. package/template/stages/07-refactoring/prompts/validation.md +76 -0
  217. package/template/stages/07-refactoring/templates/.gitkeep +0 -0
  218. package/template/stages/08-qa/CLAUDE.md +93 -0
  219. package/template/stages/08-qa/HANDOFF.md +114 -0
  220. package/template/stages/08-qa/HANDOFF.md.template +96 -0
  221. package/template/stages/08-qa/config.yaml +56 -0
  222. package/template/stages/08-qa/inputs/.gitkeep +0 -0
  223. package/template/stages/08-qa/outputs/.gitkeep +0 -0
  224. package/template/stages/08-qa/outputs/qa_report.md +138 -0
  225. package/template/stages/08-qa/prompts/.gitkeep +0 -0
  226. package/template/stages/08-qa/prompts/CLAUDE.md +0 -0
  227. package/template/stages/08-qa/prompts/collaboration.md +65 -0
  228. package/template/stages/08-qa/prompts/validation.md +71 -0
  229. package/template/stages/08-qa/templates/.gitkeep +0 -0
  230. package/template/stages/09-testing/CLAUDE.md +124 -0
  231. package/template/stages/09-testing/HANDOFF.md +118 -0
  232. package/template/stages/09-testing/HANDOFF.md.template +113 -0
  233. package/template/stages/09-testing/config.yaml +65 -0
  234. package/template/stages/09-testing/inputs/.gitkeep +0 -0
  235. package/template/stages/09-testing/outputs/.gitkeep +0 -0
  236. package/template/stages/09-testing/outputs/test_report.md +146 -0
  237. package/template/stages/09-testing/prompts/.gitkeep +0 -0
  238. package/template/stages/09-testing/prompts/CLAUDE.md +0 -0
  239. package/template/stages/09-testing/prompts/collaboration.md +77 -0
  240. package/template/stages/09-testing/prompts/validation.md +83 -0
  241. package/template/stages/09-testing/templates/.gitkeep +0 -0
  242. package/template/stages/10-deployment/CLAUDE.md +117 -0
  243. package/template/stages/10-deployment/HANDOFF.md +141 -0
  244. package/template/stages/10-deployment/HANDOFF.md.template +148 -0
  245. package/template/stages/10-deployment/config.yaml +61 -0
  246. package/template/stages/10-deployment/inputs/.gitkeep +0 -0
  247. package/template/stages/10-deployment/outputs/.gitkeep +0 -0
  248. package/template/stages/10-deployment/prompts/.gitkeep +0 -0
  249. package/template/stages/10-deployment/prompts/CLAUDE.md +0 -0
  250. package/template/stages/10-deployment/prompts/collaboration.md +80 -0
  251. package/template/stages/10-deployment/prompts/validation.md +93 -0
  252. package/template/stages/10-deployment/templates/CLAUDE.md +0 -0
  253. package/template/stages/10-deployment/templates/github-actions-cd.yaml +118 -0
  254. package/template/stages/10-deployment/templates/github-actions-ci.yaml +136 -0
  255. package/template/state/progress.json.template +111 -0
  256. package/template/state/templates/CLAUDE.md +0 -0
  257. package/template/state/templates/handoff_base.md.template +187 -0
  258. package/template/state/templates/phase_state.md.template +97 -0
@@ -0,0 +1,116 @@
1
+ #!/bin/bash
2
+ # create-checkpoint.sh - 체크포인트 생성
3
+ # ax-templates workflow pipeline
4
+
5
+ set -e
6
+
7
+ DESCRIPTION="$1"
8
+ PROJECT_ROOT="$(cd "$(dirname "$0")/.." && pwd)"
9
+ PROGRESS_FILE="$PROJECT_ROOT/state/progress.json"
10
+ TIMESTAMP=$(date +%Y%m%d-%H%M)
11
+ TIMESTAMP_ISO=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
12
+
13
+ # 색상 정의
14
+ RED='\033[0;31m'
15
+ GREEN='\033[0;32m'
16
+ YELLOW='\033[1;33m'
17
+ BLUE='\033[0;34m'
18
+ NC='\033[0m' # No Color
19
+
20
+ # 현재 스테이지 확인
21
+ if command -v jq &> /dev/null; then
22
+ CURRENT_STAGE=$(jq -r '.current_stage' "$PROGRESS_FILE")
23
+ else
24
+ echo -e "${RED}오류:${NC} jq가 필요합니다."
25
+ exit 1
26
+ fi
27
+
28
+ if [ -z "$CURRENT_STAGE" ] || [ "$CURRENT_STAGE" == "null" ]; then
29
+ echo -e "${RED}오류:${NC} 현재 진행 중인 스테이지가 없습니다."
30
+ exit 1
31
+ fi
32
+
33
+ # 기본 설명
34
+ if [ -z "$DESCRIPTION" ]; then
35
+ DESCRIPTION="체크포인트 - $CURRENT_STAGE"
36
+ fi
37
+
38
+ # 체크포인트 ID 생성
39
+ STAGE_NUM=$(echo "$CURRENT_STAGE" | cut -d'-' -f1)
40
+ CP_ID="CP-$STAGE_NUM-$TIMESTAMP"
41
+
42
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
43
+ echo "💾 체크포인트 생성: $CP_ID"
44
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
45
+ echo " 스테이지: $CURRENT_STAGE"
46
+ echo " 설명: $DESCRIPTION"
47
+ echo ""
48
+
49
+ # 체크포인트 디렉토리 생성
50
+ CP_DIR="$PROJECT_ROOT/state/checkpoints/$CP_ID"
51
+ mkdir -p "$CP_DIR"
52
+
53
+ # 1. 상태 파일 복사
54
+ echo -e "${BLUE}[1/4] 상태 파일 복사${NC}"
55
+ cp "$PROGRESS_FILE" "$CP_DIR/progress.json"
56
+ echo -e "${GREEN}✓${NC} progress.json 복사됨"
57
+
58
+ # 2. 스테이지 outputs 복사
59
+ echo -e "${BLUE}[2/4] 스테이지 출력 파일 복사${NC}"
60
+ STAGE_DIR="$PROJECT_ROOT/stages/$CURRENT_STAGE"
61
+ if [ -d "$STAGE_DIR/outputs" ]; then
62
+ cp -r "$STAGE_DIR/outputs" "$CP_DIR/outputs"
63
+ FILE_COUNT=$(find "$CP_DIR/outputs" -type f | wc -l)
64
+ echo -e "${GREEN}✓${NC} outputs 복사됨 ($FILE_COUNT 파일)"
65
+ else
66
+ mkdir -p "$CP_DIR/outputs"
67
+ echo -e "${YELLOW}⚠${NC} outputs 디렉토리 없음 (빈 디렉토리 생성)"
68
+ fi
69
+
70
+ # 3. HANDOFF.md 복사 (있는 경우)
71
+ echo -e "${BLUE}[3/4] HANDOFF.md 복사${NC}"
72
+ if [ -f "$STAGE_DIR/HANDOFF.md" ]; then
73
+ cp "$STAGE_DIR/HANDOFF.md" "$CP_DIR/"
74
+ echo -e "${GREEN}✓${NC} HANDOFF.md 복사됨"
75
+ else
76
+ echo -e "${YELLOW}⚠${NC} HANDOFF.md 없음"
77
+ fi
78
+
79
+ # 4. 메타데이터 생성
80
+ echo -e "${BLUE}[4/4] 메타데이터 생성${NC}"
81
+ cat > "$CP_DIR/metadata.json" << EOF
82
+ {
83
+ "id": "$CP_ID",
84
+ "stage": "$CURRENT_STAGE",
85
+ "description": "$DESCRIPTION",
86
+ "created_at": "$TIMESTAMP_ISO",
87
+ "files": []
88
+ }
89
+ EOF
90
+
91
+ # 파일 목록 추가
92
+ if command -v jq &> /dev/null; then
93
+ FILES=$(find "$CP_DIR" -type f -not -name "metadata.json" | jq -R -s -c 'split("\n") | map(select(length > 0))')
94
+ jq ".files = $FILES" "$CP_DIR/metadata.json" > "$CP_DIR/metadata.json.tmp" && mv "$CP_DIR/metadata.json.tmp" "$CP_DIR/metadata.json"
95
+ fi
96
+ echo -e "${GREEN}✓${NC} 메타데이터 생성됨"
97
+
98
+ # 5. progress.json에 체크포인트 추가
99
+ echo ""
100
+ echo -e "${BLUE}상태 업데이트${NC}"
101
+ jq ".checkpoints += [{\"id\": \"$CP_ID\", \"stage\": \"$CURRENT_STAGE\", \"description\": \"$DESCRIPTION\", \"created_at\": \"$TIMESTAMP_ISO\"}] | \
102
+ .stages.\"$CURRENT_STAGE\".checkpoint_id = \"$CP_ID\"" \
103
+ "$PROGRESS_FILE" > "${PROGRESS_FILE}.tmp" && mv "${PROGRESS_FILE}.tmp" "$PROGRESS_FILE"
104
+ echo -e "${GREEN}✓${NC} progress.json 업데이트됨"
105
+
106
+ # 완료 메시지
107
+ echo ""
108
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
109
+ echo -e "${GREEN}✓${NC} 체크포인트 생성 완료!"
110
+ echo ""
111
+ echo " ID: $CP_ID"
112
+ echo " 위치: state/checkpoints/$CP_ID/"
113
+ echo ""
114
+ echo -e "${BLUE}복구 명령어:${NC}"
115
+ echo " scripts/restore-checkpoint.sh $CP_ID"
116
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
@@ -0,0 +1,96 @@
1
+ #!/bin/bash
2
+ # gemini-wrapper.sh - tmux 기반 Gemini CLI 래퍼
3
+ # ax-templates workflow pipeline
4
+ # tmux wait-for 채널 기반 동기화 방식 (폴링 없음, 즉시 반응)
5
+
6
+ SESSION_NAME="ax-gemini"
7
+ CHANNEL="ax-gemini-done-$$"
8
+ OUTPUT_FILE="/tmp/ax-gemini-output-$$"
9
+ PROMPT="$1"
10
+ TIMEOUT="${2:-300}" # 기본 5분 타임아웃
11
+
12
+ # 색상 정의
13
+ RED='\033[0;31m'
14
+ GREEN='\033[0;32m'
15
+ YELLOW='\033[1;33m'
16
+ BLUE='\033[0;34m'
17
+ NC='\033[0m' # No Color
18
+
19
+ # 사용법
20
+ if [ -z "$PROMPT" ]; then
21
+ echo "사용법: $0 \"<prompt>\" [timeout_seconds]"
22
+ echo "예시: $0 \"Reddit에서 Claude Code 관련 게시물을 찾아줘\" 300"
23
+ exit 1
24
+ fi
25
+
26
+ # tmux 확인
27
+ if ! command -v tmux &> /dev/null; then
28
+ echo -e "${RED}오류:${NC} tmux가 설치되어 있지 않습니다."
29
+ echo "설치: brew install tmux (macOS) 또는 apt install tmux (Ubuntu)"
30
+ exit 1
31
+ fi
32
+
33
+ # Gemini CLI 확인
34
+ if ! command -v gemini &> /dev/null; then
35
+ echo -e "${YELLOW}경고:${NC} gemini CLI가 설치되어 있지 않습니다."
36
+ echo "Gemini CLI 없이 시뮬레이션 모드로 실행합니다."
37
+ echo ""
38
+ echo "[시뮬레이션] Gemini 응답:"
39
+ echo "---"
40
+ echo "Gemini CLI가 설치되면 실제 응답이 표시됩니다."
41
+ echo "프롬프트: $PROMPT"
42
+ exit 0
43
+ fi
44
+
45
+ # 임시 파일 정리
46
+ cleanup() {
47
+ rm -f "$OUTPUT_FILE"
48
+ }
49
+ trap cleanup EXIT
50
+
51
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
52
+ echo -e "${BLUE}🤖 Gemini CLI 호출${NC}"
53
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
54
+ echo " 세션: $SESSION_NAME"
55
+ echo " 타임아웃: ${TIMEOUT}초"
56
+ echo ""
57
+
58
+ # tmux 세션 확인/생성
59
+ if ! tmux has-session -t "$SESSION_NAME" 2>/dev/null; then
60
+ echo -e "${YELLOW}⚠${NC} 새 tmux 세션 생성: $SESSION_NAME"
61
+ tmux new-session -d -s "$SESSION_NAME"
62
+ sleep 1
63
+ fi
64
+
65
+ # 프롬프트 이스케이프
66
+ ESCAPED_PROMPT=$(printf '%s' "$PROMPT" | sed 's/"/\\"/g' | sed "s/'/'\\\\''/g")
67
+
68
+ # Gemini CLI 실행 + 완료 시 채널에 시그널
69
+ echo -e "${BLUE}Gemini 호출 중...${NC}"
70
+ tmux send-keys -t "$SESSION_NAME" "gemini \"$ESCAPED_PROMPT\" 2>&1 | tee $OUTPUT_FILE; tmux wait-for -S $CHANNEL" Enter
71
+
72
+ # 타임아웃 처리를 위해 백그라운드 타이머
73
+ (sleep "$TIMEOUT" && tmux wait-for -S "$CHANNEL" 2>/dev/null) &
74
+ TIMER_PID=$!
75
+
76
+ # 채널 시그널 대기 (블로킹)
77
+ tmux wait-for "$CHANNEL"
78
+ kill $TIMER_PID 2>/dev/null || true
79
+
80
+ # 결과 출력
81
+ echo ""
82
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
83
+ echo -e "${GREEN}📄 Gemini 응답:${NC}"
84
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
85
+
86
+ if [[ -f "$OUTPUT_FILE" ]]; then
87
+ cat "$OUTPUT_FILE"
88
+ else
89
+ echo -e "${RED}오류:${NC} 출력을 캡처하지 못했습니다."
90
+ exit 1
91
+ fi
92
+
93
+ echo ""
94
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
95
+ echo -e "${GREEN}✓${NC} Gemini 호출 완료"
96
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
@@ -0,0 +1,109 @@
1
+ #!/bin/bash
2
+ # init-project.sh - 새 프로젝트 초기화
3
+ # ax-templates workflow pipeline
4
+
5
+ set -e
6
+
7
+ PROJECT_NAME="$1"
8
+ PROJECT_ROOT="$(cd "$(dirname "$0")/.." && pwd)"
9
+ TIMESTAMP=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
10
+
11
+ # 색상 정의
12
+ RED='\033[0;31m'
13
+ GREEN='\033[0;32m'
14
+ YELLOW='\033[1;33m'
15
+ BLUE='\033[0;34m'
16
+ NC='\033[0m' # No Color
17
+
18
+ # 사용법
19
+ if [ -z "$PROJECT_NAME" ]; then
20
+ echo "사용법: $0 <project-name>"
21
+ echo "예시: $0 my-saas-app"
22
+ exit 1
23
+ fi
24
+
25
+ # 프로젝트 이름 검증
26
+ if ! [[ "$PROJECT_NAME" =~ ^[a-z0-9-]+$ ]]; then
27
+ echo -e "${RED}오류:${NC} 프로젝트 이름은 영문 소문자, 숫자, 하이픈만 허용됩니다."
28
+ exit 1
29
+ fi
30
+
31
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
32
+ echo "🚀 프로젝트 초기화: $PROJECT_NAME"
33
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
34
+
35
+ # 1. 프로젝트 디렉토리 생성
36
+ PROJECT_DIR="$PROJECT_ROOT/projects/$PROJECT_NAME"
37
+
38
+ if [ -d "$PROJECT_DIR" ]; then
39
+ echo -e "${RED}오류:${NC} 프로젝트 '$PROJECT_NAME'이(가) 이미 존재합니다."
40
+ exit 1
41
+ fi
42
+
43
+ mkdir -p "$PROJECT_DIR"
44
+ echo -e "${GREEN}✓${NC} 프로젝트 디렉토리 생성: $PROJECT_DIR"
45
+
46
+ # 2. 상태 파일 초기화
47
+ PROGRESS_FILE="$PROJECT_ROOT/state/progress.json"
48
+
49
+ if command -v jq &> /dev/null; then
50
+ jq ".pipeline.project_name = \"$PROJECT_NAME\" | \
51
+ .pipeline.started_at = \"$TIMESTAMP\" | \
52
+ .pipeline.updated_at = \"$TIMESTAMP\" | \
53
+ .current_stage = \"01-brainstorm\"" \
54
+ "$PROGRESS_FILE" > "${PROGRESS_FILE}.tmp" && mv "${PROGRESS_FILE}.tmp" "$PROGRESS_FILE"
55
+ echo -e "${GREEN}✓${NC} 상태 파일 업데이트됨"
56
+ else
57
+ echo -e "${YELLOW}⚠${NC} jq 미설치 - 상태 파일 수동 업데이트 필요"
58
+ fi
59
+
60
+ # 3. 입력 파일 템플릿 생성
61
+ BRAINSTORM_DIR="$PROJECT_ROOT/stages/01-brainstorm"
62
+ mkdir -p "$BRAINSTORM_DIR/inputs"
63
+
64
+ cat > "$BRAINSTORM_DIR/inputs/project_brief.md" << 'EOF'
65
+ # Project Brief
66
+
67
+ ## 프로젝트 이름
68
+ {{PROJECT_NAME}}
69
+
70
+ ## 한 줄 설명
71
+ [프로젝트를 한 줄로 설명해주세요]
72
+
73
+ ## 문제 정의
74
+ [해결하려는 문제는 무엇인가요?]
75
+
76
+ ## 타겟 사용자
77
+ [주요 사용자는 누구인가요?]
78
+
79
+ ## 핵심 기능 (초안)
80
+ 1. [기능 1]
81
+ 2. [기능 2]
82
+ 3. [기능 3]
83
+
84
+ ## 성공 기준
85
+ [프로젝트가 성공했다고 판단하는 기준은?]
86
+
87
+ ## 제약조건
88
+ - 일정:
89
+ - 예산:
90
+ - 기술:
91
+
92
+ ## 참고 자료
93
+ - [URL 또는 문서]
94
+ EOF
95
+
96
+ sed -i '' "s/{{PROJECT_NAME}}/$PROJECT_NAME/g" "$BRAINSTORM_DIR/inputs/project_brief.md" 2>/dev/null || \
97
+ sed -i "s/{{PROJECT_NAME}}/$PROJECT_NAME/g" "$BRAINSTORM_DIR/inputs/project_brief.md"
98
+
99
+ echo -e "${GREEN}✓${NC} 프로젝트 브리프 템플릿 생성: stages/01-brainstorm/inputs/project_brief.md"
100
+
101
+ # 4. 완료 메시지
102
+ echo ""
103
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
104
+ echo -e "${GREEN}✓${NC} 프로젝트 '$PROJECT_NAME' 초기화 완료!"
105
+ echo ""
106
+ echo -e "${BLUE}다음 단계:${NC}"
107
+ echo "1. stages/01-brainstorm/inputs/project_brief.md 작성"
108
+ echo "2. /run-stage 01-brainstorm 실행"
109
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
@@ -0,0 +1,245 @@
1
+ #!/bin/bash
2
+ # list-stages.sh - 스테이지 목록 및 상세 정보 표시
3
+ # ax-templates workflow pipeline
4
+
5
+ set -e
6
+
7
+ PROJECT_ROOT="$(cd "$(dirname "$0")/.." && pwd)"
8
+ PROGRESS_FILE="$PROJECT_ROOT/state/progress.json"
9
+ STAGES_DIR="$PROJECT_ROOT/stages"
10
+
11
+ # 색상 정의
12
+ RED='\033[0;31m'
13
+ GREEN='\033[0;32m'
14
+ YELLOW='\033[1;33m'
15
+ BLUE='\033[0;34m'
16
+ CYAN='\033[0;36m'
17
+ WHITE='\033[1;37m'
18
+ GRAY='\033[0;90m'
19
+ NC='\033[0m' # No Color
20
+
21
+ # 옵션 및 인자 처리
22
+ OUTPUT_JSON=false
23
+ FILTER_PENDING=false
24
+ FILTER_COMPLETED=false
25
+ STAGE_NUM=""
26
+
27
+ while [[ "$#" -gt 0 ]]; do
28
+ case $1 in
29
+ --json) OUTPUT_JSON=true ;;
30
+ --pending) FILTER_PENDING=true ;;
31
+ --completed) FILTER_COMPLETED=true ;;
32
+ [0-9]*) STAGE_NUM="$1" ;;
33
+ *) ;;
34
+ esac
35
+ shift
36
+ done
37
+
38
+ # jq 확인
39
+ if ! command -v jq &> /dev/null; then
40
+ echo -e "${RED}오류:${NC} jq가 필요합니다."
41
+ exit 1
42
+ fi
43
+
44
+ # 스테이지 정보 배열
45
+ declare -a STAGE_IDS=("01-brainstorm" "02-research" "03-planning" "04-ui-ux" "05-task-management" "06-implementation" "07-refactoring" "08-qa" "09-testing" "10-deployment")
46
+ declare -a STAGE_NAMES=("brainstorm" "research" "planning" "ui-ux" "task-management" "implementation" "refactoring" "qa" "testing" "deployment")
47
+ declare -a STAGE_AI=("Gemini+Claude" "Claude+MCP" "Gemini" "Gemini" "ClaudeCode" "ClaudeCode" "Codex" "ClaudeCode" "Codex" "ClaudeCode")
48
+ declare -a STAGE_MODES=("YOLO" "Plan Mode" "Plan Mode" "Plan Mode" "Plan Mode" "Plan+Sandbox" "Deep Dive" "Plan+Sandbox" "Playwright" "Headless")
49
+ declare -a STAGE_SHORTCUTS=("brainstorm" "research" "planning" "ui-ux" "tasks" "implement" "refactor" "qa" "test" "deploy")
50
+
51
+ # 현재 스테이지 가져오기
52
+ if [ -f "$PROGRESS_FILE" ]; then
53
+ CURRENT_STAGE=$(jq -r '.current_stage // "none"' "$PROGRESS_FILE")
54
+ else
55
+ CURRENT_STAGE="none"
56
+ fi
57
+
58
+ # 상태 아이콘 반환
59
+ status_icon() {
60
+ case $1 in
61
+ completed) echo "✅" ;;
62
+ in_progress) echo "🔄" ;;
63
+ pending) echo "⏳" ;;
64
+ failed) echo "❌" ;;
65
+ *) echo "⏳" ;;
66
+ esac
67
+ }
68
+
69
+ # 특정 스테이지 상세 보기
70
+ show_stage_detail() {
71
+ local num=$1
72
+ local idx=$((num - 1))
73
+
74
+ if [ $idx -lt 0 ] || [ $idx -ge 10 ]; then
75
+ echo -e "${RED}오류:${NC} 유효한 스테이지 번호를 입력하세요 (01-10)"
76
+ exit 1
77
+ fi
78
+
79
+ local STAGE_ID="${STAGE_IDS[$idx]}"
80
+ local STAGE_NAME="${STAGE_NAMES[$idx]}"
81
+ local AI="${STAGE_AI[$idx]}"
82
+ local MODE="${STAGE_MODES[$idx]}"
83
+ local SHORTCUT="${STAGE_SHORTCUTS[$idx]}"
84
+ local STAGE_PATH="$STAGES_DIR/$STAGE_ID"
85
+ local CONFIG_PATH="$STAGE_PATH/config.yaml"
86
+
87
+ # 상태 가져오기
88
+ if [ -f "$PROGRESS_FILE" ]; then
89
+ STATUS=$(jq -r ".stages.\"$STAGE_ID\".status // \"pending\"" "$PROGRESS_FILE")
90
+ else
91
+ STATUS="pending"
92
+ fi
93
+
94
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
95
+ printf "📋 ${WHITE}Stage %02d: %s${NC}\n" "$num" "${STAGE_NAME^}"
96
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
97
+ echo -e "AI Model: ${CYAN}$AI${NC}"
98
+ echo -e "Mode: ${CYAN}$MODE${NC}"
99
+ echo -e "Status: $(status_icon $STATUS) $STATUS"
100
+
101
+ # config.yaml에서 추가 정보 가져오기
102
+ if [ -f "$CONFIG_PATH" ]; then
103
+ # timeout 추출 (yq가 있으면 사용, 없으면 grep)
104
+ if command -v yq &> /dev/null; then
105
+ TIMEOUT=$(yq -r '.timeout // "60"' "$CONFIG_PATH")
106
+ CHECKPOINT=$(yq -r '.checkpoint_required // false' "$CONFIG_PATH")
107
+ else
108
+ TIMEOUT=$(grep "timeout:" "$CONFIG_PATH" 2>/dev/null | head -1 | awk '{print $2}' || echo "60")
109
+ CHECKPOINT=$(grep "checkpoint_required:" "$CONFIG_PATH" 2>/dev/null | head -1 | awk '{print $2}' || echo "false")
110
+ fi
111
+ echo -e "Timeout: ${TIMEOUT}분"
112
+ if [ "$CHECKPOINT" == "true" ]; then
113
+ echo -e "Checkpoint: ${YELLOW}필수${NC}"
114
+ fi
115
+ fi
116
+
117
+ echo ""
118
+
119
+ # Inputs
120
+ echo -e "${BLUE}[Inputs]${NC}"
121
+ if [ -d "$STAGE_PATH/inputs" ]; then
122
+ find "$STAGE_PATH/inputs" -type f -name "*.md" -o -name "*.json" -o -name "*.yaml" 2>/dev/null | while read -r f; do
123
+ echo " • $(basename "$f")"
124
+ done
125
+ fi
126
+ if [ $idx -gt 0 ]; then
127
+ PREV_IDX=$((idx - 1))
128
+ PREV_STAGE="${STAGE_IDS[$PREV_IDX]}"
129
+ echo -e " ${GRAY}• $PREV_STAGE/outputs/*${NC}"
130
+ fi
131
+ if [ -z "$(find "$STAGE_PATH/inputs" -type f 2>/dev/null)" ] && [ $idx -eq 0 ]; then
132
+ echo " (없음 - 첫 번째 스테이지)"
133
+ fi
134
+
135
+ echo ""
136
+
137
+ # Outputs
138
+ echo -e "${BLUE}[Outputs]${NC}"
139
+ if [ -d "$STAGE_PATH/outputs" ]; then
140
+ for f in "$STAGE_PATH/outputs"/*; do
141
+ if [ -e "$f" ]; then
142
+ echo " • $(basename "$f")"
143
+ fi
144
+ done
145
+ fi
146
+ if [ -d "$STAGE_PATH/templates" ]; then
147
+ echo -e " ${GRAY}(템플릿 참조: templates/)${NC}"
148
+ fi
149
+
150
+ echo ""
151
+
152
+ # Quick Commands
153
+ echo -e "${BLUE}[Quick Commands]${NC}"
154
+ echo " • /$SHORTCUT - 이 스테이지 바로 시작"
155
+ printf " • /run-stage %02d - 전제조건 확인 후 시작\n" "$num"
156
+
157
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
158
+ }
159
+
160
+ # 특정 스테이지 상세 보기
161
+ if [ -n "$STAGE_NUM" ]; then
162
+ # 앞의 0 제거
163
+ STAGE_NUM=$((10#$STAGE_NUM))
164
+ show_stage_detail "$STAGE_NUM"
165
+ exit 0
166
+ fi
167
+
168
+ # JSON 출력
169
+ if [ "$OUTPUT_JSON" = true ]; then
170
+ echo "["
171
+ for i in "${!STAGE_IDS[@]}"; do
172
+ STAGE_ID="${STAGE_IDS[$i]}"
173
+ STATUS="pending"
174
+ if [ -f "$PROGRESS_FILE" ]; then
175
+ STATUS=$(jq -r ".stages.\"$STAGE_ID\".status // \"pending\"" "$PROGRESS_FILE")
176
+ fi
177
+
178
+ if [ $i -gt 0 ]; then echo ","; fi
179
+ printf '{"id":"%s","name":"%s","ai":"%s","mode":"%s","status":"%s"}' \
180
+ "$STAGE_ID" "${STAGE_NAMES[$i]}" "${STAGE_AI[$i]}" "${STAGE_MODES[$i]}" "$STATUS"
181
+ done
182
+ echo "]"
183
+ exit 0
184
+ fi
185
+
186
+ # 목록 표시
187
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
188
+ echo -e "📋 ${WHITE}Pipeline Stages${NC}"
189
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
190
+ printf " ${GRAY}## %-16s %-14s %-12s Status${NC}\n" "Stage" "AI Model" "Mode"
191
+ echo "─────────────────────────────────────────────────────────────"
192
+
193
+ for i in "${!STAGE_IDS[@]}"; do
194
+ STAGE_ID="${STAGE_IDS[$i]}"
195
+ STAGE_NAME="${STAGE_NAMES[$i]}"
196
+ AI="${STAGE_AI[$i]}"
197
+ MODE="${STAGE_MODES[$i]}"
198
+
199
+ # 상태 가져오기
200
+ STATUS="pending"
201
+ if [ -f "$PROGRESS_FILE" ]; then
202
+ STATUS=$(jq -r ".stages.\"$STAGE_ID\".status // \"pending\"" "$PROGRESS_FILE")
203
+ fi
204
+
205
+ # 필터링
206
+ if [ "$FILTER_PENDING" = true ] && [ "$STATUS" != "pending" ]; then
207
+ continue
208
+ fi
209
+ if [ "$FILTER_COMPLETED" = true ] && [ "$STATUS" != "completed" ]; then
210
+ continue
211
+ fi
212
+
213
+ ICON=$(status_icon "$STATUS")
214
+ NUM=$(printf "%02d" $((i + 1)))
215
+
216
+ # 현재 스테이지 표시
217
+ if [ "$STAGE_ID" == "$CURRENT_STAGE" ]; then
218
+ ARROW=" ${YELLOW}←${NC}"
219
+ else
220
+ ARROW=""
221
+ fi
222
+
223
+ printf " %s %-16s %-14s %-12s %s%b\n" "$NUM" "$STAGE_NAME" "$AI" "$MODE" "$ICON" "$ARROW"
224
+ done
225
+
226
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
227
+
228
+ # 다음 단계 안내
229
+ if [ "$CURRENT_STAGE" != "none" ] && [ -n "$CURRENT_STAGE" ]; then
230
+ CURRENT_NUM=$(echo "$CURRENT_STAGE" | cut -d'-' -f1)
231
+ CURRENT_NUM=$((10#$CURRENT_NUM))
232
+ NEXT_NUM=$((CURRENT_NUM + 1))
233
+
234
+ if [ $NEXT_NUM -le 10 ]; then
235
+ NEXT_SHORTCUT="${STAGE_SHORTCUTS[$((NEXT_NUM - 1))]}"
236
+ printf "현재: ${CYAN}%s${NC} | 다음: ${GREEN}/run-stage %02d${NC} 또는 ${GREEN}/%s${NC}\n" \
237
+ "$CURRENT_STAGE" "$NEXT_NUM" "$NEXT_SHORTCUT"
238
+ else
239
+ echo -e "현재: ${CYAN}$CURRENT_STAGE${NC} | ${GREEN}파이프라인 완료!${NC}"
240
+ fi
241
+ else
242
+ echo -e "시작: ${GREEN}/init-project [name]${NC} 또는 ${GREEN}/run-stage 01${NC}"
243
+ fi
244
+
245
+ echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"