From mst
Recovers incomplete Claude Code workflows from .gran-maestro snapshots, resumes from last phase, and cleans orphan git worktrees. Activated by keywords like '복구' or /mst:recover.
npx claudepluginhub myrtlepn/gran-maestro --plugin mstThis skill uses the workspace's default tool permissions.
Claude Code 세션 종료 후 진행 중이던 워크플로우를 복구합니다.
Detects and resumes incomplete work after CLI crashes, network drops, or agent errors. Prioritizes TASKS.md tasks, progress logs, git worktree status, and conversation history.
Restores project context from prior sessions or after /clear by loading STATE.md, detecting checkpoints and incomplete work, presenting status, and routing to next actions.
Resumes interrupted Maestro sessions using existing active-session files and shared phase tracking. Use to continue multi-agent orchestration workflows after interruptions.
Share bugs, ideas, or general feedback.
Claude Code 세션 종료 후 진행 중이던 워크플로우를 복구합니다. 파일 기반 상태에서 자동으로 복구 가능한 태스크를 탐색합니다.
경로 규칙 (MANDATORY): 이 스킬의 모든
.gran-maestro/경로는 절대경로로 사용합니다. 스킬 실행 시작 시PROJECT_ROOT를 취득하고, 이후 모든 경로에{PROJECT_ROOT}/접두사를 붙입니다.PROJECT_ROOT=$(pwd)
{PLUGIN_ROOT}는 이 스킬의 "Base directory"에서skills/{스킬명}/을 제거한 절대경로입니다. 상대경로(.claude/...)는 절대 사용하지 않습니다.
~/.claude/user-profile.json (AskUserQuestion 컨텍스트, 비차단)~/.claude/user-profile.json을 Read한다.
user_profile_context = null로 처리하고 기존 동작을 유지한다 (graceful fallback).role (string)experience_level (string)domain_knowledge (string[])communication_style (string)user_profile_context = null로 처리한다 (워크플로우 차단 금지).AskUserQuestion과 사용자 설명 텍스트 작성 시:
communication_style을 최우선 반영한다.experience_level/domain_knowledge에 맞춰 용어 수준과 설명 깊이를 조절한다./mst:recover)먼저 {PROJECT_ROOT}/.gran-maestro/state/*/snapshot.json을 스캔한다.
중단된 스킬: {skill}, Step {N}/{M}재개: /mst:{skill} (필요 시 Step 정보 포함)PAC-6)REQ/태스크 복구 목록을 만들기 전에 {PROJECT_ROOT}/.gran-maestro/worktrees/*.meta.json 중
state == "cleaned"인 메타를 순회한다. cleaned 메타는 정상적으로는 실제 worktree 디렉토리,
git worktree 등록, 작업 브랜치가 모두 없어야 한다.
아래 조건 중 하나라도 참이면 해당 메타를 orphan으로 판단한다.
git worktree list --porcelain 결과에 메타의 path가 여전히 존재한다.git branch --list {branch} 결과가 존재한다.path 디렉토리/경로가 실제 파일시스템에 존재한다.orphan 감지 및 정리는 helper를 사용한다.
python3 {PLUGIN_ROOT}/scripts/mst.py worktree detect-orphans --clean --json
helper는 orphan마다 아래 순서로 강제 정리한다.
python3 {PLUGIN_ROOT}/scripts/mst.py worktree remove --path {p} --forcegit branch -D {branch}{PROJECT_ROOT}/.gran-maestro/worktrees/{taskId}.meta.json 제거recover 자체 로그는 stdout에 간결히 남긴다. --json 결과의 orphans[]를 확인해 아래 형식으로 출력한다.
[recover-orphan] detected taskId={taskId} path={p} branch={branch} reasons={worktree_listed,branch_exists,path_exists}
[recover-orphan] cleaned taskId={taskId}
정리 실패(failed가 비어 있지 않음) 시에는 해당 taskId와 실패 command/message를 출력하고, 메타를 삭제하지 않는다.
정상 cleaned 메타(실제 디렉토리/브랜치/등록 없음)는 출력 없이 skip한다.
requests/ 전체 스캔 → terminal 상태(completed/cancelled/failed) 제외 → 태스크 status.json 확인 → 복구 가능 목록 표시 → AskUserQuestion으로 복구 대상 선택 → 해당 Phase 재개
/mst:recover REQ-001)request.json + 모든 태스크 상태 확인 → 마지막 활성 Phase 판별 → 재개
/mst:recover REQ-001-01)tasks/01/status.json + spec.md의 Assigned Agent 확인 → 상태별 복구:
executing → CLI 프로세스 확인 → 없으면 외주 재실행review → 리뷰 재개 (git diff, phase3_protocol)feedback → 피드백 문서 기반 외주 재실행merging → merge 상태 확인 후 재개merge_conflict → git -C {worktree_path} status로 충돌 파일 목록 확인 후 출력 →
AskUserQuestion:
git -C {worktree_path} diff --check (마커 있으면 중단 + 재해소 안내)git -C {worktree_path} add -Agit -C {worktree_path} commit -m "Resolve merge conflicts in {REQ-ID}/{TASK-ID}"python3 {PLUGIN_ROOT}/scripts/mst.py worktree remove --path {worktree_path} --force (--force 필수: merge_conflict 상태에서는 미커밋 변경 존재, prune 자동 실행 포함)queued/pending/pre_check → 외주 실행/사전 검증 재실행pre_check_failed → 실패 내용 포함 외주 재실행AskUserQuestion으로 사용자 확인 후 실행
Phase 2 상태(pending/queued/executing/pre_check_failed/feedback)는 반드시 /mst:codex 또는 /mst:gemini 외주; Claude(PM) 직접 코드 작성 금지.
⚠️ CONTINUATION GUARD: 서브스킬 반환 후 즉시 다음 Step 진행 (hook이 자동 강제).
Assigned Agent 기준: codex → mst:codex; gemini → mst:geminiSkill(skill: "mst:codex", args: "{프롬프트} --dir {worktree_path} --trace {REQ-ID}/{TASK-NUM}/phase2-impl")
Skill(skill: "mst:gemini", args: "{프롬프트} --dir {worktree_path} --files {worktree_path}/**/* --trace {REQ-ID}/{TASK-NUM}/phase2-impl")
feedback 상태: feedback-RN.md 수정 요청을 프롬프트에 포함[MST skill={name} step={N}/{M} return_to={parent_skill/step | null}]skill: 현재 실행 중인 스킬 이름step: 현재 단계(N/M) 또는 서브스킬 종료 시 returnedreturn_to: 최상위 스킬이면 null, 서브스킬이면 {parent_skill}/{step_number}[MST skill={subskill} step=returned return_to={parent/step}][MST skill={name} step=1/3 return_to=null][MST skill={subskill} step=returned return_to={parent_skill}/{step_number}]| 마지막 상태 | 복구 동작 | Phase |
|---|---|---|
pending | 실행 큐에 삽입 | Phase 2 |
queued | 큐에 재삽입 | Phase 2 |
executing | 프로세스 확인 → 재실행 | Phase 2 |
pre_check | 사전 검증 재실행 | Phase 2 |
pre_check_failed | 피드백 첨부 재실행 | Phase 2 |
review | 리뷰 재개 | Phase 3 |
feedback | 피드백 기반 재실행 | Phase 4→2 |
merging | merge 상태 확인 | Phase 5 |
merge_conflict | 사용자에게 옵션 제시 | Phase 5 |
Gran Maestro — 복구 가능한 요청
═══════════════════════════════════════
REQ-001 "사용자 인증 기능 추가"
마지막 Phase: 2 (외주 실행)
복구 가능 태스크:
├── 01: executing → 재실행 필요
└── 02: pending → 큐에 삽입
REQ-003 "설정 페이지 리팩토링"
마지막 Phase: 3 (PM 리뷰)
복구 가능 태스크:
└── 01: review → 리뷰 재개
═══════════════════════════════════════
목록 출력 후 AskUserQuestion으로 복구 대상 선택:
옵션 구성:
옵션 포맷:
"{REQ-ID}: {title 앞 25자}""마지막 Phase: {N} ({상태}) | 태스크: {요약}""전체 복구 (all)" 옵션:
"전체 복구 (all)""복구 가능한 모든 요청을 순서대로 재개합니다"Other (자유 입력): 목록에 없는 REQ ID를 직접 입력하거나 콤마 구분으로 복수 지정 가능
예: REQ-005 또는 REQ-005,REQ-007
/mst:recover # 모든 미완료 요청 복구 목록
/mst:recover REQ-001 # 특정 요청 복구
/mst:recover REQ-001-01 # 특정 태스크 복구
/mst:list --all 확인REQ-NNN 형식 확인; /mst:list로 조회git worktree list로 확인; 수동 정리 필요할 수 있음