Skill156 estrellas del repoactualizado 2d ago
project-butler
Project memory workflow for init/upgrade, profile-aware setup, end session, normal/full close, file organization, document archiving, language switching, versioned update logs, rule review, status, wiki sync, and context recovery. Use for /project-butler, setup/初始化, foundation setup, profile setup, end session/收工, normal close, full close, foundation repair, organize files/整理文件, change language/切换语言, continue/接着上次, continue full context/全面回顾, review claude, sync wiki, status. Maintains project memory files.
Instalar en Claude Code
Copiargit clone https://github.com/JamesShi96/project-butler ~/.claude/skills/project-butlerDespués abre una sesión nueva de Claude Code; el skill carga automáticamente.
Definición
SKILL.md
# Project Butler — Project Memory Stack
Initialize standardized project memory:
```
上层(稳定原则)
┌─────────────────────────────────────┐
│ CLAUDE.md(项目宪法)← 人工确认 │
│ ↑ candidates(AI 自动收集候选) │
└─────────────────────────────────────┘
↑ 抽象沉淀
中层(当前快照)
┌─────────────────────────────────────┐
│ PROJECT.md(项目 Wiki)← AI 自动同步 │
│ 概览 / 结构 / 模块状态 / 文件索引 │
│ STRUCTURE.md(文件管理规则)← AI 自动│
│ 目录规则 / 匹配条件 / 整理历史 │
│ UPDATE_LOG.md(里程碑变化)← AI 自动 │
│ DOCS.md(文档索引 + 元数据)← AI 自动 │
│ .claude/project-profile.json(画像配置)│
│ .claude/profile-pending.json(画像待处理)│
└─────────────────────────────────────┘
↑ 状态汇总
下层(事实流水)
┌────────────────────┐ ┌────────────────────┐
│ log/(会话日志) │ │ TODO.md(执行清单)│
│ raw + summaries │ │ owner/deadline/ │
│ + archive(分级) │ │ deps │
└────────────────────┘ └────────────────────┘
↓
session-handoff.md(下次接手点)
```
Core idea: bottom feeds top, top constrains bottom. Logs and TODOs are raw facts. Handoff marks the next resume point. Wiki is the current snapshot. Structure manages file organization. Docs index manages document output. Update Log records versioned milestone changes. Constitution is stable principles.
Supports 3 language modes: English (`en`), Chinese (`zh`), or bilingual. All content adapts to the selected language.
---
## Step 0: Trigger Routing
Determine how this skill was triggered:
**A. "整理文件" / "organize files":**
1. Read `references/file-reorganization.md`
2. Execute **Mode A: Four-Phase Organize** (Discover → Ask or Plan → Plan → Execute)
3. Report and stop
**B. "收工" / "end session" / "结束会话" / "we're done" / "wrap up" / "done for today" / "normal close" / "full close":**
1. Execute the **End Session Flow** below (inline)
2. Report and stop
**C. Initialization (/project-butler, 初始化项目, setup project, etc.):**
→ Continue to **Init Flow** below
**D. "切换语言" / "change language":**
1. Read `references/language-change.md` + `references/language-adaptation.md`
2. Execute the Language Change Protocol
3. Report and stop
**E. "continue" / "接着上次" / "上次做到哪了":**
1. Read `references/continue.md`
2. Execute the Continue process (recover last session context)
3. Report and stop
**F. "continue full context" / "全面回顾" / "项目全景" / "full context":**
1. Read `references/continue-full-context.md`
2. Execute the Continue Full Context process (full project trajectory recovery)
3. Report and stop
**G. "review claude" / "审查规则" / "更新宪法" / "check the rules":**
1. Read `.claude/candidates.md`
2. Present pending candidates one by one for accept / reject / rewrite
3. For accepted or rewritten candidates, append to CLAUDE.md only after explicit user confirmation
4. Move processed candidates to adopted or rejected sections in `.claude/candidates.md`
5. Report and stop
**H. "sync wiki" / "同步项目" / "update overview" / "refresh overview":**
1. Read PROJECT.md, STRUCTURE.md, UPDATE_LOG.md, DOCS.md, TODO.md, and session-handoff.md if present
2. Rescan current project files and update PROJECT.md current snapshot, module map, file structure, key file index, links, and progress sections
3. Preserve user-authored content where possible
4. Report and stop
**I. "status" / "项目现状" / "where are we":**
1. Read PROJECT.md and session-handoff.md
2. Also read TODO.md and latest UPDATE_LOG.md entry if present
3. If `.claude/project-profile.json` or `.claude/profile-pending.json` exists, read `references/project-profile-system.md` and include profile debt / review queue in the dashboard
4. Present a compact project dashboard in the configured language: Project, Active Work, Recent Change, Profile, Next Best Step
5. Report and stop
**J. "foundation setup" / "profile setup" / "foundation repair" / "profile repair" / "profile sync":**
1. Read `references/project-profile-system.md`
2. Execute the matching Profile System flow
3. Report and stop
---
## End Session Flow
When triggered by "end session" / "结束会话" / "收工" / "we're done" / "wrap up" / "done for today" / "normal close" / "full close", execute in order:
1. **Write session log** → `log/session-YYYY-MM-DD-{slug}.md`
- Same-day multiple sessions: use slug to distinguish (e.g., `session-2026-04-21-prd-draft.md`)
- Format: see Session Log Format below
2. **Log Compaction** → if unarchived raw logs ≥ threshold (default 10, configured in CLAUDE.md):
read `references/log-compaction.md` and execute
3. **Update session-handoff.md** → refresh "current progress" and "next steps"
4. **Update PROJECT.md** → if structure/module status changed
5. **Update TODO.md** → mark completed tasks
6. **Collect constitution candidates** → append to `.claude/candidates.md` (see rules below)
7. **Profile impact scan** → if `.claude/project-profile.json` exists, `.claude/profile-pending.json` exists, or the user explicitly requested Normal Close / Full Close / profile sync:
- Read `references/project-profile-system.md`
- Run the Profile-Aware End Session flow
- For Normal Close: record profile-impacting changes in `.claude/profile-pending.json`
- For Full Close: produce a Scope Plan before changing profile docs
- Do not rewrite protected sections, document policies, or stable baselines without explicit confirmation
8. **File reorganization (incremental)** → read `references/file-reorganization.md`, execute Mode B
- If STRUCTURE.md missing: execute Mode A first to establish baseline
- Update `.claude/.file-snapshot.json`
9. **Document archiving** → read `references/document-archiving.md`, scan and archive document output
- Identify documents created/modified this session
- Classify by type, archive to `docs/` subdirectories
- Update `DOCS.md` index and metadata
- If DOCS.md missing: create it (upgrade compatibility)
10. **Evaluate & write update log** → read `references/update-log.md`
- Evaluate session significance
- If significant: determine bump level (major/minor/patch), calculate new version from UPDATE_LOG.md metadata, prepend versioned entry
- Optionall