{"id":"748678a0-db6f-49a1-94e2-c38da654ed51","shortId":"35gS8x","kind":"skill","title":"forge-bugfix","tagline":"一次修一个 bug + 独立 worktree + 独立 TDD + Bug 修复验收报告 + **多会话并行协调** + dev server 端口治理 + Pass 边界接力（v7.2）。\n每个 bug 从登记开始就创建结构化 Bug 修复验收报告。支持 3-4 个窗口同时修不同功能域的 bug，\n靠 `.forge/active.md` 心跳文件 + 功能域判重 + 合并前 merge 预演避免撞车；\n启动应用时优先使用项目统一 dev entrypoint，避免 worktree 抢端口或测到旧服务。\n在 Codex 环境中，前端复现和修复后自验","description":"# /forge-bugfix：一次一 bug + Bug 修复验收报告\n\n## 设计哲学\n\n**短会话、单 bug 隔离、结构化证据、可追溯、可丢弃。**\n\n核心机制：\n\n- **Bug 修复验收报告**：每个 bug 从登记/领取开始就创建 `docs/bugfix/reviews/BF-XX.md`\n  - 发现时：记录来源、现象、初始截图/日志、关联 Feature Spec\n  - 修复时：记录 worktree、TDD 红绿证据、根因、commit、涉及文件\n  - QA 时：forge-qa 回填前后端地址、环境身份校验、逐步截图、深度断言\n  - 人工验收时：用户只看\"人工验收指南\"和同一组验收地址，填最终结论\n- **两种验收节奏**：\n  - **单 bug 模式**：QA 全过后立即进入 P6.5，等用户验收该 bug\n  - **QA 自动闭环 / 批量模式**：单 bug QA 通过后标记 `qa-pass-pending-final-review`，最后由批次汇总统一交给用户验收\n- **新发现必须分流**（禁止顺手修）：\n  - 原 bug 未 Pass 前：只记录为“待确认新发现”，不进入当前修复\n  - 原 bug 已 Pass 后：先明确告知用户“本次 bug 修复已完成”，再询问是否写入文档\n  - 用户确认后，独立 bug → `docs/bugfix/backlog.md` 的待修区，分配 BF-XX 编号\n  - 用户确认后，新需求 → `docs/bugfix/backlog.md` 的新需求区，建议 /forge-prd 立项\n  - 用户确认后，模糊反馈 → `docs/bugfix/backlog.md` 的待澄清区\n  - 同根（并入当前修复）→ **AI 必须举证**（同文件/同函数/同数据流的具体证据），举证不通过默认独立 bug\n- **Pass 边界接力**：\n  - 只要原 bug 已 Pass，不论新问题来自用户验收、QA 发现，还是 AI 在修复中发现的衍生问题，都不得继续修\n  - AI 必须先说清楚：原 bug 已收敛、证据是什么、当前修复到此关闭\n  - 再问用户：是否把新问题更新到 `docs/bugfix/backlog.md` / 报告中\n  - 用户确认后，AI 完成 P7.5 分流，并给一段简短接力 prompt，让用户开另一个会话继续\n- **下一个 bug 默认建议新会话或 /clear、/compact**：\n  - 上下文干净 + 边界清晰 + 避免长会话的 scope 蔓延\n  - 除非用户明确要共因地一起修\n\n> 演进历史和设计决策背景见 `forge-cookbook/docs/forge-bugfix-changelog.md`。\n\n## 铁律\n\n1. **不做根因分析，就不写修复代码。** 直觉再强也要先验证。\n2. **每次只修 1 bug，或 1-2 个**经 P4.5 确认共因**的 bug**。其余进 `docs/bugfix/backlog.md`。\n3. **每个 bug 独立 worktree + 独立 TDD + 独立 commit + 独立 QA 回归**。批量只做编排，不合并工程单元。\n4. **修完不自动合并**，必须等用户填完单 bug 或批次最终验收结论。\n5. **没有 Bug 修复验收报告不算完**。每个 BF 编号必须有 `docs/bugfix/reviews/BF-XX.md`，经 forge-qa 和用户/批次两层验收后才进 P7。\n6. **新发现的 bug / 新需求 / 模糊反馈 → 原 bug Pass 后询问是否写入 `docs/bugfix/backlog.md`**，绝不在当前修复内夹带。\n7. **同根判定必须举证**。AI 声称\"这条新发现是当前 bug 同根\"时，必须列出具体证据（同文件、同函数、同数据流），证据不足默认为独立 bug。\n8. **并行协调必须登记**（v6.0）。P2 确认范围 + P3 创建 worktree 之后，必须在项目根 `.forge/active.md` 追加一行会话登记；P2 推荐前必须读 `.forge/active.md` 做功能域判重；P7 合并前必须跑 `git merge --no-commit --no-ff` 预演。清理 active 的责任在 forge-fupan 或 /forge-status，不在 forge-bugfix 自己。\n9. **自动闭环有上限**。同一 bug 连续回修失败 3 次，或遇到需求/设计/环境身份不确定，必须标记 `blocked-human` 并让用户判断，禁止无限循环。\n\n---\n\n## 流程总览\n\n```\n═══════════ 会话级（每会话一次，多次修复复用）═══════════\nP0  环境探测（前置脚本，自动执行）\nP1  问题理解 + 强制读 PRD/ENGINEERING/Bugfix 历史/Memory\n\n═══════════ 每次修复（一次一 bug，可循环）═══════════\nP2   范围推荐\n     ├─ AI 从 docs/bugfix/backlog.md 捞候选 + 列出本会话新报告的 bug\n     ├─ AI 接收 forge-qa 发现的结构化 bug（若来自 QA 自动闭环）\n     ├─ 推荐\"本次修 X\"（1 个 / 或 1-2 共因），其余 → backlog\n     └─ 用户确认范围\nP2.5 创建/更新 Bug 修复验收报告 docs/bugfix/reviews/BF-XX.md\n     ├─ 写入来源、现象、初始证据、Feature Spec 场景、功能域、当前状态\n     └─ 同步 backlog.md 的报告链接\nP3   创建 worktree（端口预检）+ 复现\nP4   根因追踪 + 假设验证 + 5 Whys + 修复方案确认\nP5   worktree 内独立 TDD 驱动修复 + 原子提交\nP5.3 ⭐ 更新 Bug 修复验收报告为待 QA 状态\n     ├─ 写入 TDD 红绿证据、根因、修复摘要、commit、涉及文件\n     └─ 写入人工验收指南草案，QA 区域留给 forge-qa\nP6   ⭐ 调用 forge-qa 自动验收\n     ├─ forge-qa 针对每个验证项跑自动化测试\n     ├─ 强校验 Frontend/Backend 地址、PID、cwd、commit 一致性\n     ├─ 把每个前端交互关键步骤截图嵌入报告\n     ├─ QA 全过 → 单 bug 模式进 P6.5；批量模式标记 qa-pass-pending-final-review\n     └─ QA 有挂 → 有界回 P5；达到上限或有疑问则 blocked-human\nP6.5 ⭐ 用户人工验收 / 批次最终验收\n     ├─ AI 输出\"请人工验收 @ docs/bugfix/reviews/BF-XX.md\"\n     ├─ 用户打开文档填\"你的验收\"列 + 最终结论（Pass / Fail / Pass + 新发现）\n     └─ 用户说\"验收了\" → AI 读报告 → 判定\nP7   ⭐ 按最终结论分流\n     ├─ Pass → worktree 合并决策（合并 / 暂存 / 推迟）\n     ├─ Fail → 回 P5（只修原 bug，不接新问题）\n     └─ Pass + 新发现 → 先完成当前修复的合并/暂存决策 → 进 P7.4\nP7.4 ⭐ Pass 边界确认 + 文档更新询问\n     ├─ 告知用户：本次 bug 已完成，当前修复到此关闭\n     ├─ 列出新问题来源：用户反馈 / QA 发现 / AI 发现的衍生问题\n     ├─ 询问是否写入 docs/bugfix/backlog.md / 报告索引\n     ├─ 用户确认 → 进 P7.5 分流，并输出简短接力 prompt\n     └─ 用户不确认 → 不写 backlog，不继续修新问题，结束本次 bugfix\nP7.5 ⭐ 新发现分流到 backlog\n     ├─ 逐条分析，AI 做分类判断（同根 / 独立 bug / 新需求 / 模糊反馈）\n     ├─ 同根（声称时必须举证）→ 新 bug 建议在新会话修\n     ├─ 独立 bug → backlog.md 的 🐛 待修区，分配 BF-XX\n     ├─ 新需求 → backlog.md 的 💡 新需求区，建议 /forge-prd 立项\n     └─ 模糊反馈 → backlog.md 的 🌀 待澄清区\nP8   沉淀：归档 backlog 对应条目 + bugfix 文档补记\n\n═══════════ 出口 ═══════════\n- 用户想继续修下一个 bug → 默认建议新会话或 /clear、/compact\n  （除非明确共因才本会话继续，由用户主动选择）\n- 全部完成 → 建议 /forge-review、/forge-ship 或 /forge-fupan\n```\n\n**红线**：\n1. 写任何修复代码前必须完成 P2-P4（含范围确认和 5 Whys 根因确认）\n2. 每个 BF 编号必须先有 Bug 修复验收报告（P2.5），修复后必须更新报告（P5.3）才能进入 QA\n3. 报告没有用户最终结论或批次最终结论前，**不进 P7**——即使 QA 全过\n4. 同根判定声称必须举证，证据不足默认独立 bug → 原 bug Pass 后问用户是否写入 backlog，再走新会话\n\n---\n\n## P0 环境探测（会话级·前置脚本，自动执行）\n\n```bash\n# === 基础信息 ===\n_BRANCH=$(git branch --show-current 2>/dev/null || echo \"unknown\")\n_ROOT=$(git rev-parse --show-toplevel 2>/dev/null || pwd)\necho \"分支: $_BRANCH\"\necho \"根目录: $_ROOT\"\necho \"---\"\n\n# === Git 状态 ===\necho \"=== Git 状态 ===\"\ngit status --porcelain 2>/dev/null | head -20\necho \"=== 最近 10 条提交 ===\"\ngit log --oneline -10 2>/dev/null\necho \"---\"\n\n# === 现有 worktree 清单 ===\necho \"=== 现有 worktree ===\"\ngit worktree list 2>/dev/null\necho \"---\"\n\n# === 复现引擎 1: gstack/browse → $BROWSE ===\nBROWSE=\"\"\nfor p in \"$_ROOT/.Codex/skills/gstack/browse/dist/browse\" \\\n         \"$HOME/.Codex/skills/gstack/browse/dist/browse\" \\\n         \"$_ROOT/.Codex/skills/browse/dist/browse\" \\\n         \"$HOME/.Codex/skills/browse/dist/browse\"; do\n  [ -x \"$p\" ] && BROWSE=\"$p\" && break\ndone\n[ -n \"$BROWSE\" ] && echo \"BROWSE=$BROWSE\" || echo \"BROWSE=（不可用）\"\n\n# === 复现引擎 2: Playwright → $PW_AVAILABLE ===\nPW_AVAILABLE=\"false\"\nif command -v npx &>/dev/null && npx playwright --version &>/dev/null 2>&1; then\n  PW_AVAILABLE=\"true\"\nelif python3 -c \"from playwright.sync_api import sync_playwright\" 2>/dev/null; then\n  PW_AVAILABLE=\"true\"\nfi\necho \"PW_AVAILABLE=$PW_AVAILABLE\"\n\n# === 框架 / 测试框架 / Dev Server 状态 ===\n# ... 框架探测 / 测试框架探测 ...\n\n# === 统一 dev server 入口 → $APP_URL ===\nAPP_URL=\"\"\nDEV_STATUS=\"\"\nif [ -f \"$_ROOT/package.json\" ] && (cd \"$_ROOT\" && npm run 2>/dev/null | grep -q \"dev:status\"); then\n  DEV_STATUS=\"$(cd \"$_ROOT\" && npm run dev:status 2>/dev/null || true)\"\n  echo \"$DEV_STATUS\"\n  APP_URL=\"$(printf \"%s\\n\" \"$DEV_STATUS\" | awk '/Frontend:/{print $2; exit}')\"\nelif [ -x \"$_ROOT/scripts/dev-stack.sh\" ]; then\n  DEV_STATUS=\"$(cd \"$_ROOT\" && bash scripts/dev-stack.sh status 2>/dev/null || true)\"\n  echo \"$DEV_STATUS\"\n  APP_URL=\"$(printf \"%s\\n\" \"$DEV_STATUS\" | awk '/Frontend:/{print $2; exit}')\"\nelse\n  # 兼容旧项目：只读探测，不把探测结果当作 worktree 启动许可\n  for port in 3456 3000 4000 5173 8080 8000; do\n    if lsof -i :\"$port\" -sTCP:LISTEN &>/dev/null 2>&1; then\n      APP_URL=\"http://localhost:$port\"\n      _PID=$(lsof -ti :\"$port\" -sTCP:LISTEN 2>/dev/null | head -1)\n      _CWD=$(lsof -p \"$_PID\" 2>/dev/null | awk '$4==\"cwd\"{print $9}')\n      echo \"APP_URL=$APP_URL (PID=$_PID cwd=$_CWD)\"\n      break\n    fi\n  done\nfi\n[ -z \"$APP_URL\" ] && echo \"APP_URL=（未检测到运行中的应用）\"\n\n# === 项目文档清单 ===\nDOC_PRD=\"\"; DOC_ENG=\"\"; DOC_QA=\"\"; DOC_BACKLOG=\"\"; DOC_BUGFIX=\"\"; DOC_REVIEWS=\"\"\nfor p in \"$_ROOT/docs/PRD.md\" \"$_ROOT/PRD.md\"; do [ -f \"$p\" ] && DOC_PRD=\"$p\" && echo \"PRD: $p\" && break; done\nfor p in \"$_ROOT/docs/ENGINEERING.md\" \"$_ROOT/ENGINEERING.md\"; do [ -f \"$p\" ] && DOC_ENG=\"$p\" && echo \"ENGINEERING: $p\" && break; done\nfor p in \"$_ROOT/docs/QA.md\" \"$_ROOT/QA.md\"; do [ -f \"$p\" ] && DOC_QA=\"$p\" && echo \"QA: $p\" && break; done\n\n# backlog（bug 任务池，单一入口）\nfor p in \"$_ROOT/docs/bugfix/backlog.md\" \"$_ROOT/backlog.md\"; do\n  [ -f \"$p\" ] && DOC_BACKLOG=\"$p\" && echo \"BACKLOG: $p\" && break\ndone\nif [ -z \"$DOC_BACKLOG\" ]; then\n  DOC_BACKLOG=\"$_ROOT/docs/bugfix/backlog.md\"\n  echo \"BACKLOG（首次使用，将从模板初始化）: $DOC_BACKLOG\"\nfi\n\n# reviews 目录（每个 bug 一个 Bug 修复验收报告）\nDOC_REVIEWS=\"$_ROOT/docs/bugfix/reviews\"\nmkdir -p \"$DOC_REVIEWS\" 2>/dev/null\necho \"REVIEWS 目录: $DOC_REVIEWS\"\n\n[ -d \"$_ROOT/docs/bugfix\" ] && DOC_BUGFIX=\"$_ROOT/docs/bugfix\" && echo \"BUGFIX 历史: $DOC_BUGFIX\"\n\n# === 报告目录 ===\nREPORT_DIR=\"$_ROOT/.gstack/bugfix-reports\"\nmkdir -p \"$REPORT_DIR/screenshots\" 2>/dev/null\necho \"报告目录: $REPORT_DIR\"\n\n# === 并行会话环境（v6.0 新增）===\n# active.md: 跨 worktree 的心跳文件，项目根 .forge/active.md\nmkdir -p \"$_ROOT/.forge\" 2>/dev/null\nACTIVE=\"$_ROOT/.forge/active.md\"\nif [ ! -f \"$ACTIVE\" ]; then\n  # 首次使用，从模板初始化（模板路径按 skill 安装位置回退）\n  for tpl in \"$HOME/.claude/skills/forge-bugfix/templates/active.md\" \\\n             \"$HOME/.claude/skills/forge/skills/forge-bugfix/templates/active.md\"; do\n    [ -f \"$tpl\" ] && cp \"$tpl\" \"$ACTIVE\" && echo \"✅ 初始化 .forge/active.md（请编辑功能域声明区）\" && break\n  done\nfi\necho \"ACTIVE=$ACTIVE\"\n\n# 当前 Claude Code session id（通过 PID 回溯 ~/.claude/sessions/<pid>.json）\nSID_SCRIPT=\"\"\nfor s in \"$HOME/.claude/skills/forge-bugfix/scripts/get-session-id.sh\" \\\n         \"$HOME/.claude/skills/forge/skills/forge-bugfix/scripts/get-session-id.sh\"; do\n  [ -x \"$s\" ] || [ -f \"$s\" ] && SID_SCRIPT=\"$s\" && break\ndone\nCURRENT_SID=\"\"\nif [ -n \"$SID_SCRIPT\" ]; then\n  CURRENT_SID=$(bash \"$SID_SCRIPT\" 2>/dev/null || echo \"\")\nfi\n[ -n \"$CURRENT_SID\" ] && echo \"SESSION_ID=$CURRENT_SID\" || echo \"SESSION_ID=（无法自动获取，后续 P3 会提示）\"\n\n# 扫一眼 active.md 里\"进行中会话\"节，报告当前有哪些并行会话\nif [ -f \"$ACTIVE\" ]; then\n  echo \"--- 当前并行会话 ---\"\n  awk '/^## 进行中会话/{flag=1;next} /^## /{flag=0} flag && /^- /{print}' \"$ACTIVE\" | grep -v '<!--' || echo \"（暂无）\"\nfi\n```\n\n**关键变量**：\n\n| 变量 | 含义 |\n|------|------|\n| `$BROWSE` | gstack/browse 路径，空=不可用 |\n| `$PW_AVAILABLE` | Playwright 是否可用 |\n| `$APP_URL` | 本地应用 URL（优先来自项目 `dev:status` / `dev-stack status`）|\n| `$DOC_PRD` / `$DOC_ENG` / `$DOC_BUGFIX` | 项目文档路径 |\n| `$DOC_BACKLOG` | bug 任务池 `docs/bugfix/backlog.md` |\n| `$DOC_REVIEWS` | Bug 修复验收报告目录 `docs/bugfix/reviews/` |\n| `$REPORT_DIR` | 截图和报告输出目录 |\n| `$ACTIVE` | 并行心跳文件 `.forge/active.md`（v6.0） |\n| `$CURRENT_SID` | 当前 Claude Code session id（v6.0） |\n\n⚠️ **新增**：APP_URL 不再优先扫描常见端口。若项目提供 `npm run dev:status` 或 `scripts/dev-stack.sh`，必须从统一状态输出读取 URL、PID、cwd，防止 worktree 端口劫持（历史踩坑：worktree 旧 uvicorn 抢 8080，主项目改动不生效，30+ 分钟才定位）。\n\n⚠️ **v6.0 新增**：P0 结束时 AI 必须向用户报告当前 `.forge/active.md` 的\"进行中会话\"情况——如果发现疑似僵尸（worktree 目录不存在 / 分支已合并到 main），**建议用户先跑 /forge-status 清理**再继续。AI 不自己清（那是 /forge-status 的职责）。\n\n---\n\n## P1 问题理解 + 上下文采集（会话级·一次执行）\n\n> ⚡ **会话级声明**：本步只在会话首次进入时执行一次。同一会话做多次修复时，P1 不重读，直接复用上下文。\n\n### 1.1 解析用户输入\n\n用户报告 bug 的方式：\n- 直接描述现象 / 粘贴错误 / 提供截图 / 引用已有 Bug ID\n\n### 1.2 强制读取项目文档\n\n**不读 PRD 不知道\"正确\"，不读 ENGINEERING.md 不理解数据流，不读 bugfix 历史会重复排查。**\n\n| 文档 | 必须/按需 | 读什么 |\n|------|-----------|--------|\n| PRD (`$DOC_PRD`) | **必须** | 功能预期行为、验收标准 |\n| ENGINEERING.md (`$DOC_ENG`) | **必须** | 架构、数据流、模块边界 |\n| Bugfix 历史 (`$DOC_BUGFIX`) | **必须** | 已修 bug 的根因 — 防重复排查 |\n| **Backlog (`$DOC_BACKLOG`)** | **必须** | 任务池 — 了解已登记待修 bug / 新需求 / 待澄清反馈 |\n| **已归档已处理区** | **必须** | 历史修复回溯 — 以后遇到类似问题时搜这里 |\n| QA.md (`$DOC_QA`) | 按需 | 已知问题列表 |\n| Memory（MEMORY.md） | **必须** | feedback 类条目 — 历史踩坑 |\n| `git log --since=\"3 days\" -- affected-files` | 按需 | 最近变更（回归 Bug 必看）|\n\n#### Bugfix 历史检索\n\n```bash\nif [ -n \"$DOC_BUGFIX\" ]; then\n  ls -t \"$DOC_BUGFIX\"/*.md 2>/dev/null | head -5\n  grep -rl \"<用户描述的关键词>\" \"$DOC_BUGFIX\" 2>/dev/null\nfi\n```\n\n匹配到历史记录 → AskUserQuestion：\"这个问题与 BF-XXXX-N 类似，上次根因是 XXX，沿用还是重新排查？\"\n\n### 1.3 检查工作区状态\n\n```bash\ngit status --porcelain\n```\n\n主仓库有未提交变更 → AskUserQuestion：\n- A) 先提交 — commit 后再开始（推荐）\n- B) 先暂存 — stash，修复完 pop\n- C) 直接开始 — worktree 隔离，不影响主仓库\n\n### 1.4 信息不足时\n\n通过 AskUserQuestion 一次问一个：什么操作触发？预期行为？实际行为？一直存在还是最近出现？\n\n---\n\n## P2 范围推荐（多来源捞候选 + 写入 backlog.md）\n\n> 🎯 核心：不做\"全量分诊排序后逐个修\"，而是\"AI 推荐单次修复范围，其余进 backlog.md\"。\n> **v6.0 新增**：P2 必须做功能域判重（读 `.forge/active.md`），决定**同域合并到已有会话** vs **异域鼓励新窗口并行**。\n> **v7.0 新增**：forge-qa 发现的问题也是正式入口。QA 自动闭环可以批量登记 bug，但修复执行仍然一次一个 bug。\n\n### 2.0 并行状态读取 + 功能域准备（v6.0 新增）\n\n**硬性步骤**。在 2.1 捞候选之前，AI 必须：\n\n1. **读 `.forge/active.md`**\n   - 解析\"功能域声明\"区 → 得到本项目的合法功能域标签清单 `$DOMAINS`\n   - 解析\"进行中会话\"节 → 得到所有占用中的域集合 `$BUSY_DOMAINS`（多域条目视为同时占用多个）\n   - 如果 `.forge/active.md` 不存在，AI 提示用户\"首次使用并行化，需要你在 .forge/active.md 里声明功能域标签（示例已给出）\"，并暂停等用户确认后再继续\n\n2. **给每条候选 bug 打功能域标签**\n   - 标签必须从 `$DOMAINS` 选取，不得自创\n   - 重构型 bug 允许多域（逗号分隔），任一域与 `$BUSY_DOMAINS` 有交集即判冲突\n   - 无法判定时向用户确认，不猜测\n\n3. **对照判定**\n   - bug.功能域 ∩ `$BUSY_DOMAINS` ≠ 空 → 标记\"⚠️ 域冲突：域 X 当前由 session Y 占用\"\n   - bug.功能域 ∩ `$BUSY_DOMAINS` = 空 → 标记\"✅ 可并行\"\n\n### 2.1 AI 捞候选\n\n候选来源有三个：\n\n1. **用户本会话报告的 bug**（直接描述）\n2. **forge-qa 发现的结构化 bug**（来自功能开发后的 QA 自动闭环或完整 QA 报告）\n3. **`$DOC_BACKLOG` 的 🐛 待修区**（跨会话登记的）\n\nforge-qa 传入的问题必须包含：标题、严重度、关联 Feature Spec 场景、复现步骤、截图/日志证据、Frontend/Backend 地址、环境身份摘要、是否属于本轮功能范围。缺字段则先补齐报告，不直接修。\n\nAI 合并三个来源，推荐**本次修哪个/哪些**：\n\n```\n推荐规则：\n- 默认推荐 1 个 bug\n- 当且仅当 AI 判断 2 个 bug 共享同一根因时，可推荐 1-2 个（必须举证）\n- 共因判断标准：\n  ✓ 修同一组文件\n  ✓ 改同一个函数/数据结构\n  ✓ 同一个上游依赖（如同一个 API 端点失效）\n- 不共因的\"看起来类似\" → 拆开走多次修复（单独会话）\n- 从 backlog 捞候选时，优先级 P0 > P1 > P2，相同优先级按登记时间\n```\n\n### 2.2 AskUserQuestion 确认\n\n```\n🎯 本次修复范围推荐\n\n本会话新报告：N 个问题\nBacklog 待修区：M 个条目（P0: X 个 / P1: Y 个 / P2: Z 个）\n当前并行会话：K 个（域 asr / 域 player ... 被占用）\n\n我推荐本次修：\n\n  ✅ 本次：[Bug A]（BF-0419-2）\n     来源：本会话新报告 / 或 backlog 登记于 2026-04-17\n     功能域：asr\n     并行判定：✅ 可并行（域 asr 当前无活跃会话）\n        或：⚠️ 域冲突（域 asr 已被 session abc-123 占用——建议你切去那个窗口加入而非新开）\n     理由：阻塞核心流程且独立可定位（或：Bug A + Bug C 共因 = XX.tsx 的 source 字段处理）\n\n  📋 推迟到 backlog（下次修复或下次会话再说）：\n     - Bug B: [症状] → 写入 backlog.md 🐛 待修区（P1，域 auth）\n     - Bug D: [症状] → 写入 backlog.md 🐛 待修区（P2，域 player）\n     - 新需求 N1: [描述] → 写入 backlog.md 💡 新需求区（建议 /forge-prd）\n\n我会把推迟的写入 `$DOC_BACKLOG`，把本次修复的在 P3 登记到 `.forge/active.md`。\n\nA) 同意推荐 — 进入 P3 创建 worktree 并登记 active\nB) 调整范围 — 改修 [其他 bug]\nC) 我想多修一些 — 违反单次修复原则，请说明理由\nD) 域冲突，我切到已有会话 — 本次终止，去 session abc-123 的窗口继续\n```\n\n### 2.3 写入 backlog.md\n\n用户确认后，把推迟的条目追加到 `$DOC_BACKLOG` 的对应区：\n\n**🐛 待修区（独立 bug）**：追加一行到表格：\n\n```markdown\n| BF-0419-3 | [症状一句话] | 会话 2026-04-19 用户报告 | [相关文件/模块] | auth | P1 | pending | — | docs/bugfix/reviews/BF-0419-3.md |\n```\n\n**💡 新需求区**：追加一行到表格：\n\n```markdown\n| N-0419-1 | [新需求一句话] | 会话 2026-04-19 用户报告 | 2026-04-19 | 待立项 |\n```\n\n**🌀 待澄清区**：追加一行到列表：\n\n```markdown\n- [2026-04-19] [模糊反馈原话]，未复现 / 待澄清\n```\n\n如果 `$DOC_BACKLOG` 不存在，AI 从模板 `skills/forge-bugfix/templates/backlog.md` 初始化。\n\n### 2.4 Bug 编号\n\n确认范围时为本次修复分配编号：`BF-{MMDD}-{N}`（N = 当日已用编号 +1）。\n- 编号用于：worktree 命名、commit message、Bug 修复验收报告文件名\n- 从 backlog 捞的条目，沿用其原编号，不重新分配\n\n### 2.5 创建 / 更新 Bug 修复验收报告（硬性）\n\n确认本次修复范围后，AI 必须确保 `$REVIEW_DOC=\"$DOC_REVIEWS/${BUG_ID}.md\"` 存在：\n\n```bash\nREVIEW_DOC=\"$DOC_REVIEWS/${BUG_ID}.md\"\nif [ ! -f \"$REVIEW_DOC\" ]; then\n  cp \"$HOME/.claude/skills/forge-bugfix/templates/review-checklist.md\" \"$REVIEW_DOC\"\nfi\n```\n\n然后写入报告的前置事实：\n\n| 区域 | 填什么 |\n|---|---|\n| 当前状态 | `pending` 或 `in-progress` |\n| 问题发现记录 | 来源、原始描述、关联 Feature Spec、初始影响范围 |\n| 初始证据 | 用户截图、QA 截图、console/network 摘要、日志路径 |\n| 复现记录 | 当前复现结论和待执行步骤 |\n| 验收入口 | 如已知 Frontend/Backend 地址，先写入；最终以 P6 forge-qa 强校验结果为准 |\n\n同时把 `$DOC_BACKLOG` 中该 bug 的“报告”列指向 `docs/bugfix/reviews/${BUG_ID}.md`。\n\n**禁止**等到修完代码才创建报告。报告是单个 bug 的过程案卷，不是最后的附录。\n\n---\n\n## P3 创建 worktree + 复现\n\n### 3.1 创建 worktree\n\n```bash\n# Bug 编号已在 P2.4 确定，例如 BF-0418-9\nBUG_ID=\"BF-0418-9\"\nWT_NAME=\"bf-${BUG_ID#BF-}\"  # → bf-0418-9\nWT_PATH=\"$_ROOT/.worktrees/$WT_NAME\"\nWT_BRANCH=\"bugfix/$WT_NAME\"\n\ngit worktree add \"$WT_PATH\" -b \"$WT_BRANCH\"\necho \"✅ worktree 创建: $WT_PATH (分支: $WT_BRANCH)\"\n```\n\n### 3.1.5 登记 .forge/active.md（v6.0 硬性步骤）\n\nworktree 创建成功之后**立即**登记，不得拖到修复结束再补。\n\n```bash\n# 字段：session id / worktree 相对路径 / 任务 id / 功能域\nDOMAIN=\"<P2.0 打好的功能域标签，单域或逗号分隔多域>\"\nREL_WT=\"${WT_PATH#$_ROOT/}\"   # 存相对路径，便于跨机器\nLINE=\"- session: $CURRENT_SID / worktree: $REL_WT / 任务: $BUG_ID / 域: $DOMAIN\"\n\n# 追加到 active.md 的\"进行中会话\"节末尾（用 awk 精确插入在 \"---\" 之前）\npython3 -c \"\nimport pathlib,re\np=pathlib.Path('$ACTIVE')\ntxt=p.read_text()\n# 找到'## 进行中会话'节，在它后面的（暂无进行中会话）或第一个 --- 之前插入\npat=re.compile(r'(## 进行中会话\\n[\\s\\S]*?)(\\n---)', re.M)\nline='''$LINE'''\ndef repl(m):\n    body=m.group(1)\n    # 去掉占位行\n    body=re.sub(r'\\n（暂无进行中会话）', '', body)\n    if not body.endswith('\\n'):\n        body+='\\n'\n    return body + line + '\\n' + m.group(2)\np.write_text(pat.sub(repl, txt, count=1))\n\"\n\necho \"✅ 已登记到 .forge/active.md: session=$CURRENT_SID 域=$DOMAIN\"\n```\n\n**硬性要求**：\n- `$CURRENT_SID` 为空时 AI 必须停下问用户，不得用 \"unknown\" 或占位符登记\n- 登记失败（awk 未匹配等）必须向用户报错，不得静默跳过\n- backlog.md 中对应 bug 的状态同时改 `in-progress`，\"领取会话\"字段填 session id 前 12 位即可\n\n### 3.2 ⚠️ worktree Dev Server 契约\n\n**强制步骤**。历史踩坑：worktree 内启动的服务和主仓库抢同一端口，curl/前端打到旧代码上，调试 30+ 分钟。\n\n如果本 bug 只需读代码和单元测试即可复现，可以不启动应用；一旦需要浏览器、curl、截图或端到端复现，就必须走项目统一 dev server 入口。\n\n```bash\ncd \"$WT_PATH\"\n\nif [ -f package.json ] && npm run 2>/dev/null | grep -q \"dev:status\"; then\n  npm run dev:status || true\n  npm run dev\n  npm run dev:status | tee /tmp/forge-dev-status.txt\n  APP_URL=$(awk '/Frontend:/{print $2; exit}' /tmp/forge-dev-status.txt)\nelif [ -x scripts/dev-stack.sh ]; then\n  bash scripts/dev-stack.sh status || true\n  bash scripts/dev-stack.sh start\n  bash scripts/dev-stack.sh status | tee /tmp/forge-dev-status.txt\n  APP_URL=$(awk '/Frontend:/{print $2; exit}' /tmp/forge-dev-status.txt)\nelse\n  echo \"未发现统一 dev server 入口；必须显式选择非默认端口，并记录 PID/cwd/URL\"\n  echo \"旧项目兜底探测：\"\n  for port in 3456 3000 4000 5173 8080 8000; do\n    PID=$(lsof -ti :\"$port\" -sTCP:LISTEN 2>/dev/null | head -1)\n    if [ -n \"$PID\" ]; then\n      CWD=$(lsof -p \"$PID\" 2>/dev/null | awk '$4==\"cwd\"{print $9}')\n      echo \"端口 $port: PID=$PID cwd=$CWD\"\n    fi\n  done\nfi\n```\n\n**硬性要求**：\n- 有 `npm run dev:status` 或 `scripts/dev-stack.sh` 时，不得裸跑 `uvicorn` / `vite` / `next dev`。\n- `APP_URL` 必须从状态输出读取，传给复现、截图和 forge-qa；不得凭常见端口猜。\n- 状态输出必须显示监听进程 cwd 属于当前 worktree；不一致就先 `npm run dev:stop` / `bash scripts/dev-stack.sh stop` 后重启。\n- 旧项目没有统一入口时，AI 必须把端口、PID、cwd、URL 写进报告，且不得占用主分支固定端口。\n\n### 3.3 切换到 worktree 工作\n\n```bash\ncd \"$WT_PATH\"\n# 后续所有操作（复现、修改、commit）都在 worktree 内进行\n```\n\n### 3.4 复现 Bug\n\n**确定性复现是调查的核心。无法复现就无法验证修复。**\n\n引擎优先级：Codex browser-use:browser（可用时） > Playwright / gstack-browse > 纯代码\n\n#### Codex browser-use:browser（Codex + Browser Use 插件可用时）\n\n用于前端页面、交互、视觉、控制台相关 bug 的复现：\n\n- 打开 P3.2 得到的 `APP_URL`，不得猜端口\n- 按用户路径操作页面，采集 DOM snapshot 和关键状态截图\n- 复现截图写入 `docs/bugfix/reviews/assets/${BUG_ID}/`，并在报告“初始证据 / 复现截图”区内嵌\n- 读取 console logs，错误写入报告\n- 如果代码或 build 刚变更，验证前 reload 页面并重新采集 DOM/screenshot\n\n规则：\n\n1. 执行浏览器动作前必须加载并遵守 `browser-use:browser` skill。\n2. 使用 Codex in-app browser 的 `iab` backend；不要因为 Computer Use 工具可见就跳过 Browser Use。\n3. Computer Use 只在 Browser Use 不可用、被中断或目标不是浏览器页面时兜底，兜底原因必须写入报告。\n4. P3 复现可以用 Browser Use；P6 正式 QA 仍必须交给 forge-qa。\n\n#### gstack/browse（`$BROWSE` 非空时）\n\n```bash\n$BROWSE goto $APP_URL/path/to/page\n$BROWSE screenshot $REPORT_DIR/screenshots/${BUG_ID}-before.png\n$BROWSE snapshot -i              # 查可交互元素\n$BROWSE click @e5                # 触发 bug\n$BROWSE snapshot -D              # 查变化\n$BROWSE console --errors         # 查 JS 错误\n$BROWSE network                  # 查失败请求\n```\n\n#### Playwright（`$PW_AVAILABLE=true`）\n\n```bash\nnpx playwright test --grep \"related-test\"\nnpx playwright screenshot $APP_URL/path /tmp/${BUG_ID}-before.png\n```\n\n#### 纯代码（始终可用）\n\n```bash\ncurl -s $APP_URL/api/endpoint | python3 -m json.tool\nnpm test -- --grep \"related-test\" 2>/dev/null\npython3 -m pytest -k \"related-test\" -v 2>/dev/null\ntail -50 $_ROOT/logs/*.log 2>/dev/null\n```\n\n**无法复现 → 停止**。AskUserQuestion 升级或收集更多证据。\n\n---\n\n## P4 根因追踪 + 假设验证 + 方案确认\n\n### 4.1 根因追踪\n\n从症状回溯到根因：\n1. **Grep 定位引用**：用错误消息、函数名、API 端点搜索\n2. **Read 追踪调用链**：从入口点沿调用链追踪\n3. **画数据流**：输入 → 处理 → 输出，哪一步断裂？\n4. **检查最近变更**：`git log --oneline -20 -- <affected-files>`\n\n### 4.2 模式检查清单（追踪时内嵌）\n\n- **竞态条件** — 间歇性、时序敏感 → 查共享状态并发访问\n- **空值传播** — TypeError → 查可选值缺少守卫\n- **状态不同步** — 数据不一致、部分更新 → 查事务/回调/生命周期\n- **前后端不一致** — 前端异常但 API 正确 → 查字段映射、类型转换\n- **缓存过期** — 旧数据 → 查 Redis/CDN/浏览器/SW 缓存版本号\n- **配置漂移** — 本地正常线上不行 → 查环境变量、特性开关\n- **进程身份** — 改了代码没效果 → 查进程 cwd（worktree 端口劫持是典型）\n- **SQL/查询错误** — 数据缺失或重复 → 查 WHERE/JOIN/去重\n- **开关/数据就绪错位** — API 通过但 UI 仍不对 → 查 feature flag、config、DB settings、后端 `enabled` 字段、测试数据是否足以展示用户问题\n\n### 4.2.1 用户问题闭环检查（前端/交互 bug 必做）\n\n如果 bug 来自用户反馈，AI 必须把用户原话转成一句可验收断言：\n\n```\n用户原话：<用户看到/无法完成的问题>\n闭环断言：修复后，用户在 <页面/流程> 中应该能 <看到/完成的结果>\n证明方式：<截图 / 交互 / API / 测试命令>\n```\n\n后续 P5/P6/P6.5 都以这句闭环断言为准。**接口 200、单测通过、没有 console error 都只是证据，不等于用户问题闭环。**\n\n### 4.2.2 配置 / 开关 / 数据就绪门禁\n\n涉及页面展示、权限边界、数据可见性、灰度发布、冷启动、实验开关的 bug，根因阶段必须检查并写入报告：\n\n| 检查面 | 必查内容 |\n|---|---|\n| Feature flag / config | 配置文件、环境变量、远程配置、DB settings 是否符合预期 |\n| 后端返回状态 | API 是否返回 `enabled/disabled`、权限状态、空态原因 |\n| 数据就绪 | 本地/测试/线上数据是否足以让用户看到目标状态 |\n| UI fallback | 前端是否因开关/空态/error 走了合理 fallback |\n\n如果配置或数据不满足用户闭环断言，不得声称 bug 已修复；应修正配置/数据，或标记 `blocked-human` 请用户确认开关策略。\n\n### 4.3 假设验证（标签化日志）\n\n在疑似根因处加**标签化临时日志**，每条标注假设编号：\n\n```\n命名规则：[DEBUG H{N}] — N 是假设编号\n  console.log('[DEBUG H1] feedItems length:', items.length)\n  logger.info(f'[DEBUG H2] query params: {params}')\n```\n\n复现后查日志，按 `[DEBUG HN]` 过滤验证。\n\n### 4.4 三振出局\n\n3 个假设都失败 → 立即停止。AskUserQuestion：\n\n```\nA) 继续调查 — 我有新假设：[描述]\nB) 升级处理 — 需要更了解系统的人\nC) 埋点等待 — 加日志，下次触发时捕获\nD) 放弃本次尝试 — git worktree remove，开新会话用精炼描述重启\n   （适用于上下文已嘈杂的情况）\n```\n\n### 4.5 5 Whys 根因确认 + 方案确认\n\n**假设验证通过后不直接动手。先向用户解释根因 + 方案，确认后才进 P5。**\n\n通过 AskUserQuestion，用 5 Whys 因果链：\n\n```\n🔍 根因定位完成（{BUG_ID}）\n\n问题：[用户看到的现象]\n\n5 Whys 因果链：\n  1. 为什么 [症状]？→ 因为 [直接原因]\n  2. 为什么 [直接原因]？→ 因为 [更深一层]\n  3. 为什么 [更深一层]？→ 因为 [根因]\n  ✅ 根因：[一句话]\n\n影响范围：[影响哪些功能/页面]\n\nBug 类型：[选一个]\n  数据流断裂 / 前后端不一致 / 状态同步 / 配置漂移\n  / 工具链约束 / UI 渲染 / 兄弟路径遗漏 / 进程身份\n\n修复方案：\n  A) [用\"做什么\"描述，不写代码] （推荐）\n  B) [备选]\n\n推荐 A，理由 [一句话]。\n```\n\n**用户确认才进 P5。**\n\n### 红旗信号\n\n- \"先临时修一下\" — 没有\"临时\"。要么修到位，要么升级。\n- 还没追踪数据流就提方案 — 在猜。\n- 每次修复都暴露新问题 — 错误层级。\n\n---\n\n## P5 worktree 内最小修复 + 原子提交\n\n### 5.1 修复原则\n\n- **修根因不修症状** — 最小变更，消除实际问题\n- **最少文件、最少行数** — 抵制\"顺手重构\"\n- **只修本次范围内的 bug，不加功能**\n\n### 5.2 ⚠️ 修复中的范围控制（默认硬性拒绝 + 同根必须举证）\n\n**修复过程中识别到以下信号 → 立即停下，列为“待确认新发现”，不在本次修复中处理。**\n\n原 bug 尚未 Pass 时，不把这些新问题正式写入 backlog。AI 只在当前报告或会话回复里保留“待确认新发现”摘要，等原 bug 通过 P6/P6.5 后进入 **P7.4 Pass 边界确认**，由用户决定是否写入文档。\n\n| 信号 | 处理 |\n|------|------|\n| 用户说\"顺便加...\"、\"另外...\"、\"延伸需求\"、\"我希望...\"、\"如果能...\" | 列为待确认新需求；原 bug Pass 后询问是否写入 `$DOC_BACKLOG` 的 💡 新需求区，并建议走 /forge-prd 立项 |\n| 验收反馈中描述了当前功能不存在的行为 | 同上（大概率是新需求） |\n| AI 自己想到\"顺手重构\"、\"加 lint\"、\"优化下\" | **硬性拒绝**：不写入 backlog（backlog 不是 AI 想法垃圾桶），在相关代码加 `// REFACTOR: {想法}` 注释即可，下次动到这个文件时再看 |\n| 修复中发现新 bug（明显不共因）| 列为待确认独立 bug；原 bug Pass 后询问是否写入 `$DOC_BACKLOG` 的 🐛 待修区并分配 BF-XX |\n| 修复中怀疑发现\"同根\"的另一个 bug | **必须举证**（下文 5.2.1）否则默认独立 bug |\n\n#### 5.2.1 同根判定的举证要求（硬约束）\n\nAI 不得轻易声称\"这个新发现和当前 bug 同根、要一起修\"。声称同根必须满足以下**至少一项**并向用户展示证据：\n\n- ✓ **同一文件的同一函数** 被两个症状触发（贴代码位置：文件名:行号）\n- ✓ **同一个数据结构/状态字段** 的错误处理引发两个症状（贴字段名 + 引用点）\n- ✓ **同一个上游依赖失效**（同一个 API 端点 / 同一个外部库调用）\n\n举证不足 → 默认独立 bug，先列为待确认新发现；原 bug Pass 后询问是否写入 backlog，再走下次会话。\n\n新发现 bug 的默认处理：\n\n```\n通过 AskUserQuestion：\n\n🆕 修 {当前 BUG_ID} 时发现新 bug：\n   [新 bug 症状]\n\nAI 同根判定：[独立 / 疑似同根（附证据）]\n我会先把它列为“待确认新发现”，不写入 backlog，也不夹带到本次修复。\n等 {当前 BUG_ID} 通过验收后，我会先告知本次 bug 已完成，再问你是否把这个新问题更新到文档中。\n\nA) 默认：本次修复继续，新 bug 等当前 bug Pass 后再决定是否入档（推荐）\nB) 这是共因（AI 举证已给出）→ 并入当前修复（罕见）\nC) 我现在就想修 → 必须先完成当前 bug 并进入 P7.4；确认入档后开新会话接力\n```\n\n### 5.3 爆炸半径控制\n\n修复涉及 >5 个文件 → AskUserQuestion：\n\n```\n本次修复涉及 N 个文件，超出\"最小修复\"预期。\n\nA) 继续 — 根因确实跨这些文件\nB) 拆分 — 先修关键路径，其余开新会话\nC) 重新思考 — 可能有更精准的方案\n```\n\n### 5.4 原子提交（在 worktree 内）\n\n```bash\n# 仍在 $WT_PATH 内\ngit add <修改的文件>\ngit commit -m \"$(cat <<EOF\nfix(${BUG_ID}): <一句话描述>\n\n根因: <根因>\n修复: <修复方式>\nEOF\n)\"\n```\n\n### 5.5 清理临时代码\n\n删除所有 `[DEBUG H` 标签化日志和断言。\n\n```bash\ngrep -rn \"\\[DEBUG H\" --include=\"*.{js,ts,tsx,py,go,rb}\" .\n# 上述命令应返回空\n```\n\n---\n\n## P5.3 更新 Bug 修复验收报告为待 QA 状态\n\n> 🎯 **关键节点**。代码修完 + 独立 TDD 变绿 + 原子提交之后，AI **必须**更新 `docs/bugfix/reviews/{BUG_ID}.md`。没有完整报告，禁止进入 P6。\n\n### 5.3.1 文档存在性\n\n`$REVIEW_DOC` 应该已经在 P2.5 创建。若不存在，说明流程违规，AI 必须回到 P2.5 补建，并在报告中注明“补建原因”。\n\n```bash\nREVIEW_DOC=\"$DOC_REVIEWS/${BUG_ID}.md\"\ntest -f \"$REVIEW_DOC\" || echo \"❌ Bug 修复验收报告缺失，回 P2.5 补建\"\n```\n\n### 5.3.2 AI 填充的内容\n\nAI 负责更新报告的工程事实和人工验收草案：\n\n| 字段 | 填什么 |\n|------|--------|\n| BUG_ID | `BF-{MMDD}-{N}` |\n| Bug 描述 | 一句话用户视角的现象 |\n| 根因 | P4 5 Whys 追到的根因 |\n| 修复做了什么 | 关键逻辑改动，不超过两句话 |\n| 涉及文件 | 本次 commit 改到的文件列表 |\n| 修复时间 | 当前时间 |\n| 修复 commit | 短 hash + commit message 首行 |\n| TDD / 回归用例 | RED 失败证据 + GREEN 通过证据 |\n| 验收入口 | Frontend/Backend URL 草案；最终由 forge-qa 强校验 |\n| 人工验收指南 | 用户要检查什么 / 怎么操作 / 预期效果 / QA 参考截图占位 |\n| 用户问题闭环断言 | 用户原话 / 最终用户可见结果 / 证明方式 |\n| 配置 / 开关 / 数据就绪 | feature flag、config、后端 enabled 状态、测试数据状态 |\n| 当前状态 | `fixed-awaiting-qa` |\n\n同时把 `$DOC_BACKLOG` 中该 bug 状态更新为 `fixed-awaiting-qa`。\n\n### 5.3.3 人工验收指南最少条件\n\n- **至少 3 条**验证项\n- 其中**至少 1 条边界/异常态**（空数据 / 失败场景 / 错误恢复）\n- 每条验证项必须可以**独立验证**（不依赖其他条）\n- 操作步骤用 `1. ... → 2. ...` 方式写，明确可执行\n\n### 5.3.4 禁止行为\n\n- ❌ AI 不得填\"QA 测试过程与截图证据\"节（留给 forge-qa）\n- ❌ AI 不得填\"你的验收\"列或最终结论（留给用户）\n- ❌ AI 不得自行勾选最终结论\n- ❌ AI 不得省略任何验证项（即使 bug 很小，也要最少 3 条）\n- ❌ AI 不得把多个非同根 bug 写进同一份报告\n\n### 5.3.5 完成后向用户报告\n\n```\n✅ Bug 修复验收报告已更新为待 QA (BF-0419-2)\n\n📄 文档路径：docs/bugfix/reviews/BF-0419-2.md\n\n我已经填好：根因、修复记录、TDD 红绿证据、{N} 条人工验收指南。\n接下来我会调用 forge-qa 跑自动验收（P6），\nQA 会把逐步截图、深度断言、前后端环境身份校验写回报告。\n\n现在开始 P6，请稍候。\n```\n\n---\n\n## P6 调用 forge-qa 自动验收（强规范：必须执行）\n\n> 🎯 **不再由 forge-bugfix 内部做 QA**，明确调用 `/forge-qa`。职责分离 + 双层验收。\n> **本节是 AI 必须执行的硬性流程**，任何 QA 跳过都是违规。\n\n### 6.1 触发前置检查（硬性门禁，不通过不得调用）\n\n调用 forge-qa 之前，AI **必须**逐项核对：\n\n| 检查项 | 命令或方式 | 不通过处理 |\n|---|---|---|\n| Bug 修复验收报告存在 | `test -f \"$REVIEW_DOC\" && echo OK` | 回 P2.5 补建报告 |\n| 人工验收指南 ≥ 3 条 | 读报告，数\"人工验收指南\"表格行数 | 回 P5.3 补齐验证项 |\n| QA 证据区未被 AI 越位填写 | 读\"QA 测试过程与截图证据\"节 | AI 越位填过就清空重来 |\n| 独立 TDD 证据已写入 | 读\"TDD / 回归用例\"节 | 回 P5 补 RED/GREEN 证据 |\n| worktree 代码已提交 | `cd \"$WT_PATH\" && git status --porcelain` 应为空 | 补提交 |\n| 独立 worktree 证据 | 报告 Worktree 字段包含 `.worktrees/bf-...` 或项目约定的独立 worktree 路径 | 回 P3 创建/迁移独立 worktree；已有例外必须写明原因并让用户确认 |\n| 用户问题闭环断言 | 报告有\"用户问题闭环断言\"，且结论不为空 | 回 P5.3 补齐 |\n| 配置/开关/数据检查 | 前端/权限/数据可见性 bug 的报告有\"配置 / 开关 / 数据就绪检查\" | 回 P4 重查根因 |\n| APP_URL 来源（如 bug 类型需要） | `APP_URL` 来自 `npm run dev:status` / `scripts/dev-stack.sh status` 输出 | 回 P3.2 重启并重新读取 |\n| 应用可访问（如 bug 类型需要） | `curl -sf \"$APP_URL\" > /dev/null` | 用统一 dev 入口重启 |\n| 前后端进程身份核对 | `dev:status` 或 `lsof -p $PID \\| grep cwd` 指向当前 worktree | 停当前 worktree 服务后重启；无法确认则 blocked-human |\n\n**任一不通过 → 不启动 forge-qa，先补齐。**\n\n### 6.2 触发 forge-qa（必须用 Skill 工具）\n\nAI **必须**通过 Skill 工具触发 forge-qa，**不得**用自然语言\"暗示\"、不得绕过：\n\n调用格式：\n\n```\nSkill(\n  skill=\"forge-qa\",\n  args=\"mode=B review_doc=<报告路径> bug_id=<BF-XXXX> worktree=<路径> app_url=<URL> commit=<hash>\"\n)\n```\n\n**args 字段强制要求**：\n\n| 参数 | 值 | 必填 |\n|------|-----|------|\n| `mode=B` | 指示 forge-qa 进入 Mode B（单 bug 验收）| ✅ |\n| `review_doc=<路径>` | Bug 修复验收报告的绝对路径 | ✅ |\n| `bug_id=BF-{MMDD}-{N}` | 本次 Bug 编号 | ✅ |\n| `worktree=<路径>` | 当前 worktree 绝对路径 | ✅ |\n| `commit=<hash>` | 修复 commit 短 hash | ✅ |\n| `app_url=<URL>` | 本地应用 URL（若 bug 类型需要；必须来自 dev:status/dev-stack status）| 条件必填 |\n\nAI 在调用前向用户说明：\n\n```\n🧪 调用 forge-qa 做自动验收 (BF-0419-2)\n\nBug 修复验收报告: docs/bugfix/reviews/BF-0419-2.md\n模式: Mode B（单 bug 验收）\n传入参数: review_doc, bug_id, worktree, commit, app_url\n\nforge-qa 会跑完所有验证项，把逐步截图、深度断言、环境身份校验回填到报告里，我等它返回。\n```\n\n然后**立刻**执行 Skill 工具调用，不要做任何其他操作。\n\n### 6.3 等待返回 + 重读报告（不依赖记忆）\n\nforge-qa 执行完成后，AI 必须**重新读取 `$REVIEW_DOC`**，以文件内容为准解析结果：\n\n```bash\ncat \"$REVIEW_DOC\"\n```\n\n**禁止**依赖 Skill 工具返回的文本消息推断 QA 结果，只以报告文件内容为准。\n\n### 6.4 结果解析（三态 + 证据完整性门禁）\n\nforge-qa 返回后，AI **必须先跑 Bug 修复验收报告完整性校验器**，再判断能否进入 P6.5。\n\n校验器路径：本 skill 的 `scripts/validate-bugfix-report.py`。\n\n推荐命令：\n\n```bash\npython3 \"<forge-bugfix skill dir>/scripts/validate-bugfix-report.py\" \\\n  \"$REVIEW_DOC\" \\\n  --ready-for-user \\\n  --expect-app-url \"$APP_URL\" \\\n  --require-browser-evidence \\\n  --require-user-problem-closure \\\n  --require-independent-worktree \\\n  --require-config-readiness\n```\n\n`FRONTEND_OR_INTERACTION_BUG` 的判定：\n\n- bug 涉及页面展示、点击、输入、弹窗、路由、视觉、console/network、移动端适配 → 必须传 `--require-browser-evidence`\n- bug 来自用户反馈 → 必须传 `--require-user-problem-closure`\n- 每个 bug 原则上必须传 `--require-independent-worktree`\n- 前端展示、权限边界、数据可见性、灰度/冷启动开关相关 bug → 必须传 `--require-config-readiness`\n- 纯 API / 纯后端 / 纯脚本 bug → 可去掉 `--require-browser-evidence`；若没有 app_url，也去掉 `--expect-app-url \"$APP_URL\"`。报告仍必须写明浏览器证据来源为 `N/A` 和原因\n\n校验器失败即 `QA_INCOMPLETE`。**不得**因为单元测试、curl smoke 或 forge-qa 文本返回看起来通过，就绕过这个门禁。\n\n| 报告状态 | 信号 | 下一步 |\n|---------|------|--------|\n| QA 证据区所有验证项 = PASS，环境一致性 = PASS，用户问题闭环断言 = PASS，且校验器输出 `QA_EVIDENCE_COMPLETE` | `QA_PASS` | 单 bug 模式进 **P6.5**；批量模式标记 `qa-pass-pending-final-review` |\n| 任一验证项 = FAIL 或环境一致性 = FAIL | `QA_FAIL` | 有界回 **P5** 继续修复 |\n| QA 证据区缺少截图、断言、环境校验、截图文件不存在，或校验器失败 | `QA_INCOMPLETE` | **异常兜底**（见 6.6）|\n| 需求/设计/环境身份无法判断 | `BLOCKED_HUMAN` | 标记 `blocked-human`，整理决策卡问用户 |\n\n### 6.5 QA_FAIL 时的回修纪律\n\n未达到自动闭环上限时，AI 直接：\n\n1. 读报告的\"QA 测试过程与截图证据\"和\"QA 自动闭环记录\"节，看哪条 FAIL + 具体原因 + 证据\n2. 回到 P4.1 重新追根因（**不跳过根因分析**）\n3. 修完 → 重提 commit（新 commit 追加，不 amend）\n4. 更新 `$REVIEW_DOC` 的修复记录、TDD 证据和闭环轮次，**不要改用户验收区**\n5. 回到 P6.1 重新走门禁 → 再次触发 forge-qa\n6. **同一 bug 连续失败 3 次**，或失败原因涉及需求/设计/环境不确定 → 标记 `blocked-human`，给用户决策卡\n\n决策卡必须包含：问题、QA 截图/日志证据、已尝试修复、当前疑问、2-3 个可选决策和 AI 推荐理由。\n\n### 6.6 异常兜底\n\n#### 异常 A：Skill 工具调用失败或不可用\n\n```\n❌ forge-qa 调用失败\n\n错误：<原始错误信息>\n\n处理顺序（AI 必须尝试 A → B → C）：\nA) 重试一次（瞬时失败常见）\nB) AI 手动执行 forge-qa Mode B 的等价流程\n   （按 skills/forge-qa/SKILL.md 的 Mode B 章节逐条跑，亲自回填报告）\nC) 若 B 也不可行 → AskUserQuestion 告知用户 QA 环节无法自动化，\n   请用户决定：C1) 自己先过一遍验证项；C2) 暂停本次修复等环境修好\n```\n\n#### 异常 B：QA_INCOMPLETE（报告缺少证据）\n\nAI 先把报告\"当前状态\"和 `$DOC_BACKLOG` 对应条目更新为 `qa-incomplete`，再处理原因。禁止把 `qa-incomplete` 报告描述成 \"pending user verification\"。\n\n```\n⚠️ forge-qa 未跑完所有验证项\n\n已跑：X / N\n漏掉：<验证项列表>\n原因：<读\"QA 测试过程与截图证据\"节>\n校验器输出：\n<粘贴 validate-bugfix-report.py 的 QA_INCOMPLETE 列表>\n\nAI 必须判断：\n1. 是 blocker 导致（服务挂了/依赖不可用）→ 修 blocker → 回 P6.1 重跑\n2. 是报告里有不可自动验证的项 → 在 QA 证据区标 \"N/A 仅人工验收\"，继续 P6.5 或批次最终验收\n3. 是 forge-qa 内部错误 → 报错给用户，按异常 A 处理\n```\n\n注意：第 2 种只适用于**确实不可自动验证**的非前端项。只要 bug 涉及前端页面或交互，就不能用 \"N/A 仅人工验收\" 代替截图；必须补 browser-use/Playwright 截图，或标记 `blocked-human`。\n\n#### 异常 C：报告被 forge-qa 以外的东西污染\n\n```bash\n# 调用后检查报告是否完整、格式没被破坏\ndiff <(wc -l \"$REVIEW_DOC\") <(预期行数)\n```\n\n若报告结构被破坏 → AskUserQuestion 请用户确认，AI 不自行\"修复\"报告。\n\n### 6.7 铁律（总结）\n\n1. **必须用 Skill 工具调用 forge-qa**，不得用自然语言\"暗示\"\n2. **必须通过门禁检查**（6.1 所有项）才能触发\n3. **必须重读报告文件**解析结果，不依赖记忆或返回消息\n4. **必须通过 `validate-bugfix-report.py --ready-for-user`**，否则就是 `QA_INCOMPLETE`\n5. **前端/交互 bug 没有 Markdown 内嵌截图，禁止进入 P6.5**\n6. **QA_FAIL 未达上限时不打扰用户**，AI 自己回 P5 重来\n7. **连续 3 次 QA 失败必须升级用户**，不能无限循环\n8. **不得越位填\"QA 测试过程与截图证据\"节**，那是 forge-qa 的领地\n\n### 6.8 P3 复现工具复用\n\nforge-bugfix 的 browser-use:browser、gstack/browse、Playwright、截图留证等工具在 **P3 复现**阶段由 forge-bugfix 直接调用。P6 阶段这些工具由 forge-qa 统一编排，结果填到 Bug 修复验收报告，不产出散乱的 QA 报告。\n\nCodex 环境中的优先级：\n\n1. 前端页面/交互/视觉 bug：优先 browser-use:browser\n2. 可重复脚本断言：Playwright / 项目测试框架\n3. 快速探索或已有 gstack 项目：gstack/browse\n4. API / 数据 / 静态逻辑：curl、单元测试、代码检查\n\n---\n\n## P6.5 用户人工验收 / 批次最终验收（硬性关卡）\n\n> 🎯 **关键封闭点**。只有 QA 全过才进这里。单 bug 模式需要用户填写该报告的最终结论；QA 自动闭环/批量模式可以先进入 `qa-pass-pending-final-review`，等待批次最终验收包统一收口。\n> 进入本阶段前必须满足：`forge-qa Mode B` 已回填报告，且 `validate-bugfix-report.py --ready-for-user` 输出 `QA_EVIDENCE_COMPLETE`。否则停在 `QA_INCOMPLETE`，不得请用户验收。\n\n### 6.5.1 AI 通知用户\n\n单 bug 模式下，QA 全过后，AI 向用户发送：\n\n```\n✅ forge-qa 自动验收全过 (BF-0419-2)\n\n📄 请你做人工二次验收：\n   docs/bugfix/reviews/BF-0419-2.md\n\n验收地址（QA 也使用同一组地址）：\nFrontend: http://localhost:xxxx\nBackend: http://localhost:yyyy\n环境一致性：PASS\n\n步骤：\n1. 打开文档\n2. 先看\"验收入口与环境身份校验\"，使用同一组前后端地址\n3. 按\"人工验收指南\"逐条亲自验证\n4. 在\"你的验收\"列填 PASS / FAIL + 原因\n5. 在底部\"最终结论\"区勾一个：PASS / FAIL / PASS + 新发现\n6. 如果勾了\"Pass + 新发现\"，在下面的\"新发现\"区把看到的问题一条一行写出来\n7. 填完告诉我一声\"验收了\"\n\n我会读报告，按你的结论推进下一步。\n```\n\n批量模式下，AI 不打断用户逐个验收，而是：\n\n1. 把本 bug 状态写为 `qa-pass-pending-final-review`\n2. 更新 `$DOC_BACKLOG` 对应行\n3. 把本报告加入批次汇总（如 `docs/bugfix/batches/BATCH-YYYY-MM-DD.md`）\n4. 继续处理批次中下一个 bug\n\n批次结束时，才把最终验收包交给用户。\n\n### 6.5.2 等待用户信号\n\nAI 等待用户说\"验收了\"（或同义表达：\"验收完了\"、\"好了你看\"、\"已经填了\"）。\n\n收到信号前 AI 不得：\n- 主动合并 worktree\n- 进入 P7\n- 反复追问\"验收完没\"\n\n可以：\n- 用户问其他问题时正常回答\n- 用户说\"我还没试\"时回应\"不着急，我等你\"\n\n### 6.5.3 读取报告 + 判定\n\n用户说\"验收了\"后：\n\n```bash\n# AI 读取报告\ncat \"$REVIEW_DOC\"\n```\n\n解析\"最终结论\"区，判定三种情况之一：\n\n| 用户勾的是 | AI 下一步 |\n|-----------|----------|\n| PASS | 进 P7 合并决策 |\n| FAIL | 回 P5 继续修（读\"你的验收\"列的 FAIL 原因定位问题）|\n| PASS + 新发现 | 进 P7 完成当前修复的合并/暂存决策 → 进 P7.4 Pass 边界确认 |\n\n### 6.5.4 边界情况\n\n- **用户未填任何勾**：AI 提示\"最终结论还没勾，请选一个再告诉我验收了\"\n- **用户勾了多个**：AI 提示\"最终结论只能选一个，请确认\"\n- **用户填了 ❌ 但也写了新发现**：按 Fail 处理（原 bug 还没修好优先），新发现暂存（不丢），等 Pass 后再分流\n\n---\n\n## P7 按最终结论分流\n\n> 🎯 **Pass 即合并**（不再问\"是否合并\"）。**没有弃用选项**——Fail 走回 P5 继续修，放弃修复走 P4.4 三振出局。\n\n### 7.1 Pass → worktree 合并决策\n\n用户勾了 ✅ Pass，AI **先做合并预演**（v6.0 新增硬性步骤），再询问合并方式。\n\n#### 7.1.0 合并预演（硬性门禁，v6.0 新增）\n\n并行场景下，另一个会话可能已经合并了东西到 main，或者改到了相同文件。正式合并前必须预演：\n\n```bash\n# 进入主仓库（不是 worktree）\ncd \"$_ROOT\"\ngit fetch origin --quiet 2>/dev/null || true\ngit checkout main 2>/dev/null || git checkout master\ngit pull --ff-only 2>/dev/null || true\n\n# --no-commit --no-ff 做一次预演 merge\nif git merge --no-commit --no-ff \"$WT_BRANCH\" 2>/tmp/merge_preview.log; then\n  # 预演成功，立即回退，让下一步真正执行\n  git merge --abort 2>/dev/null\n  MERGE_OK=1\nelse\n  # 冲突了，回退\n  git merge --abort 2>/dev/null\n  MERGE_OK=0\n  echo \"⚠️ 合并预演失败：\"\n  cat /tmp/merge_preview.log\nfi\n```\n\n- `MERGE_OK=1` → 进 7.1.1 询问合并方式\n- `MERGE_OK=0` → 进 7.1.2 冲突处理\n\n#### 7.1.1 合并询问（预演通过时）\n\n```\n🎯 worktree 合并决策 (BF-0419-2)\n\n验收结论：✅ Pass\n合并预演：✅ 无冲突\nworktree: .worktrees/bf-{MMDD}-N\n分支:     bugfix/bf-{MMDD}-N\n本次:     N commits\n\nA) 合并到主分支（推荐）— 我会执行：\n   git checkout main\n   git pull --ff-only\n   git merge --no-ff bugfix/bf-{MMDD}-N\n   git push\n   git worktree remove .worktrees/bf-{MMDD}-N\n   git branch -d bugfix/bf-{MMDD}-N\n\nB) 暂存不合并 — 保留 worktree 和分支待后续\n   （适用于：想攒几个修复一起 review/ship）\n\nC) 推迟决定 — 先做别的，稍后回来处理\n```\n\n合并细节：如果 `git pull` 拉到新的 commits，先在 worktree 内 `git rebase main` 解决冲突，再回主仓库执行 merge。合并后 `git worktree remove` 清理 worktree 并 `git branch -d` 删除分支。\n\n#### 7.1.2 冲突处理（预演失败时）\n\n预演失败说明并行会话改到了相同文件。不自动解决，交给用户决策：\n\n```\n⚠️ 合并冲突 (BF-0419-2)\n\n本次修复合并到 main 会产生冲突。冲突文件：\n{冲突文件列表，来自 /tmp/merge_preview.log}\n\n可能原因：另一个 worktree（查 .forge/active.md）已经合并了修改，或者主分支有新提交。\n\nA) 让我先 rebase（推荐）\n   cd .worktrees/bf-{MMDD}-N\n   git rebase main\n   # 我会尝试自动解决，解决不了的给你标记冲突点\n   解决后回这里重跑 7.1 预演。\n\nB) 暂存这个修复，先处理别的\n   保留 worktree 和分支不动，以后再回来合并。\n\nC) 让我看冲突文件再决定\n   我读冲突文件的当前状态和你的修改对比给你看。\n```\n\n#### 7.1.3 合并后的 active.md 处理（v6.0）\n\n合并成功后 **不立即清理 active.md**——清理的职责分给 forge-fupan（正常结束）或 /forge-status（兜底）。forge-bugfix 只做两件事：\n- 把 `docs/bugfix/backlog.md` 中对应 bug 的状态改 `resolved`，从\"🐛 待修\"剪切到\"🗄️ 已处理\"\n- 保留 active.md 中的那一行（等复盘或 /forge-status 清）\n\n这样如果会话中还要继续修下一个 bug，active.md 的登记仍有效；如果会话在此结束，用户走 /forge-fupan 会一次性清掉。\n\n### 7.2 Fail → 回 P5\n\n```\n❌ 验收未通过 (BF-0419-2)\n\n你标了 ❌ 的验证项：\n  - 第 1 条：「点击登录头像立刻更新」未通过\n    你的说明：登录后头像还是旧的\n\n读 P4 根因链 + P5 修复内容 + 你的反馈，我会回到 P4.1 重新追根因。\n\n不接受新问题进来（新发现请下次验收时说）。\n```\n\n**不弹出 AskUserQuestion**，AI 直接回到 P5 前的根因分析。修完后：\n- 更新 commit（新 commit 追加，不 amend）\n- 更新 `$REVIEW_DOC` 的\"修复 commit\"字段\n- 重跑 P6 → P6.5\n\n### 7.3 Pass + 新发现 → 处置当前修复 + 进 P7.4\n\n```\n✅ Pass + 新发现 (BF-0419-2)\n\n当前 bug 修复已通过你的验收，我会先完成当前修复的合并/暂存决策（同 7.1）。\n新发现不会夹带到当前修复。当前修复处置完成后，我会停在 Pass 边界，\n先告诉你本次 bug 已完成，再问是否把新问题更新到文档中。\n\n处理中...\n```\n\n当前修复处置完成后，立即进入 P7.4（必须问用户，不得自动写 backlog）。\n\n---\n\n## P7.4 Pass 边界确认 + 文档更新询问\n\n> 🎯 **关键边界**：原 bug 一旦 Pass，就先关闭本次修复。新问题可能很重要，但它们不是“当前 bug 未修好”的证据。AI 必须先让用户感知这个边界，再请求是否把新问题入档。\n\n### 7.4.1 触发条件\n\n满足任一条件即进入 P7.4：\n\n- 用户最终结论是 `PASS + 新发现`\n- 用户在当前 bug 已 Pass 后又反馈了新问题\n- forge-qa / 批次最终验收发现了与原 bug 不同的新问题\n- AI 在修复、验证、合并过程中发现了衍生问题，但原 bug 已经通过闭环断言\n\n### 7.4.2 AI 必须先告知“本次 bug 已完成”\n\n输出必须包含三件事：\n\n1. 原 bug 已收敛的依据（用户结论 / QA 结果 / 闭环断言）\n2. 当前修复状态（已合并 / 暂存 / 推迟合并）\n3. 新问题不会在本会话继续修\n\n示例：\n\n```\n✅ {BUG_ID} 本次 bug 修复已完成\n\n证据：\n- forge-qa：PASS\n- 用户最终结论：PASS / PASS + 新发现\n- 用户问题闭环断言：PASS\n- 当前修复状态：已合并到 main / 已暂存 worktree / 推迟合并\n\n你后面提到的这些问题属于新的待处理事项，不再说明 {BUG_ID} 没修好。\n我不会继续在当前修复里改它们。\n```\n\n### 7.4.3 询问是否写入文档\n\n告知完成后，AI 必须用 AskUserQuestion 询问：\n\n```\n要不要我把这些新问题更新到文档里？\n\n我会做的事：\n- 独立 bug → 写入 docs/bugfix/backlog.md 的 🐛 待修区，并分配 BF 编号\n- 新需求 → 写入 docs/bugfix/backlog.md 的 💡 新需求区\n- 模糊反馈 → 写入 docs/bugfix/backlog.md 的 🌀 待澄清区\n- 然后给你一段简短接力 prompt，建议开另一个会话继续\n\nA) 更新到文档，并给接力 prompt（推荐）\nB) 暂不更新，只结束本次 bugfix\nC) 我想先改写这些问题的描述\n```\n\n### 7.4.4 用户选择后的处理\n\n| 用户选择 | AI 行为 |\n|---|---|\n| A | 进入 P7.5，分流写入 backlog / 报告索引，然后输出简短接力 prompt |\n| B | 不写 backlog，不继续修新问题；只总结本次 bugfix 已完成 |\n| C | 请用户给新描述，更新待分流列表后重新询问 A/B |\n\n**禁止行为**：\n- ❌ 不问用户就把新问题写入 backlog\n- ❌ 把新问题当成原 bug 的 Fail 继续回 P5\n- ❌ 在当前会话继续修新问题，除非用户明确要求且重新走 P2-P4；默认仍建议新会话\n- ❌ 给过长、过度规定下个会话方案的接力 prompt\n\n---\n\n## P7.5 新发现分流\n\n> 🎯 **硬性要求**：P7.5 只能在 P7.4 用户确认“更新到文档”后执行。新发现不得直接修、不得进 TODO、不得停在 AI 脑里；确认后必须逐条分类并写入 `docs/bugfix/backlog.md` 对应区。\n\n### 7.5.1 读取新发现\n\n从以下来源合并读取，解析成一条一条的条目（一行一条）：\n\n- Bug 修复验收报告的\"新发现\"区\n- P5.2 修复过程中列出的“待确认新发现”\n- P6/P6.5 中 forge-qa 或用户补充的新问题\n- P7.4 用户改写后的描述\n\n### 7.5.2 AI 逐条分类\n\n对每条新发现，AI 判断属于哪一类：\n\n| 类别 | 判定标准 | 去哪 | 编号 |\n|-----|---------|------|------|\n| 同根关联 bug（罕见）| 符合 P5.2.1 举证要求（同文件同函数/同数据字段/同上游依赖），但原 bug 已 Pass | `$DOC_BACKLOG` 🐛 待修区，标记“共因 with {BUG_ID}”，建议新会话修 | BF-{MMDD}-{N+1}, +2... |\n| 独立 bug | 是可复现的失效行为，但不符合同根标准 | `$DOC_BACKLOG` 🐛 待修区 | BF-{MMDD}-{N+1}, +2... |\n| 新需求 | 描述的是\"希望能...\"、当前功能不存在的能力 | `$DOC_BACKLOG` 💡 新需求区 | N-{MMDD}-{M+1}... |\n| 模糊反馈 | 现象说不清、未复现、\"感觉有点怪\" | `$DOC_BACKLOG` 🌀 待澄清区 | 无编号，时间戳 |\n\n### 7.5.3 AI 必须举证同根\n\n如果 AI 判定某条是\"同根\"，向用户展示证据：\n\n```\n🔍 新发现 #1：登录页右上角铃铛图标偶尔闪一下\n\nAI 判定：疑似同根\n\n举证：\n- 根因位置：AuthStore.ts:45 `onAuthChange` 回调\n- 当前 bug 引用点：Avatar.tsx:23 订阅该回调\n- 新发现引用点：Bell.tsx:17 同样订阅该回调\n- 结论：两者都受 AuthStore.onAuthChange 回调执行时机影响\n\nA) 确认同根 → 建议新会话一起修（我会写进 backlog 并标记\"共因 with BF-0419-2\"）\nB) 我觉得不是 → 按独立 bug 处理，写 backlog.md 🐛 待修区\n```\n\n举证不足 → AI 直接按独立 bug 处理，不问用户（用户如果不认可可覆盖）。\n\n### 7.5.4 分流报告\n\n完成分流后向用户输出总结：\n\n```\n📋 新发现分流完成 (来自 BF-0419-2 的验收)\n\n写入 $DOC_BACKLOG：\n\n🐛 待修 bug:\n  - BF-0419-3 铃铛图标偶尔闪一下（P2，独立）\n  - BF-0419-4 登出时有一次 404 请求（P1，独立）\n\n💡 新需求:\n  - N-0419-1 希望登录页加\"记住我\"选项（建议后续走 /forge-prd）\n\n🌀 待澄清:\n  - [2026-04-19] 翻页时感觉\"卡了一下\"，未复现\n\n接力 prompt（建议开另一个会话继续）：\n\n我刚完成 {BUG_ID}：{原 bug 一句话标题}，原 bug 已通过 QA/人工验收，当前修复状态：{已合并/已暂存/推迟合并}。修复报告：docs/bugfix/reviews/{BUG_ID}.md。过程中发现的新问题已经写入 docs/bugfix/backlog.md：{列出 BF/N 编号和一句话标题}。请从这些新条目里选一个继续 forge-bugfix，先重新判断范围和根因，不要默认沿用上一个 bug 的结论。\n```\n\n接力 prompt 只需要说清：已完成的原 bug、报告路径、backlog 新编号、建议下个会话重新判断。不要塞入完整根因、完整 diff 或强制方案，给下一个会话保留判断空间。\n\n---\n\n---\n\n## P8 沉淀（Bug 修复验收报告作为主产出 + backlog 归档）\n\n### 8.1 主产出：Bug 修复验收报告已就位\n\n`docs/bugfix/reviews/{BUG_ID}.md` 本身已经是最全的历史记录：\n- 问题发现记录（来源 / 初始证据 / Feature Spec 场景）\n- 复现记录与根因分析\n- 修复记录（worktree / TDD 红绿证据 / 文件 / commit）\n- 验收入口与环境身份校验（Frontend / Backend / PID / cwd / commit）\n- 人工验收指南\n- QA 测试过程与 Markdown 内嵌截图证据\n- 最终结论\n\n**不再重写日级别 bugfix 文档的冗余内容**。如果项目有 `docs/bugfix/{日期}.md` 的日汇总习惯，AI 只追加一行索引：\n\n```markdown\n### {BUG_ID}: {一句话标题}\n\n- **状态**: ✅ 已修复 / ❌ 阻塞\n- **Bug 修复验收报告**: [docs/bugfix/reviews/{BUG_ID}.md](./reviews/{BUG_ID}.md)\n- **worktree**: `.worktrees/bf-{MMDD}-N`（已合并 / 暂存）\n```\n\n### 8.2 Backlog 归档（硬动作）\n\n修复完成的 bug，如果原本登记在 `$DOC_BACKLOG` 🐛 待修区，AI 必须：\n\n1. 从\"🐛 待修\"表格中**剪切**该行\n2. 粘贴到\"🗄️ 已处理\"区的对应月份下，格式：\n   ```\n   - **BF-0419-2** 登录头像不刷新 — resolved 2026-04-19 → 详见 docs/bugfix/reviews/BF-0419-2.md\n   ```\n3. **已处理区永久保留**。不做清理，用于将来定位类似问题时回溯。\n\n如果修复过程中有新发现分流进 backlog（P7.5），那些条目是新登记的，保持在待修区。\n\n### 8.2.1 批量最终验收汇总（可选但推荐）\n\n如果本次是 QA 自动闭环或多会话批量修复，AI 必须维护批次汇总文档：\n\n```text\ndocs/bugfix/batches/BATCH-YYYY-MM-DD.md\n```\n\n批次汇总只做聚合，不替代单 bug 报告：\n\n```markdown\n# BATCH-YYYY-MM-DD BugFix 批量修复汇总\n\n## 验收入口\n- Frontend: ...\n- Backend: ...\n- 环境一致性: PASS\n\n## 本批次 Bug\n| Bug ID | 标题 | 状态 | 会话/Worktree | QA | 人工验收 | 报告 |\n|---|---|---|---|---|---|---|\n| BF-0425-1 | ... | qa-pass-pending-final-review | ... | PASS | 待填 | ../reviews/BF-0425-1.md |\n\n## 最终人工验收指南\n{{把本批次需要用户走的关键用户流程合并成一条或少数几条验收路线}}\n```\n\n批次汇总用于让用户最后只验收一次；每个 bug 的技术证据仍回到各自 `BF-XX.md`。\n\n### 8.3 写入 Memory（仅当真的有跨会话价值）\n\n判断标准（严格）：\n\n| 值得 | 不值得 |\n|---|---|\n| 通用踩坑模式（如\"过滤后计数必须联动\"）| 具体代码改动细节 |\n| 新的调试方法论（如\"先查进程 cwd\"）| 一次性配置修复 |\n| 工具使用技巧 | 特定 bug 的症状描述 |\n\n值得 → 写入 `~/.claude/projects/.../memory/feedback_{name}.md`，并在 MEMORY.md 加索引。\n\n> ⚠️ **不要批量写 memory**。默认**不写**，除非你能说出\"这条 memory 在下次会话会触发什么具体行为\"。\n\n### 8.4 同类模式扫描（挪到 /forge-review）\n\n同类模式扫描（grep 全代码库找同类 bug）不是本次修复的范围，挪到 `/forge-review` 做。\n\n---\n\n## 出口：建议下一步\n\nP8 完成后，AskUserQuestion：\n\n```\n✅ 本次修复完成（{BUG_ID}）\n\n📊 当前会话状态：\n  - 已完成的 bug：N 个（{BUG_ID 列表}）\n  - 暂存的 worktree：M 个（git worktree list）\n  - Backlog 待修：K 个（P0: a / P1: b / P2: c）\n\n下一步建议（按场景推荐）：\n\nA) 结束会话，下一个 bug 开新会话（强烈推荐）\n   原因：上下文已经被本次修复占据，继续会引发 scope 蔓延。\n   backlog 里 K 条待修，打开新会话说\"修 bugfix\"即可，我会从 backlog 推荐下一个。\n\nB) 本会话继续修下一个 bug（不推荐，除非明确共因）\n   等价于：立即用 /clear 清上下文，然后回 P2 启动。\n   /compact 也可以，但 /clear 更干净。\n\nC) 暂停修 bug，审查已合并的代码 → /forge-review\n   检查 SQL 安全/竞态条件/枚举完整性等结构性问题。\n\nD) 已合并的 commits 想发布 → /forge-ship\n   更新 CHANGELOG + push + 创建 PR。\n\nE) 想沉淀本会话经验 → /forge-fupan\n   提取知识、诊断 AI/用户协作模式、写复盘文档。\n   （复盘时会自动清理本会话在 .forge/active.md 的登记）\n\nF) 清点所有并行会话 → /forge-status\n   如果你开了多个窗口在修不同 bug，这个命令扫一遍 .forge/active.md，\n   基于 worktree 存在性 + 分支合并状态报告哪些是活跃、哪些是僵尸可清理。\n\nG) 关闭会话 — 没事了\n   ⚠️ 但 .forge/active.md 里本会话的登记还在，下次建议跑 /forge-status 清理。\n\n⚠️ 如果有暂存的 worktree，建议在 review/ship 前先决定它们的去留。\n```\n\n**默认推荐 A**。用户明确偏好：\"新 bug 默认新会话完成工作，或 /clear /compact 后继续\"。\n**走 A) 之前如果用户开了多个并行会话**，AI 可以主动提一句\"别忘了也可以用 /forge-status 总览一下其他会话\"。\n\n---\n\n## AskUserQuestion 格式规范\n\n每次提问结构：\n1. **重新聚焦**：当前项目、分支、正在调查的 BUG_ID\n2. **通俗解释**：高中生能懂的语言\n3. **给出建议**：推荐选项 + 理由\n4. **列出选项**：`A) B) C)`\n\n---\n\n## 重要规则\n\n### 单次修复纪律\n\n1. **每次只修 1 bug，或 1-2 经 P4.5 确认共因的 bug**。其余进 `docs/bugfix/backlog.md`。\n2. **每次一个 worktree**，命名 `.worktrees/bf-{MMDD}-{N}`。\n3. **修完不自动合并**。必须等用户填完单 bug 或批次最终验收结论，AI 才能按 Pass 走 P7 合并。\n4. **新发现的 bug / 新需求 / 模糊反馈 → 原 bug Pass 后先问用户是否写入 backlog.md**。要修就开新会话（默认）或用户明确授权本会话重新走 P2-P4。\n5. **会话出口必须建议下一步**，默认推荐新会话或 /clear、/compact。\n\n### 调查纪律\n\n6. **铁律：不做根因分析就不写修复代码。**\n7. **强制读 PRD + ENGINEERING.md + Bugfix 历史 + backlog.md**（会话级一次）。\n8. **根因必须用 5 Whys 因果链向用户解释，用户确认方案后才动手。**\n9. **3 次假设失败 → 停下来质疑架构（或弃用本次尝试开新会话）。**\n10. **绝不说\"这应该能修好\"**。验证它，证明它。\n11. **修复涉及 >5 个文件 → 必须确认。**\n12. **无法复现就不要修。**\n\n### Bug 修复验收报告纪律（硬性）\n\n13. **P2.5 必须创建或更新 `docs/bugfix/reviews/{BUG_ID}.md`**。没有报告不创建 worktree、不进 P3。\n14. **P5 修复完成后必须更新报告**。根因、修复记录、TDD 红绿证据、人工验收指南缺一不可。\n15. **人工验收指南至少 3 条**，其中至少 1 条边界/异常态。\n16. **AI 不得自行勾选最终结论**。\n17. **没有用户最终结论或批次最终结论不进 P7**，即使 forge-qa 全过。\n17.1. **状态枚举只能使用**：`pending / in-progress / fixed-awaiting-qa / qa-incomplete / qa-failed / qa-pass-pending-user-verification / qa-pass-pending-final-review / qa-pass-user-accepted / blocked-human / resolved / deferred`。\n17.2. **用户问题闭环断言必须存在**。每份报告都要写清：用户原话、最终用户可见结果、证明方式、结论。\n17.3. **配置/开关/数据就绪必须记录**。涉及前端展示、权限边界或数据可见性的 bug，缺少该检查不得进入 QA。\n\n### 自动 QA + 人工验收纪律\n\n18. **P6 明确调用 forge-qa**。不再在 forge-bugfix 内部做 QA。\n19. **forge-qa 全过才进 P6.5 或批次待最终验收状态**。QA 挂了 AI 有界回 P5 继续修，不打扰用户。\n20. **P6 后必须跑报告完整性校验器**：`validate-bugfix-report.py --ready-for-user` 不通过就是 `QA_INCOMPLETE`。\n21. **前端/交互 bug 必须有 Markdown 内嵌 QA 截图**。没有截图、截图路径不存在、环境一致性不是 PASS，都不能交给用户验收。\n22. **P6.5 等用户\"验收了\"信号**。单 bug 模式收到前不合并、不进 P7、不反复追问；批量模式等待最终验收包。\n23. **用户结论三选一**：Pass / Fail / Pass + 新发现。\n24. **Fail 不接受新问题进来**，只继续修原 bug。\n25. **Pass + 新发现**：先完成当前 bug 的合并/暂存决策，再 P7.4 告知“本次 bug 已完成”，询问是否把新问题更新到文档。\n25.0. **Pass 后的新问题必须走确认门**。无论来自用户反馈、QA 发现，还是 AI 发现的衍生问题，只有用户确认后才能写入 backlog / 报告索引。\n25.0.1. **确认入档后必须给简短接力 prompt**。内容只包括：原 bug 已完成、报告路径、已登记的新编号、建议新会话重新判断范围和根因。\n25.1. **自动闭环最多 3 轮**。第 3 次仍失败，或遇到需求/设计/环境身份疑问，必须 `blocked-human`。\n\n### 同根举证纪律（硬约束）\n\n24. **AI 声称\"同根\"必须举证**：同一文件的同一函数 / 同一数据字段 / 同一上游依赖。\n25. **举证不足 → 默认独立 bug 写进 backlog**，不并入当前修复。\n\n### worktree 纪律\n\n26. **worktree 创建后如需启动应用，必须先执行 P3.2 Dev Server 契约**。\n27. **项目存在统一入口时必须使用它**：`npm run dev:status` / `npm run dev` / `scripts/dev-stack.sh`，不得裸跑 `uvicorn`、`vite`、`next dev`。\n28. **不提供 \"弃用 worktree\" 选项**。Fail 走回 P5 继续修；真的要放弃走 P4.4 三振出局。\n29. **多次修复并发允许，但每次独立 worktree + 独立端口**；端口必须来自项目 dev-stack / `.devserver.json` / 状态输出，不能靠猜常见端口。\n29.0. **APP_URL 必须可追溯**：传给浏览器、curl、forge-qa 的 URL 必须能在 dev:status/dev-stack status 中找到对应 cwd。\n29.0.1. **无独立 worktree 不进入 P5**。如果项目无法创建 worktree（磁盘/权限/仓库状态异常），状态改 `blocked-human`，让用户决定，不在主工作区硬修。\n\n### 并行协调纪律（v6.0 新增）\n\n29.1. **P0 必须读 `.forge/active.md`**，把已占用功能域报告给用户；发现僵尸记录建议用户跑 /forge-status 清理。\n29.2. **P2 必须做功能域判重**。同域冲突时优先建议\"切去那个会话\"，不默认新开窗口。\n29.3. **P3 创建 worktree 成功后立即登记 active.md**，不得拖到修复结束。`$CURRENT_SID` 为空必须停下问用户，不得用占位符登记。\n29.4. **功能域标签必须从 `.forge/active.md` 的\"功能域声明\"区选**，AI 不得自创新标签；首次使用的项目由 AI 初始化模板 + 用户编辑域列表后才继续。\n29.5. **P7.1 合并前必须跑 `git merge --no-commit --no-ff` 预演**，冲突就回退 + 让用户决策 rebase 或暂存。\n29.6. **合并成功后不清 active.md**，交给 forge-fupan 或 /forge-status 清理。backlog.md 的状态同步改 `resolved` 是 forge-bugfix 的职责。\n29.7. **不得基于时间戳判定\"会话已死\"**。只认 worktree 存在性 + 分支 merge 状态这两个硬信号。\n\n### Backlog 纪律\n\n30. **新发现分流在用户确认后必须写进 `docs/bugfix/backlog.md`**。不写 TODO.md，不分散到多个文件；用户未确认前不得默默入档。\n31. **\"已处理\"区永久保留**（用户明确要求，用于以后定位问题时回溯）。\n32. **AI 不得往 backlog 塞\"顺手重构\"想法**。那种东西写代码注释 `// REFACTOR: xxx`。\n33. **P2 范围推荐必须先扫 backlog**，把待修区的条目作为候选之一。\n\n### 沉淀纪律\n\n34. **每个修复原子提交**。一个 BUG_ID，一个 commit（或一个 commit 组）。\n34.1. **每个 bug 独立 TDD**。前端 bug 可用 Playwright 断言作为 RED/GREEN，不能只靠截图。\n35. **Bug 修复验收报告即历史产出**，不再重复写 bugfix/{日期}.md（可留索引）。\n36. **Memory 默认不写**。除非能说出\"这条会触发未来什么具体行为\"。\n\n### 完成状态\n\n- **完成** — 根因找到，修复已应用，QA 通过，worktree 已合并/暂存/弃用\n- **完成但有顾虑** — 已修复但无法完全验证（间歇性 Bug、需要线上确认）\n- **阻塞** — 根因不明确，已升级处理\n\n### 升级机制\n\n可以随时停下来说\"超出能力\"或\"对结果没信心\"。\n\n**糟糕的修复比不修更糟。** 升级不会被惩罚。\n\n升级格式：\n```\n状态：阻塞 | 需要更多信息\n原因：[1-2 句话]\n已尝试：[做了什么]\nworktree：[路径，建议保留以便其他人接手]\n建议：[用户接下来做什么]\n```","tags":["forge","bugfix","skills","yike-gunshi","agent-skills","ai-development","claude-code","skill-md","skillsmp"],"capabilities":["skill","source-yike-gunshi","skill-forge-bugfix","topic-agent-skills","topic-ai-development","topic-claude-code","topic-forge","topic-skill-md","topic-skillsmp"],"categories":["forge-skills"],"synonyms":[],"warnings":[],"endpointUrl":"https://skills.sh/yike-gunshi/forge-skills/forge-bugfix","protocol":"skill","transport":"skills-sh","auth":{"type":"none","details":{"cli":"npx skills add yike-gunshi/forge-skills","source_repo":"https://github.com/yike-gunshi/forge-skills","install_from":"skills.sh"}},"qualityScore":"0.455","qualityRationale":"deterministic score 0.46 from registry signals: · indexed on github topic:agent-skills · 11 github stars · SKILL.md body (43,268 chars)","verified":false,"liveness":"unknown","lastLivenessCheck":null,"agentReviews":{"count":0,"score_avg":null,"cost_usd_avg":null,"success_rate":null,"latency_p50_ms":null,"narrative_summary":null,"summary_updated_at":null},"enrichmentModel":"deterministic:skill-github:v1","enrichmentVersion":1,"enrichedAt":"2026-04-25T19:02:44.190Z","embedding":null,"createdAt":"2026-04-24T07:03:37.862Z","updatedAt":"2026-04-25T19:02:44.190Z","lastSeenAt":"2026-04-25T19:02:44.190Z","tsv":"'+1':1900,5210,5222,5234 '+2':5211,5223 '-04':1737,1849,1867,1871,1878,5340,5497 '-0418':2016,2021,2030 '-0419':1729,1844,1862,3397,3704,4385,4689,4786,4878,4933,5284,5307,5316,5322,5331,5492 '-0425':5549 '-1':924,1863,2323,5332,5550 '-10':712 '-123':1753,1828 '-17':1738 '-19':1850,1868,1872,1879,5341,5498 '-2':229,396,1673,1730,3398,3705,4386,4690,4787,4879,4934,5285,5308,5493,5796,6377 '-20':704,2640 '-3':1845,4024,5317 '-4':26,5323 '-5':1447 '-50':2602 '-9':2017,2022,2031 '/.claude/projects':5590 '/.claude/sessions':1151 '/clear':205,610,5681,5689,5755,5840 '/compact':206,611,5686,5756,5841 '/dev/null':672,684,702,714,726,767,771,788,824,839,868,907,922,930,1067,1092,1110,1183,1445,1454,2241,2321,2333,2590,2600,2606,3577,4604,4610,4620,4651,4662 '/docs/forge-bugfix-changelog.md':217 '/error':2777 '/forge-bugfix':46 '/forge-fupan':619,4870,5713 '/forge-prd':155,593,1796,2989,5337 '/forge-qa':3436 '/forge-review':616,5608,5615,5695 '/forge-ship':617,5705 '/forge-status':331,1326,1332,4842,4862,5724,5741,5764,6207,6262 '/frontend':852,881,2264,2288 '/memory':366 '/memory/feedback_':5591 '/playwright':4173 '/reviews':5458 '/reviews/bf-0425-1.md':5559 '/scripts/validate-bugfix-report.py':3785 '/sw':2668 '/tmp':2569 '/tmp/forge-dev-status.txt':2260,2268,2284,2292 '/tmp/merge_preview.log':4642,4669,4794 '/worktree':5544 '0':1219,4665,4679 '1':219,225,228,392,395,621,729,773,909,1216,1544,1614,1661,1672,2143,2169,2471,2618,2869,3347,3357,3960,4125,4205,4302,4401,4442,4654,4673,4883,5009,5253,5480,5769,5790,5792,5795,5904,6376 '1.1':1345 '1.2':1356 '1.3':1467 '1.4':1490 '10':707,5865 '11':5870 '12':2204,5875 '13':5880 '14':5891 '15':5899 '16':5907 '17':5910 '17.1':5918 '17.2':5956 '17.3':5963 '18':5975 '19':5987 '2':223,630,671,683,701,713,725,756,772,787,823,838,854,867,883,908,921,929,1066,1091,1109,1182,1444,1453,1570,1618,1667,2162,2240,2266,2290,2320,2332,2478,2589,2599,2605,2625,2874,3358,3972,4023,4136,4158,4214,4312,4403,4452,4603,4609,4619,4641,4650,4661,5017,5486,5776,5803 '2.0':1533 '2.1':1540,1610 '2.2':1696 '2.3':1830 '2.4':1891 '2.5':1913 '20':6001 '200':2733 '2026':1736,1848,1866,1870,1877,5339,5496 '21':6012 '22':6026 '23':6038 '24':6044,6101 '25':6049,6109 '25.0':6063 '25.0.1':6075 '25.1':6085 '26':6118 '27':6126 '28':6141 '29':6153 '29.0':6165 '29.0.1':6182 '29.1':6201 '29.2':6209 '29.3':6215 '29.4':6226 '29.5':6238 '29.6':6254 '29.7':6272 '3':25,238,342,641,1421,1588,1629,2494,2629,2823,2879,3342,3385,3472,3977,4006,4146,4219,4252,4316,4407,4457,5022,5501,5779,5810,5861,5901,6087,6090 '3.1':2006 '3.1.5':2058 '3.2':2206 '3.3':2393 '3.4':2408 '30':1308,2218,6283 '3000':895,2308 '31':6290 '32':6295 '33':6305 '34':6311 '34.1':6321 '3456':894,2307 '35':6333 '36':6341 '4':252,648,932,2335,2503,2635,3986,4223,4321,4411,4461,5783,5821 '4.1':2615 '4.2':2641 '4.2.1':2702 '4.2.2':2740 '4.3':2791 '4.4':2821 '4.5':2845 '4000':896,2309 '404':5325 '5':257,426,627,2846,2858,2866,3133,3270,3994,4233,4418,5837,5856,5872 '5.1':2930 '5.2':2942 '5.2.1':3034,3037 '5.3':3130 '5.3.1':3220 '5.3.2':3253 '5.3.3':3339 '5.3.4':3361 '5.3.5':3391 '5.4':3152 '5.5':3179 '5173':897,2310 '6':272,4002,4242,4426,5843 '6.1':3445,4216 '6.2':3605 '6.3':3738 '6.4':3763 '6.5':3953 '6.5.1':4370 '6.5.2':4466 '6.5.3':4491 '6.5.4':4533 '6.6':3942,4028 '6.7':4202 '6.8':4267 '7':283,4250,4433,5846 '7.1':4572,4816,4941 '7.1.0':4583 '7.1.1':4675,4683 '7.1.2':4681,4778 '7.1.3':4828 '7.2':4872 '7.3':4924 '7.4.1':4977 '7.4.2':5002 '7.4.3':5053 '7.4.4':5095 '7.5.1':5155 '7.5.2':5175 '7.5.3':5244 '7.5.4':5301 '8':297,4257,5854 '8.1':5401 '8.2':5468 '8.2.1':5510 '8.3':5567 '8.4':5605 '8000':899,2312 '8080':898,1306,2311 '9':337,935,2338,5860 'a/b':5118 'abc':1752,1827 'abort':4649,4660 'accept':5950 'activ':325,1111,1115,1132,1141,1142,1209,1222,1271,1811,2116 'active.md':1100,1202,2101,4830,4835,4859,4866,6220,6256 'add':2044,3163 'affect':1424 'affected-fil':1423 'ai':163,180,183,195,285,373,379,496,510,546,567,1314,1329,1508,1542,1562,1611,1654,1665,1887,1920,2182,2386,2711,2958,2994,3005,3040,3088,3119,3210,3229,3254,3256,3363,3372,3377,3379,3387,3440,3454,3483,3489,3613,3696,3746,3771,3958,4026,4041,4050,4083,4123,4198,4246,4371,4378,4439,4468,4476,4498,4508,4536,4541,4578,4902,4974,4995,5003,5056,5098,5150,5176,5179,5245,5248,5255,5295,5443,5478,5516,5716,5761,5815,5908,5996,6070,6102,6232,6235,6296 'amend':3985,4913 'api':783,1682,2623,2659,2688,2727,2764,3061,3861,4322 'app':810,812,844,873,911,937,939,950,953,1240,1284,2261,2285,2363,2443,2483,2521,2567,2578,3550,3556,3575,3641,3684,3722,3794,3796,3871,3876,3878,6166 'arg':3631,3644 'askuserquest':1457,1474,1493,1697,2609,2826,2856,3078,3135,4069,4196,4901,5058,5621,5766 'asr':1720,1740,1744,1749 'auth':1779,1854 'authstore.onauthchange':5273 'authstore.ts:45':5260 'avail':759,761,776,791,796,798,1237,2554 'avatar.tsx:23':5266 'await':3327,3337,5926 'awk':851,880,931,1213,2106,2188,2263,2287,2334 'b':1480,1772,1812,2047,2831,2908,3117,3145,3633,3650,3657,3711,4044,4049,4056,4062,4067,4079,4354,4740,4818,5089,5108,5286,5647,5674,5786 'backend':2487,4395,5425,5534 'backlog':399,559,565,602,656,964,1017,1030,1033,1040,1043,1046,1050,1259,1394,1396,1631,1689,1703,1734,1769,1799,1836,1885,1909,1986,2957,2985,3002,3003,3022,3072,3096,3331,4088,4455,4957,5104,5110,5121,5199,5217,5229,5240,5279,5312,5387,5399,5469,5476,5506,5640,5663,5672,6073,6114,6281,6298,6308 'backlog.md':416,581,589,596,1503,1511,1775,1784,1793,1832,2192,5292,5830,5852,6264 'bash':663,864,1179,1433,1469,1930,2009,2068,2231,2273,2277,2280,2381,2397,2518,2556,2575,3157,3185,3235,3752,3783,4186,4497,4593 'batch':5526 'batch-yyyy-mm-dd':5525 'before.png':2529,2572 'bell.tsx:17':5269 'bf':147,262,586,632,1460,1728,1843,1895,2015,2020,2025,2028,2029,3026,3262,3396,3668,3703,4384,4688,4785,4877,4932,5069,5207,5219,5283,5306,5315,5321,5491,5548 'bf-xx':146,585,3025 'bf-xx.md':5566 'bf-xxxx-n':1459 'bf/n':5371 'block':349,491,2788,3597,3946,3950,4013,4177,5952,6097,6194 'blocked-human':348,490,2787,3596,3949,4012,4176,5951,6096,6193 'blocker':4127,4132 'bodi':2141,2145,2150,2155,2158 'body.endswith':2153 'branch':665,667,688,2038,2049,2057,4640,4735,4775 'break':745,945,983,999,1015,1035,1137,1168 'brows':731,732,743,748,750,751,753,1231,2423,2516,2519,2523,2530,2534,2539,2543,2549 'browser':2416,2418,2427,2429,2431,2474,2476,2484,2492,2498,2506,3800,3832,3868,4171,4275,4277,4309,4311 'browser-us':2415,2426,2473,4170,4274,4308 'bug':5,10,20,22,28,48,49,54,60,63,99,105,110,123,131,137,142,169,173,186,203,226,235,240,255,259,274,278,288,296,340,369,378,385,404,437,475,525,539,571,577,580,608,634,651,653,1018,1055,1057,1260,1265,1348,1354,1391,1400,1429,1530,1532,1572,1579,1590,1603,1616,1623,1663,1669,1726,1759,1761,1771,1780,1816,1840,1892,1906,1916,1926,1935,1988,1993,1999,2010,2018,2026,2096,2194,2221,2410,2438,2453,2527,2538,2570,2706,2709,2750,2782,2862,2889,2940,2952,2963,2981,3013,3016,3018,3031,3036,3043,3066,3069,3075,3081,3084,3086,3100,3104,3111,3113,3126,3171,3200,3214,3240,3248,3260,3265,3333,3382,3389,3393,3460,3542,3554,3571,3637,3659,3664,3666,3672,3689,3706,3713,3718,3773,3818,3820,3834,3843,3854,3864,3913,4004,4163,4236,4295,4306,4337,4374,4444,4463,4551,4851,4865,4936,4948,4964,4971,4985,4993,5000,5006,5011,5025,5028,5049,5063,5123,5160,5186,5195,5204,5213,5264,5289,5297,5314,5349,5352,5355,5365,5379,5385,5397,5403,5406,5446,5452,5455,5459,5473,5522,5538,5539,5564,5586,5612,5623,5627,5630,5655,5676,5693,5726,5752,5774,5793,5800,5813,5823,5827,5877,5884,5969,6015,6032,6048,6053,6060,6080,6112,6314,6323,6327,6334,6359 'bugfix':3,335,562,604,966,1076,1079,1082,1256,1366,1385,1388,1431,1437,1442,1452,2039,3432,4272,4286,4846,5092,5113,5376,5436,5530,5669,5850,5984,6270,6337 'bugfix/bf-':4700,4723,4737 'build':2464 'busi':1556,1583,1592,1605 'c':780,1485,1762,1817,2110,2834,3123,3149,4045,4065,4180,4748,4825,5093,5115,5649,5691,5787 'c1':4074 'c2':4076 'cat':3168,3753,4500,4668 'cd':819,832,862,2232,2398,3505,4597,4806 'changelog':5707 'checkout':4607,4612,4711 'claud':1144,1278 'click':2535 'closur':3806,3841 'code':1145,1279 'codex':43,2414,2425,2430,2480,4300 'command':764 'commit':81,246,319,446,469,1477,1904,2404,3166,3278,3283,3286,3643,3679,3681,3721,3980,3982,4624,4635,4705,4757,4908,4910,4919,5422,5428,5703,6245,6317,6319 'complet':3909,4365 'comput':2489,2495 'config':2695,2756,3319,3813,3858 'consol':2460,2544,2736 'console.log':2803 'console/network':1968,3827 'cookbook':216 'count':2168 'cp':1130,1943 'curl':2215,2225,2576,3573,3888,4325,6170 'current':670,1170,1177,1187,1192,1275,2090,2174,2179,6222 'cwd':468,925,933,943,944,1297,2328,2336,2344,2345,2373,2389,2677,3589,5427,5582,6181 'd':1073,1781,1821,2541,2838,4736,4776,5701 'day':1422 'db':2696,2760 'dd':5529 'debug':2798,2804,2811,2818,3182,3188 'def':2138 'defer':5955 'dev':13,37,801,807,814,827,830,836,842,849,860,871,878,1245,1248,1290,2208,2228,2244,2249,2254,2257,2296,2353,2362,2379,3561,3579,3582,3692,6123,6130,6134,6140,6160,6177 'dev-stack':1247,6159 'devserver.json':6162 'diff':4189,5392 'dir':1085,1096,1269 'dir/screenshots':1090,2526 'doc':957,959,961,963,965,967,977,993,1009,1029,1039,1042,1049,1059,1064,1071,1075,1081,1251,1253,1255,1258,1263,1373,1379,1387,1395,1408,1436,1441,1451,1630,1798,1835,1884,1923,1924,1932,1933,1941,1946,1985,2984,3021,3223,3237,3238,3246,3330,3465,3635,3662,3717,3750,3755,3787,3989,4087,4193,4454,4502,4916,5198,5216,5228,5239,5311,5475 'docs/bugfix':5439 'docs/bugfix/backlog.md':143,152,159,192,237,281,375,549,1262,4849,5065,5073,5078,5153,5369,5802,6285 'docs/bugfix/batches/batch-yyyy-mm-dd.md':4460,5519 'docs/bugfix/reviews':1267,1992,3213,5364,5405,5454,5883 'docs/bugfix/reviews/assets':2452 'docs/bugfix/reviews/bf-0419-2.md':3400,3708,4388,5500 'docs/bugfix/reviews/bf-0419-3.md':1857 'docs/bugfix/reviews/bf-xx.md':66,264,406,499 'dom':2448 'dom/screenshot':2469 'domain':1551,1557,1575,1584,1593,1606,2077,2099,2177 'done':746,947,984,1000,1016,1036,1138,1169,2347 'e':5711 'e5':2536 'echo':673,686,689,692,695,705,715,719,727,749,752,794,841,870,936,952,980,996,1012,1032,1045,1068,1078,1093,1133,1140,1184,1189,1194,1211,1225,2050,2170,2294,2302,2339,3247,3466,4666 'elif':778,856,2269 'els':885,2293,4655 'enabl':2699,3321 'enabled/disabled':2766 'eng':960,994,1254,1380 'engin':997 'engineering.md':1363,1378,5849 'entrypoint':38 'eof':3169,3178 'error':2545,2737 'evid':3801,3833,3869,3908,4364 'exit':855,884,2267,2291 'expect':3793,3875 'expect-app-url':3792,3874 'f':817,975,991,1007,1027,1114,1128,1163,1208,1939,2236,2810,3244,3463,5722 'fail':505,521,3924,3926,3928,3955,3969,4244,4416,4423,4514,4521,4548,4565,4873,5125,5933,6041,6045,6146 'fallback':2774,2779 'fals':762 'featur':73,410,1642,1961,2693,2754,3317,5413 'feedback':1415 'feeditem':2806 'fetch':4600 'ff':322,4617,4627,4638,4716,4722,6248 'ff-on':4616,4715 'fi':793,946,948,1051,1139,1185,1227,1455,1947,2346,2348,4670 'file':1425 'final':117,483,3921,4346,4450,5555,5944 'fix':3170,3326,3336,5925 'fixed-awaiting-qa':3325,3335,5924 'flag':1215,1218,1220,2694,2755,3318 'forg':2,86,215,267,328,334,382,452,457,461,1525,1620,1636,1981,2369,2513,3301,3370,3410,3424,3431,3451,3602,3608,3619,3629,3653,3700,3725,3743,3768,3892,4000,4035,4053,4103,4149,4183,4210,4264,4271,4285,4291,4351,4381,4838,4845,4990,5032,5170,5375,5915,5979,5983,5989,6172,6259,6269 'forge-bugfix':1,333,3430,4270,4284,4844,5374,5982,6268 'forge-cookbook':214 'forge-fupan':327,4837,6258 'forge-qa':85,266,381,451,456,460,1524,1619,1635,1980,2368,2512,3300,3369,3409,3423,3450,3601,3607,3618,3628,3652,3699,3724,3742,3767,3891,3999,4034,4052,4102,4148,4182,4209,4263,4290,4350,4380,4989,5031,5169,5914,5978,5988,6171 'forge/active.md':30,307,311,1105,1135,1273,1316,1517,1546,1560,1566,1803,2060,2172,4799,5720,5728,5738,6204,6228 'frontend':3815,4392,5424,5533 'frontend/backend':465,1648,1975,3296 'fupan':329,4839,6260 'g':5734 'git':315,666,676,693,696,698,709,722,1418,1470,2042,2637,2840,3162,3165,3508,4599,4606,4611,4614,4631,4647,4658,4710,4713,4718,4726,4728,4734,4754,4761,4768,4774,4810,5637,6241 'go':3195 'goto':2520 'green':3293 'grep':825,1223,1448,2242,2560,2585,2619,3186,3588,5610 'gstack':2422,4318 'gstack-brows':2421 'gstack/browse':730,1232,2515,4278,4320 'h':2799,3183,3189 'h1':2805 'h2':2812 'hash':3285,3683 'head':703,923,1446,2322 'hn':2819 'home/.claude/skills/forge-bugfix/scripts/get-session-id.sh':1158 'home/.claude/skills/forge-bugfix/templates/active.md':1125 'home/.claude/skills/forge-bugfix/templates/review-checklist.md':1944 'home/.claude/skills/forge/skills/forge-bugfix/scripts/get-session-id.sh':1159 'home/.claude/skills/forge/skills/forge-bugfix/templates/active.md':1126 'home/.codex/skills/browse/dist/browse':739 'home/.codex/skills/gstack/browse/dist/browse':737 'human':350,492,2789,3598,3947,3951,4014,4178,5953,6098,6195 'iab':2486 'id':1147,1191,1196,1281,1355,1927,1936,1994,2019,2027,2071,2075,2097,2202,2454,2528,2571,2863,3082,3101,3172,3215,3241,3261,3638,3667,3719,5026,5050,5205,5350,5366,5407,5447,5456,5460,5540,5624,5631,5775,5885,6315 'import':784,2111 'in-app':2481 'in-progress':1954,2196,5921 'includ':3190 'incomplet':3885,3939,4081,4092,4097,4121,4232,4368,5930,6011 'independ':3809,3847 'interact':3817 'items.length':2808 'js':2547,3191 'json':1152 'json.tool':2582 'k':1717,2594,5642,5665 'l':4191 'length':2807 'line':2088,2136,2137,2159 'lint':2998 'list':724,5639 'listen':906,920,2319 'localhost':913,4393,4396 'log':710,1419,2461,2604,2638 'logger.info':2809 'ls':1439 'lsof':902,916,926,2315,2329,3585 'm':1705,2140,2581,2592,3167,5233,5635 'm.group':2142,2161 'main':1324,4590,4608,4712,4763,4789,4812,5043 'markdown':1842,1860,1876,4238,5432,5445,5524,6017 'master':4613 'md':1443,1928,1937,1995,3216,3242,5367,5408,5441,5457,5461,5593,5886,6339 'memori':1412,5569,5598,5603,6342 'memory.md':1413,5595 'merg':34,316,4629,4632,4648,4652,4659,4663,4671,4677,4719,4766,6242,6279 'messag':1905,3287 'mkdir':1062,1087,1106 'mm':5528 'mmdd':1896,3263,3669,4697,4701,4724,4732,4738,4808,5208,5220,5232,5464,5808 'mode':3632,3649,3656,3710,4055,4061,4353 'n':747,848,877,1173,1186,1435,1462,1701,1861,1897,1898,2131,2134,2148,2154,2156,2160,2325,2800,2801,3137,3264,3406,3670,4108,4698,4702,4704,4725,4733,4739,4809,5209,5221,5231,5330,5465,5628,5809 'n/a':3881,4141,4166 'n1':1790 'name':2024,2036,2041,5592 'network':2550 'next':1217,2361,6139 'no-commit':317,4622,4633,6243 'no-ff':320,4625,4636,4720,6246 'npm':821,834,1288,2238,2247,2252,2255,2351,2377,2583,3559,6128,6132 'npx':766,768,2557,2564 'ok':3467,4653,4664,4672,4678 'onauthchang':5261 'onelin':711,2639 'origin':4601 'p':734,742,744,927,970,976,979,982,986,992,995,998,1002,1008,1011,1014,1022,1028,1031,1034,1063,1088,1107,2114,2330,3586 'p.read':2118 'p.write':2163 'p0':357,658,1312,1692,1707,5644,6202 'p1':361,1334,1342,1693,1710,1777,1855,5327,5646 'p2':300,309,371,624,1499,1514,1694,1713,1786,5131,5319,5648,5684,5835,6210,6306 'p2-p4':623,5130,5834 'p2.0':2078 'p2.4':2012 'p2.5':401,636,3225,3231,3251,3469,5881 'p3':302,418,1199,1801,1807,2002,2504,3524,4268,4281,5890,6216 'p3.2':2441,3567,6122 'p4':423,625,2611,3269,3548,4890,5132,5836 'p4.1':3974,4896 'p4.4':4570,6151 'p4.5':232,5798 'p5':429,488,523,2854,2915,2926,3499,3930,4248,4516,4567,4875,4892,4904,5127,5892,5998,6148,6186 'p5.2':5164 'p5.2.1':5189 'p5.3':435,638,3198,3479,3534 'p5/p6/p6.5':2730 'p6':454,1979,2508,3219,3413,3419,3421,4288,4922,5976,6002 'p6.1':3996,4134 'p6.5':103,477,493,3776,3915,4144,4241,4328,4923,5992,6027 'p6/p6.5':2965,5167 'p7':271,313,513,644,4481,4512,4526,4558,5819,5912,6035 'p7.1':6239 'p7.4':532,533,2967,3128,4530,4929,4954,4958,4980,5142,5173,6057 'p7.5':197,553,563,5102,5137,5140,5507 'p8':599,5395,5619 'package.json':2237 'param':2814,2815 'pars':679 'pass':16,115,125,133,170,175,279,481,504,506,515,527,534,654,2954,2968,2982,3019,3070,3114,3901,3903,3905,3911,3919,4344,4399,4415,4422,4424,4428,4448,4510,4523,4531,4556,4560,4573,4577,4692,4925,4930,4945,4959,4966,4982,4987,5034,5036,5037,5040,5197,5536,5553,5557,5817,5828,5936,5942,5948,6024,6040,6042,6050,6064 'pat':2127 'pat.sub':2165 'path':2033,2046,2054,2084,2234,2400,3160,3507 'pathlib':2112 'pathlib.path':2115 'pend':116,482,1856,1952,3920,4099,4345,4449,5554,5920,5937,5943 'pid':467,915,928,941,942,1149,1296,2314,2326,2331,2342,2343,2388,3587,5426 'pid/cwd/url':2301 'player':1722,1788 'playwright':757,769,786,1238,2420,2552,2558,2565,4279,4314,6329 'playwright.sync':782 'pop':1484 'porcelain':700,1472,3510 'port':892,904,914,918,2305,2317,2341 'pr':5710 'prd':958,978,981,1252,1359,1372,1374,5848 'prd/engineering/bugfix':364 'print':853,882,934,1221,2265,2289,2337 'printf':846,875 'problem':3805,3840 'progress':1956,2198,5923 'prompt':200,556,5082,5087,5107,5136,5346,5382,6077 'pull':4615,4714,4755 'push':4727,5708 'pw':758,760,775,790,795,797,1236,2553 'pwd':685 'py':3194 'pytest':2593 'python3':779,2109,2580,2591,3784 'q':826,2243 'qa':83,87,101,106,111,114,177,248,268,383,387,439,449,453,458,462,472,480,485,544,640,646,962,1010,1013,1409,1526,1528,1621,1625,1627,1637,1966,1982,2370,2510,2514,3202,3302,3308,3328,3338,3365,3371,3395,3411,3414,3425,3434,3443,3452,3481,3486,3603,3609,3620,3630,3654,3701,3726,3744,3760,3769,3884,3893,3899,3907,3910,3918,3927,3932,3938,3954,3962,3965,4001,4018,4036,4054,4071,4080,4091,4096,4104,4113,4120,4139,4150,4184,4211,4231,4243,4254,4259,4265,4292,4298,4334,4339,4343,4352,4363,4367,4376,4382,4390,4447,4991,5014,5033,5171,5357,5430,5514,5545,5552,5916,5927,5929,5932,5935,5941,5947,5971,5973,5980,5986,5990,5994,6010,6019,6067,6173,6350 'qa-fail':5931 'qa-incomplet':4090,4095,5928 'qa-pass-pending-final-review':113,479,3917,4342,4446,5551,5940 'qa-pass-pending-user-verif':5934 'qa-pass-user-accept':5946 'qa.md':1407 'queri':2813 'quiet':4602 'r':2129,2147 'rb':3196 're':2113 're.compile':2128 're.m':2135 're.sub':2146 'read':2626 'readi':3789,3814,3859,4227,4359,6006 'ready-for-us':3788,4226,4358,6005 'rebas':4762,4804,4811,6252 'red':3291 'red/green':3501,6331 'redis/cdn':2666 'refactor':3008,6303 'rel':2081,2093 'relat':2562,2587,2596 'related-test':2561,2586,2595 'reload':2467 'remov':2842,4730,4770 'repl':2139,2166 'report':1084,1089,1095,1268,2525 'requir':3799,3803,3808,3812,3831,3838,3846,3857,3867 'require-browser-evid':3798,3830,3866 'require-config-readi':3811,3856 'require-independent-worktre':3807,3845 'require-user-problem-closur':3802,3837 'resolv':4853,5495,5954,6266 'return':2157 'rev':678 'rev-pars':677 'review':118,484,968,1052,1060,1065,1069,1072,1264,1922,1925,1931,1934,1940,1945,3222,3236,3239,3245,3464,3634,3661,3716,3749,3754,3786,3922,3988,4192,4347,4451,4501,4915,5556,5945 'review/ship':4747,5746 'rl':1449 'rn':3187 'root':675,691,820,833,863,2085,4598 'root/.codex/skills/browse/dist/browse':738 'root/.codex/skills/gstack/browse/dist/browse':736 'root/.forge':1108 'root/.forge/active.md':1112 'root/.gstack/bugfix-reports':1086 'root/.worktrees':2034 'root/backlog.md':1025 'root/docs/bugfix':1074,1077 'root/docs/bugfix/backlog.md':1024,1044 'root/docs/bugfix/reviews':1061 'root/docs/engineering.md':988 'root/docs/prd.md':972 'root/docs/qa.md':1004 'root/engineering.md':989 'root/logs':2603 'root/package.json':818 'root/prd.md':973 'root/qa.md':1005 'root/scripts/dev-stack.sh':858 'run':822,835,1289,2239,2248,2253,2256,2352,2378,3560,6129,6133 'scope':210,5661 'screenshot':2524,2566 'script':1154,1166,1175,1181 'scripts/dev-stack.sh':865,1293,2271,2274,2278,2281,2356,2382,3563,6135 'scripts/validate-bugfix-report.py':3781 'server':14,802,808,2209,2229,2297,6124 'session':1146,1190,1195,1280,1600,1751,1826,2070,2089,2173,2201 'set':2697,2761 'sf':3574 'show':669,681 'show-curr':668 'show-toplevel':680 'sid':1153,1165,1171,1174,1178,1180,1188,1193,1276,2091,2175,2180,6223 'sinc':1420 'skill':1120,2477,3611,3616,3626,3627,3735,3758,3779,4032,4207 'skill-forge-bugfix' 'skills/forge-bugfix/templates/backlog.md':1889 'skills/forge-qa/skill.md':4059 'smoke':3889 'snapshot':2449,2531,2540 'sourc':1766 'source-yike-gunshi' 'spec':74,411,1643,1962,5414 'sql':2680,5697 'stack':1249,6161 'start':2279 'stash':1482 'status':699,815,828,831,837,843,850,861,866,872,879,1246,1250,1291,1471,2245,2250,2258,2275,2282,2354,3509,3562,3564,3583,3694,6131,6179 'status/dev-stack':3693,6178 'stcp':905,919,2318 'stop':2380,2383 'sync':785 'tail':2601 'tdd':9,78,244,432,442,3207,3289,3404,3492,3495,3991,5419,5896,6325 'tee':2259,2283 'test':2559,2563,2584,2588,2597,3243,3462 'text':2119,2164,5518 'ti':917,2316 'todo':5148 'todo.md':6287 'topic-agent-skills' 'topic-ai-development' 'topic-claude-code' 'topic-forge' 'topic-skill-md' 'topic-skillsmp' 'toplevel':682 'tpl':1123,1129,1131 'true':777,792,840,869,2251,2276,2555,4605,4621 'ts':3192 'tsx':3193 'txt':2117,2167 'typeerror':2649 'ui':2690,2773,2897 'unknown':674,2185 'url':811,813,845,874,912,938,940,951,954,1241,1243,1285,1295,2262,2286,2364,2390,2444,3297,3551,3557,3576,3642,3685,3687,3723,3795,3797,3872,3877,3879,6167,6175 'url/api/endpoint':2579 'url/path':2568 'url/path/to/page':2522 'use':2417,2428,2432,2475,2490,2493,2496,2499,2507,4172,4276,4310 'user':3791,3804,3839,4100,4229,4361,5938,5949,6008 'uvicorn':1304,2359,6137 'v':765,1224,2598 'v6.0':299,1098,1274,1282,1310,1512,1536,2061,4580,4586,4832,6199 'v7.0':1522 'v7.2':18 'validate-bugfix-report.py':4118,4225,4357,6004 'verif':4101,5939 'version':770 'vite':2360,6138 'vs':1520 'wc':4190 'where/join':2684 'whys':427,628,2847,2859,2867,3271,5857 'worktre':7,40,77,242,304,420,430,516,717,721,723,889,1102,1299,1302,1321,1487,1809,1902,2004,2008,2043,2051,2063,2072,2092,2207,2213,2375,2395,2406,2678,2841,2927,3155,3503,3514,3517,3521,3527,3591,3593,3639,3674,3677,3720,3810,3848,4479,4574,4596,4686,4695,4729,4743,4759,4769,4772,4797,4822,5045,5418,5462,5634,5638,5730,5744,5805,5888,6116,6119,6144,6156,6184,6188,6218,6276,6352,6381 'worktrees/bf-':3519,4696,4731,4807,5463,5807 'wt':2023,2032,2035,2037,2040,2045,2048,2053,2056,2082,2083,2094,2233,2399,3159,3506,4639 'x':391,741,857,1161,1598,1708,2270,4107 'xx':148,587,3027 'xx.tsx':1764 'xxx':1465,6304 'xxxx':1461,4394 'y':1601,1711 'yyyi':4397,5527 'z':949,1038,1714 '一个':1056,6313,6316 '一句话':2885,2913 '一句话描述':3173 '一句话标题':5353,5448 '一句话用户视角的现象':3267 '一旦':4965 '一旦需要浏览器':2224 '一次一':47,368 '一次修一个':4 '一次性配置修复':5583 '一次执行':1338 '一次问一个':1494 '一直存在还是最近出现':1498 '一致性':470 '一行一条':5159 '三态':3765 '三振出局':2822,4571,6152 '上下文已经被本次修复占据':5659 '上下文干净':207 '上下文采集':1336 '上次根因是':1464 '上述命令应返回空':3197 '下一个':202,5654 '下一步':3898,4509 '下一步建议':5650 '下文':3033 '下次修复或下次会话再说':1770 '下次动到这个文件时再看':3011 '下次建议跑':5740 '下次触发时捕获':2837 '不':3984,4912 '不一致就先':2376 '不丢':4554 '不产出散乱的':4297 '不依赖其他条':3355 '不依赖记忆':3741 '不依赖记忆或返回消息':4222 '不值得':5574 '不做':1505 '不做根因分析':220 '不做根因分析就不写修复代码':5845 '不做清理':5503 '不共因的':1684 '不再优先扫描常见端口':1286 '不再在':5981 '不再由':3429 '不再说明':5048 '不再重写日级别':5435 '不再重复写':6336 '不再问':4562 '不写':558,5109,5600,6286 '不写代码':2906 '不写入':3001,3095 '不分散到多个文件':6288 '不加功能':2941 '不反复追问':6036 '不可用':754,1235,2500 '不合并工程单元':251 '不同的新问题':4994 '不启动':3600 '不在':332 '不在主工作区硬修':6197 '不在本次修复中处理':2950 '不存在':1561,1886 '不并入当前修复':6115 '不弹出':4900 '不影响主仓库':1489 '不得':3621,3886,4477 '不得停在':5149 '不得凭常见端口猜':2371 '不得基于时间戳判定':6273 '不得填':3364,3373 '不得声称':2781 '不得往':6297 '不得把多个非同根':3388 '不得拖到修复结束':6221 '不得拖到修复结束再补':2067 '不得猜端口':2445 '不得用':2184 '不得用占位符登记':6225 '不得用自然语言':4212 '不得省略任何验证项':3380 '不得绕过':3624 '不得自创':1577 '不得自创新标签':6233 '不得自动写':4956 '不得自行勾选最终结论':3378,5909 '不得裸跑':2358,6136 '不得请用户验收':4369 '不得越位填':4258 '不得轻易声称':3041 '不得进':5147 '不得静默跳过':2191 '不打扰用户':6000 '不打断用户逐个验收':4440 '不把探测结果当作':888 '不把这些新问题正式写入':2956 '不接受新问题进来':4898,6046 '不接新问题':526 '不推荐':5677 '不提供':6142 '不是':3004,4595 '不是最后的附录':2001 '不是本次修复的范围':5613 '不替代单':5521 '不猜测':1587 '不理解数据流':1364 '不直接修':1653 '不着急':4489 '不知道':1360 '不立即清理':4834 '不等于用户问题闭环':2739 '不继续修新问题':560,5111 '不能只靠截图':6332 '不能无限循环':4256 '不能靠猜常见端口':6164 '不自动解决':4782 '不自己清':1330 '不自行':4199 '不要做任何其他操作':3737 '不要因为':2488 '不要塞入完整根因':5390 '不要批量写':5597 '不要改用户验收区':3993 '不要默认沿用上一个':5378 '不论新问题来自用户验收':176 '不读':1358,1362,1365 '不超过两句话':3275 '不跳过根因分析':3976 '不进':643,5889,6034 '不进入':6185 '不进入当前修复':129 '不通过不得调用':3448 '不通过处理':3459 '不通过就是':6009 '不重新分配':1912 '不重读':1343 '不问用户':5299 '不问用户就把新问题写入':5120 '不默认新开窗口':6214 '且':4356 '且不得占用主分支固定端口':2392 '且校验器输出':3906 '且结论不为空':3532 '两种验收节奏':97 '两者都受':5272 '严格':5572 '严重度':1640 '个':230,393,1662,1668,1674,1709,1712,1715,1718,5629,5636,5643 '个假设都失败':2824 '个可选决策和':4025 '个文件':3134,3138,5873 '个条目':1706 '个窗口同时修不同功能域的':27 '个问题':1702 '中':5168 '中对应':2193,4850 '中应该能':2721 '中找到对应':6180 '中的那一行':4860 '中该':1987,3332 '临时':2919 '为什么':2870,2875,2880 '为空必须停下问用户':6224 '为空时':2181 '主产出':5402 '主仓库有未提交变更':1473 '主动合并':4478 '主项目改动不生效':1307 '举证':5258 '举证不足':3064,5294,6110 '举证不通过默认独立':168 '举证已给出':3120 '举证要求':5190 '之前':2108,3453 '之前如果用户开了多个并行会话':5760 '之前插入':2126 '之后':305 '也不可行':4068 '也不夹带到本次修复':3097 '也使用同一组地址':4391 '也去掉':3873 '也可以':5687 '也要最少':3384 '了解已登记待修':1399 '交互':2435,2705,2726,4235,4304,6014 '交给':6257 '交给用户决策':4783 '亲自回填报告':4064 '人工验收':5358,5546 '人工验收指南':94,3304,3471,3476,4409,5429 '人工验收指南最少条件':3340 '人工验收指南缺一不可':5898 '人工验收指南至少':5900 '人工验收时':92 '人工验收纪律':5974 '什么操作触发':1495 '仅人工验收':4142,4167 '仅当真的有跨会话价值':5570 '仍不对':2691 '仍在':3158 '仍必须交给':2511 '从':374,1688,1908,4854,5481 '从以下来源合并读取':5157 '从入口点沿调用链追踪':2628 '从模板':1888 '从模板初始化':1118 '从症状回溯到根因':2617 '从登记':64 '从登记开始就创建结构化':21 '仓库状态异常':6191 '代替截图':4168 '代码修完':3205 '代码已提交':3504 '代码检查':4327 '以后再回来合并':4824 '以后遇到类似问题时搜这里':1406 '以外的东西污染':4185 '以文件内容为准解析结果':3751 '任一不通过':3599 '任一域与':1582 '任一验证项':3923 '任何':3442 '任务':2074,2095 '任务池':1019,1261,1398 '优先':4307 '优先来自项目':1244 '优先级':1691 '优化下':2999 '会一次性清掉':4871 '会产生冲突':4790 '会把逐步截图':3415 '会提示':1200 '会话':1847,1865,5543 '会话出口必须建议下一步':5838 '会话已死':6274 '会话级':354,660,1337 '会话级一次':5853 '会话级声明':1339 '会跑完所有验证项':3727 '传入参数':3715 '传入的问题必须包含':1638 '传给复现':2366 '传给浏览器':6169 '但':5688,5737 '但不符合同根标准':5215 '但也写了新发现':4546 '但修复执行仍然一次一个':1531 '但原':4999,5194 '但它们不是':4969 '但每次独立':6155 '位即可':2205 '你后面提到的这些问题属于新的待处理事项':5047 '你标了':4880 '你的反馈':4894 '你的说明':4887 '你的验收':501,3374,4413,4519 '使用':2479 '使用同一组前后端地址':4406 '例如':2014 '依赖':3757 '依赖不可用':4130 '便于跨机器':2087 '保持在待修区':5509 '保留':4742,4821,4858 '信号':2971,3897,6030 '信息不足时':1491 '修':3079,4131,5668 '修同一组文件':1677 '修复':3176,3282,3680,4200,4918 '修复中发现新':3012 '修复中怀疑发现':3028 '修复中的范围控制':2943 '修复做了什么':3273 '修复内容':4893 '修复原则':2931 '修复后':2717 '修复后必须更新报告':637 '修复完':1483 '修复完成后必须更新报告':5893 '修复完成的':5472 '修复已完成':138,5029 '修复已应用':6349 '修复已通过你的验收':4937 '修复报告':5363 '修复摘要':445 '修复方式':3177 '修复方案':2901 '修复方案确认':428 '修复时':75 '修复时间':3280 '修复涉及':3132,5871 '修复记录':3403,5417,5895 '修复过程中列出的':5165 '修复过程中识别到以下信号':2946 '修复验收报告':11,23,50,61,405,635,1058,1917,3707,4296,5453 '修复验收报告不算完':260 '修复验收报告为待':438,3201 '修复验收报告作为主产出':5398 '修复验收报告即历史产出':6335 '修复验收报告存在':3461 '修复验收报告完整性校验器':3774 '修复验收报告已就位':5404 '修复验收报告已更新为待':3394 '修复验收报告文件名':1907 '修复验收报告的':5161 '修复验收报告的绝对路径':3665 '修复验收报告目录':1266 '修复验收报告纪律':5878 '修复验收报告缺失':3249 '修完':3978 '修完不自动合并':253,5811 '修完后':4906 '修改':2403 '修改的文件':3164 '修根因不修症状':2932 '候选来源有三个':1613 '值':3647 '值得':5573,5588 '假设验证':425,2613,2792 '假设验证通过后不直接动手':2850 '做':5616 '做一次预演':4628 '做了什么':6380 '做什么':2904 '做分类判断':568 '做功能域判重':312 '做自动验收':3702 '停下来质疑架构':5863 '停当前':3592 '停止':2608 '允许多域':1580 '兄弟路径遗漏':2899 '先临时修一下':2917 '先修关键路径':3147 '先做别的':4750 '先做合并预演':4579 '先写入':1977 '先列为待确认新发现':3067 '先向用户解释根因':2851 '先告诉你本次':4947 '先在':4758 '先处理别的':4820 '先完成当前':6052 '先完成当前修复的合并':529 '先把报告':4084 '先提交':1476 '先明确告知用户':135 '先暂存':1481 '先查进程':5581 '先看':4404 '先补齐':3604 '先重新判断范围和根因':5377 '兜底':4843 '兜底原因必须写入报告':2502 '入口':809,2230,2298 '入口重启':3580 '全代码库找同类':5611 '全过':473,647,5917 '全过后':4377 '全过后立即进入':102 '全过才进':5991 '全过才进这里':4335 '全部完成':614 '全量分诊排序后逐个修':1506 '共享同一根因时':1670 '共因':397,1763,5202,5281 '共因判断标准':1676 '关联':72,1641,1960 '关键变量':1228 '关键封闭点':4332 '关键节点':3204 '关键边界':4962 '关键逻辑改动':3274 '关闭会话':5735 '其中':3345 '其中至少':5903 '其他':1815 '其余':398 '其余开新会话':3148 '其余进':236,1510,5801 '具体代码改动细节':5578 '具体原因':3970 '兼容旧项目':886 '内':3156,3161,4760 '内启动的服务和主仓库抢同一端口':2214 '内容只包括':6078 '内嵌':6018 '内嵌截图':4239 '内嵌截图证据':5433 '内最小修复':2928 '内独立':431 '内进行':2407 '内部做':3433,5985 '内部错误':4151 '再':6056 '再判断能否进入':3775 '再回主仓库执行':4765 '再处理原因':4093 '再次触发':3998 '再继续':1328 '再询问合并方式':4582 '再询问是否写入文档':139 '再请求是否把新问题入档':4976 '再走下次会话':3073 '再走新会话':657 '再问你是否把这个新问题更新到文档中':3106 '再问是否把新问题更新到文档中':4950 '再问用户':190 '写':5291 '写任何修复代码前必须完成':622 '写入':441,1502,1774,1783,1792,1831,5064,5072,5077,5310,5568,5589 '写入人工验收指南草案':448 '写入来源':407 '写复盘文档':5718 '写进':6113 '写进同一份报告':3390 '写进报告':2391 '冲突了':4656 '冲突处理':4682,4779 '冲突就回退':6250 '冲突文件':4791 '冲突文件列表':4792 '决定':1518 '决策卡必须包含':4016 '冷启动':2748 '冷启动开关相关':3853 '出口':606,5617 '函数名':2622 '分支':687,2055,4699,5772,6278 '分支合并状态报告哪些是活跃':5732 '分支已合并到':1323 '分流':198,554 '分流写入':5103 '分流报告':5302 '分配':145,584 '分钟':2219 '分钟才定位':1309 '切去那个会话':6213 '切换到':2394 '列':502 '列为':2948 '列为待确认新需求':2979 '列为待确认独立':3015 '列出':5370 '列出新问题来源':542 '列出本会话新报告的':377 '列出选项':5784 '列填':4414 '列或最终结论':3375 '列指向':1991 '列的':4520 '列表':4122,5632 '刚变更':2465 '创建':303,402,419,1808,1914,2003,2007,2052,3226,3525,5709,6217 '创建后如需启动应用':6120 '创建成功之后':2064 '初始化':1134,1890 '初始化模板':6236 '初始影响范围':1963 '初始截图':70 '初始证据':409,1964,2456,5412 '删除分支':4777 '删除所有':3181 '判定':512,4493,5256 '判定三种情况之一':4506 '判定某条是':5249 '判定标准':5182 '判断':1666 '判断属于哪一类':5180 '判断标准':5571 '别忘了也可以用':5763 '前':126,2203 '前先决定它们的去留':5747 '前后端不一致':2657,2893 '前后端环境身份校验写回报告':3417 '前后端进程身份核对':3581 '前的根因分析':4905 '前端':2704,3539,4234,6013,6326 '前端复现和修复后自验':45 '前端展示':3849 '前端异常但':2658 '前端打到旧代码上':2216 '前端是否因开关':2775 '前端页面':4303 '前置脚本':359,661 '剪切':5484 '剪切到':4856 '功能域':413,1591,1604,1739,2076 '功能域准备':1535 '功能域判重':32 '功能域声明':1548,6230 '功能域标签必须从':6227 '功能预期行为':1376 '加':2997 '加日志':2836 '加索引':5596 '匹配到历史记录':1456 '区':1549,4505,5163 '区内嵌':2458 '区勾一个':4421 '区域':1949 '区域留给':450 '区把看到的问题一条一行写出来':4432 '区永久保留':6292 '区的对应月份下':5489 '区选':6231 '升级不会被惩罚':6370 '升级处理':2832 '升级或收集更多证据':2610 '升级机制':6364 '升级格式':6371 '单':53,98,109,474,3658,3712,3912,4336,4373,6031 '单一入口':1020 '单元测试':4326 '单域或逗号分隔多域':2080 '单次修复纪律':5789 '单测通过':2734 '单独会话':1687 '占用':1602,1754 '卡了一下':5343 '即使':645,3381,5913 '即可':5670 '即合并':4561 '历史':365,1080,1386,5851 '历史会重复排查':1367 '历史修复回溯':1405 '历史检索':1432 '历史踩坑':1301,1417,2212 '原':122,130,185,277,652,2951,2980,3017,3068,4550,4963,5010,5351,5354,5826,6079 '原则上必须传':3844 '原因':4111,4417,5658,6375 '原因定位问题':4522 '原始描述':1959 '原始错误信息':4039 '原子提交':434,2929,3153 '原子提交之后':3209 '去':1825 '去哪':5183 '去掉占位行':2144 '去重':2685 '参数':3646 '参考截图占位':3309 '双层验收':3438 '反复追问':4482 '发现':178,545,6068 '发现僵尸记录建议用户跑':6206 '发现时':67 '发现的结构化':384,1622 '发现的衍生问题':547,6071 '发现的问题也是正式入口':1527 '变绿':3208 '变量':1229 '句话':6378 '另一个':4796 '另一个会话可能已经合并了东西到':4589 '另外':2975 '只以报告文件内容为准':3762 '只修原':524 '只修本次范围内的':2939 '只做两件事':4847 '只在':2497 '只在当前报告或会话回复里保留':2959 '只总结本次':5112 '只有':4333 '只有用户确认后才能写入':6072 '只结束本次':5091 '只继续修原':6047 '只能在':5141 '只要':4162 '只要原':172 '只认':6275 '只记录为':127 '只读探测':887 '只追加一行索引':5444 '只需要说清':5383 '只需读代码和单元测试即可复现':2222 '可丢弃':58 '可以':4484 '可以不启动应用':2223 '可以主动提一句':5762 '可以随时停下来说':6365 '可去掉':3865 '可并行':1609,1742 '可循环':370 '可推荐':1671 '可用':6328 '可用时':2419 '可留索引':6340 '可能原因':4795 '可能有更精准的方案':3151 '可追溯':57 '可选但推荐':5512 '可重复脚本断言':4313 '合并':518,5820 '合并三个来源':1655 '合并冲突':4784 '合并决策':517,4513,4575,4687 '合并到主分支':4707 '合并前':33 '合并前必须跑':314,6240 '合并后':4767 '合并后的':4829 '合并成功后':4833 '合并成功后不清':6255 '合并细节':4752 '合并询问':4684 '合并过程中发现了衍生问题':4998 '合并预演':4584,4693 '合并预演失败':4667 '同':4940 '同一':339,4003 '同一上游依赖':6108 '同一个':3060 '同一个上游依赖':1680 '同一个上游依赖失效':3059 '同一个外部库调用':3063 '同一个数据结构':3054 '同一会话做多次修复时':1341 '同一数据字段':6107 '同一文件的同一函数':3049,6106 '同上':2992 '同上游依赖':5193 '同函数':166,293 '同域冲突时优先建议':6212 '同域合并到已有会话':1519 '同意推荐':1805 '同数据字段':5192 '同数据流':294 '同数据流的具体证据':167 '同文件':165,292 '同文件同函数':5191 '同时把':1984,3329 '同样订阅该回调':5270 '同根':161,289,569,574,3029,3044,5250,6104 '同根举证纪律':6099 '同根关联':5185 '同根判定':3089 '同根判定声称必须举证':649 '同根判定必须举证':284 '同根判定的举证要求':3038 '同根必须举证':2945 '同步':415 '同类模式扫描':5606,5609 '后':134,4496 '后先问用户是否写入':5829 '后再决定是否入档':3115 '后再分流':4557 '后再开始':1478 '后又反馈了新问题':4988 '后必须跑报告完整性校验器':6003 '后执行':5145 '后的新问题必须走确认门':6065 '后端':2698,3320 '后端返回状态':2763 '后继续':5757 '后续':1198,2729 '后续所有操作':2401 '后询问是否写入':280,2983,3020,3071 '后进入':2966 '后重启':2384 '后问用户是否写入':655 '向用户发送':4379 '向用户展示证据':5251 '否则停在':4366 '否则就是':4230 '否则默认独立':3035 '含义':1230 '含范围确认和':626 '启动':5685 '启动应用时优先使用项目统一':36 '启动许可':890 '告知':6058 '告知完成后':5055 '告知用户':537,4070 '命令或方式':3458 '命名':1903,5806 '命名规则':2797 '和':3964,4086 '和关键状态截图':2450 '和分支不动':4823 '和分支待后续':4744 '和原因':3882 '和同一组验收地址':95 '和用户':269 '哪一步断裂':2634 '哪些':1658 '哪些是僵尸可清理':5733 '回':522,3250,3468,3478,3498,3523,3533,3547,3566,4133,4515,4874 '回到':3973,3995 '回填前后端地址':88 '回归':249,1428 '回归用例':3290,3496 '回溯':1150 '回调':2655,5262 '回调执行时机影响':5274 '回退':4657 '因为':2872,2877,2882 '因为单元测试':3887 '因果链':2860,2868 '因果链向用户解释':5858 '在':42,1539,3154,4138,4412 '在下次会话会触发什么具体行为':5604 '在下面的':4430 '在修复':4996 '在修复中发现的衍生问题':181 '在它后面的':2123 '在底部':4419 '在当前会话继续修新问题':5128 '在猜':2923 '在疑似根因处加':2794 '在相关代码加':3007 '在调用前向用户说明':3697 '地址':466,1649,1976 '场景':412,1644,5415 '埋点等待':2835 '域':1597,1719,1721,1743,1748,1778,1787,2098,2176 '域冲突':1596,1747,1822 '基于':5729 '基础信息':664 '塞':6299 '填什么':1950,3259 '填充的内容':3255 '填完告诉我一声':4434 '填最终结论':96 '声称':286,6103 '声称同根必须满足以下':3046 '声称时必须举证':575 '处理':2632,2972,4155,4549,4831,5290,5298 '处理中':4951 '处理顺序':4040 '处置当前修复':4927 '备选':2909 '复现':422,2005,2402,2409,4282 '复现可以用':2505 '复现后查日志':2816 '复现工具复用':4269 '复现引擎':728,755 '复现截图':2457 '复现截图写入':2451 '复现步骤':1645 '复现记录':1971 '复现记录与根因分析':5416 '复盘时会自动清理本会话在':5719 '多会话并行协调':12 '多域条目视为同时占用多个':1558 '多来源捞候选':1501 '多次修复复用':356 '多次修复并发允许':6154 '大概率是新需求':2993 '失败场景':3351 '失败必须升级用户':4255 '失败证据':3292 '契约':2210,6125 '好了你看':4473 '如':3553,3570,4459,5576,5580 '如同一个':1681 '如已知':1974 '如果':1559,1883,2708,4753,5247 '如果代码或':2463 '如果会话在此结束':4868 '如果你开了多个窗口在修不同':5725 '如果修复过程中有新发现分流进':5505 '如果勾了':4427 '如果原本登记在':5474 '如果发现疑似僵尸':1320 '如果有暂存的':5743 '如果本':2220 '如果本次是':5513 '如果能':2978 '如果配置或数据不满足用户闭环断言':2780 '如果项目无法创建':6187 '如果项目有':5438 '始终可用':2574 '字段':2069,2700,3258,4920 '字段包含':3518 '字段填':2200 '字段处理':1767 '字段强制要求':3645 '存在':1929 '存在性':5731,6277 '存相对路径':2086 '安全':5698 '安装位置回退':1121 '完成':196,6347 '完成但有顾虑':6356 '完成分流后向用户输出总结':5303 '完成后':5620 '完成后向用户报告':3392 '完成当前修复的合并':4527 '完成状态':6346 '完成的结果':2723 '完整':5391 '定位引用':2620 '实际行为':1497 '实验开关的':2749 '审查已合并的代码':5694 '对应区':5154 '对应条目':603 '对应条目更新为':4089 '对应行':4456 '对每条新发现':5178 '对照判定':1589 '对结果没信心':6368 '导致':4128 '将从模板初始化':1048 '尚未':2953 '就不写修复代码':221 '就不能用':4165 '就先关闭本次修复':4967 '就必须走项目统一':2227 '就绕过这个门禁':3895 '属于当前':2374 '工作':2396 '工具':3612 '工具使用技巧':5584 '工具可见就跳过':2491 '工具触发':3617 '工具调用':3736,4208 '工具调用失败或不可用':4033 '工具返回的文本消息推断':3759 '工具链约束':2896 '已':132,174,4986,5196 '已修':1390 '已修复':2783,5450 '已修复但无法完全验证':6357 '已升级处理':6363 '已合并':5019,5360,5466,6353 '已合并到':5042 '已合并的':5702 '已回填报告':4355 '已处理':4857,5488,6291 '已处理区永久保留':5502 '已完成':540,3105,4949,5007,5114,6061,6081 '已完成的':5626 '已完成的原':5384 '已尝试':6379 '已尝试修复':4021 '已归档已处理区':1403 '已收敛':187 '已收敛的依据':5012 '已暂存':5044,5361 '已有例外必须写明原因并让用户确认':3528 '已登记到':2171 '已登记的新编号':6083 '已知问题列表':1411 '已经合并了修改':4800 '已经填了':4474 '已经通过闭环断言':5001 '已被':1750 '已跑':4106 '已通过':5356 '希望登录页加':5333 '希望能':5226 '并':4773 '并入当前修复':162,3121 '并分配':5068 '并向用户展示证据':3048 '并在':5594 '并在报告':2455 '并在报告中注明':3233 '并建议走':2988 '并暂停等用户确认后再继续':1569 '并标记':5280 '并登记':1810 '并给一段简短接力':199 '并给接力':5086 '并行会话环境':1097 '并行判定':1741 '并行协调必须登记':298 '并行协调纪律':6198 '并行场景下':4588 '并行心跳文件':1272 '并行状态读取':1534 '并让用户判断':351 '并记录':2300 '并输出简短接力':555 '并进入':3127 '应为空':3511 '应修正配置':2784 '应用可访问':3569 '应该已经在':3224 '延伸需求':2976 '建议':154,592,615,1795,6384 '建议下一步':5618 '建议下个会话重新判断':5389 '建议你切去那个窗口加入而非新开':1755 '建议保留以便其他人接手':6383 '建议后续走':5336 '建议在':5745 '建议在新会话修':578 '建议开另一个会话继续':5083,5347 '建议新会话一起修':5277 '建议新会话修':5206 '建议新会话重新判断范围和根因':6084 '建议用户先跑':1325 '开关':2686,2742,3315,3537,3545,5965 '开新会话':5656 '开新会话用精炼描述重启':2843 '异域鼓励新窗口并行':1521 '异常':4030,4078,4179 '异常兜底':3940,4029 '异常态':3349,5906 '弃用':6143,6355 '引擎优先级':2413 '引用已有':1353 '引用点':3058,5265 '弹窗':3824 '强制步骤':2211 '强制读':363,5847 '强制读取项目文档':1357 '强校验':464,3303 '强校验结果为准':1983 '强烈推荐':5657 '强规范':3427 '归档':601,5400,5470 '当且仅当':1664 '当前':1143,1277,3080,3099,3676,4935,4970,5263 '当前会话状态':5625 '当前修复到此关闭':189,541 '当前修复处置完成后':4943,4952 '当前修复状态':5018,5041,5359 '当前功能不存在的能力':5227 '当前复现结论和待执行步骤':1972 '当前并行会话':1212,1716 '当前无活跃会话':1745 '当前时间':3281 '当前状态':414,1951,3324,4085 '当前由':1599 '当前疑问':4022 '当前项目':5771 '当日已用编号':1899 '影响哪些功能':2887 '影响范围':2886 '待修':4855,5313,5482,5641 '待修区':583,1633,1704,1776,1785,1838,5067,5200,5218,5293,5477 '待修区并分配':3024 '待填':5558 '待澄清':1882,5338 '待澄清区':598,1874,5080,5241 '待澄清反馈':1402 '待确认新发现':128,2949,2960,3094,5166 '待立项':1873 '很小':3383 '得到所有占用中的域集合':1555 '得到本项目的合法功能域标签清单':1550 '得到的':2442 '心跳文件':31 '必做':2707 '必填':3648 '必查内容':2753 '必看':1430 '必须':1369,1375,1381,1389,1397,1404,1414,1543,3211,3455,3614,3747,5479,6095 '必须举证':164,1675,3032,6105 '必须举证同根':5246 '必须从状态输出读取':2365 '必须从统一状态输出读取':1294 '必须传':3829,3836,3855 '必须做功能域判重':1515,6211 '必须停下问用户':2183 '必须先告知':5004 '必须先完成当前':3125 '必须先执行':6121 '必须先让用户感知这个边界':4975 '必须先说清楚':184 '必须先跑':3772 '必须列出具体证据':291 '必须创建或更新':5882 '必须判断':4124 '必须可追溯':6168 '必须向用户报告当前':1315 '必须向用户报错':2190 '必须回到':3230 '必须在项目根':306 '必须尝试':4042 '必须执行':3428 '必须执行的硬性流程':3441 '必须把用户原话转成一句可验收断言':2712 '必须把端口':2387 '必须显式选择非默认端口':2299 '必须有':6016 '必须来自':3691 '必须标记':347 '必须用':3610,4206,5057 '必须确保':1921 '必须确认':5874 '必须等用户填完单':254,5812 '必须维护批次汇总文档':5517 '必须能在':6176 '必须补':4169 '必须读':6203 '必须通过':4224 '必须通过门禁检查':4215 '必须重读报告文件':4220 '必须问用户':4955 '快速探索或已有':4317 '怎么操作':3306 '总结':4204 '总览一下其他会话':5765 '情况':1319 '想发布':5704 '想攒几个修复一起':4746 '想沉淀本会话经验':5712 '想法':3009,6301 '想法垃圾桶':3006 '感觉有点怪':5238 '成功后立即登记':6219 '我不会继续在当前修复里改它们':5052 '我会从':5671 '我会做的事':5061 '我会停在':4944 '我会先告知本次':3103 '我会先完成当前修复的合并':4938 '我会先把它列为':3093 '我会写进':5278 '我会回到':4895 '我会尝试自动解决':4813 '我会执行':4709 '我会把推迟的写入':1797 '我会读报告':4436 '我切到已有会话':1823 '我刚完成':5348 '我已经填好':3401 '我希望':2977 '我想先改写这些问题的描述':5094 '我想多修一些':1818 '我推荐本次修':1724 '我有新假设':2829 '我现在就想修':3124 '我等你':4490 '我等它返回':3731 '我觉得不是':5287 '我读冲突文件的当前状态和你的修改对比给你看':4827 '我还没试':4487 '或':227,330,394,618,1292,1733,1746,1758,1953,2355,3584,3890,4841,5754,5794,6261,6367 '或一个':6318 '或占位符登记':2186 '或同义表达':4471 '或失败原因涉及需求':4008 '或弃用本次尝试开新会话':5864 '或强制方案':5393 '或批次待最终验收状态':5993 '或批次最终验收':4145 '或批次最终验收结论':256,5814 '或暂存':6253 '或标记':2786,4175 '或校验器失败':3937 '或环境一致性':3925 '或用户明确授权本会话重新走':5833 '或用户补充的新问题':5172 '或第一个':2125 '或者主分支有新提交':4801 '或者改到了相同文件':4591 '或遇到需求':344,6092 '或项目约定的独立':3520 '截图':1646,1967,2725,4019,4174,6020 '截图和':2367 '截图和报告输出目录':1270 '截图或端到端复现':2226 '截图文件不存在':3936 '截图留证等工具在':4280 '截图路径不存在':6022 '所有项':4217 '手动执行':4051 '才把最终验收包交给用户':4465 '才能按':5816 '才能触发':4218 '才能进入':639 '打功能域标签':1573 '打好的功能域标签':2079 '打开':2440 '打开文档':4402 '打开新会话说':5667 '执行':3734 '执行完成后':3745 '执行浏览器动作前必须加载并遵守':2472 '扫一眼':1201 '批次两层验收后才进':270 '批次最终验收':495,4330 '批次最终验收发现了与原':4992 '批次汇总只做聚合':5520 '批次汇总用于让用户最后只验收一次':5562 '批次结束时':4464 '批量修复汇总':5531 '批量只做编排':250 '批量最终验收汇总':5511 '批量模式':108 '批量模式下':4438 '批量模式可以先进入':4341 '批量模式标记':478,3916 '批量模式等待最终验收包':6037 '找到':2120 '把':4848 '把已占用功能域报告给用户':6205 '把待修区的条目作为候选之一':6309 '把推迟的条目追加到':1834 '把新问题当成原':5122 '把本':4443 '把本批次需要用户走的关键用户流程合并成一条或少数几条验收路线':5561 '把本报告加入批次汇总':4458 '把本次修复的在':1800 '把每个前端交互关键步骤截图嵌入报告':471 '把逐步截图':3728 '抢':1305 '抢端口或测到旧服务':41 '报告':1628,1990,3516,4201,4299,5523,5547 '报告中':193 '报告仍必须写明浏览器证据来源为':3880 '报告当前有哪些并行会话':1206 '报告描述成':4098 '报告是单个':1998 '报告有':3530 '报告没有用户最终结论或批次最终结论前':642 '报告状态':3896 '报告目录':1083,1094 '报告索引':550,5105,6074 '报告缺少证据':4082 '报告被':4181 '报告路径':3636,5386,6082 '报错给用户':4152 '抵制':2937 '拆分':3146 '拆开走多次修复':1686 '拉到新的':4756 '挂了':5995 '指向当前':3590 '指示':3651 '按':2817,4058,4408,4547 '按你的结论推进下一步':4437 '按场景推荐':5651 '按异常':4153 '按最终结论分流':514,4559 '按独立':5288 '按用户路径操作页面':2446 '按需':1370,1410,1426 '挪到':5607,5614 '捞候选':376,1612 '捞候选之前':1541 '捞候选时':1690 '捞的条目':1910 '接下来我会调用':3408 '接力':5345,5381 '接口':2732 '接收':380 '控制台相关':2437 '推荐':389,1479,1656,2907,2910,3116,4708,4805,5088 '推荐下一个':5673 '推荐前必须读':310 '推荐单次修复范围':1509 '推荐命令':3782 '推荐理由':4027 '推荐规则':1659 '推荐选项':5781 '推迟':520 '推迟决定':4749 '推迟到':1768 '推迟合并':5021,5046,5362 '描述':1791,2830,2905,3266 '描述的是':5225 '提供截图':1352 '提取知识':5714 '提示':4537,4542 '提示用户':1563 '插件可用时':2433 '摘要':1969,2961 '操作步骤用':3356 '支持':24 '收到信号前':4475 '改了代码没效果':2675 '改修':1814 '改到的文件列表':3279 '改同一个函数':1678 '放弃修复走':4569 '放弃本次尝试':2839 '数':3475 '数据':2785,4323 '数据不一致':2652 '数据可见性':2746,3541,3851 '数据就绪':2769,3316 '数据就绪必须记录':5966 '数据就绪检查':3546 '数据就绪错位':2687 '数据就绪门禁':2743 '数据检查':3538 '数据流':1383 '数据流断裂':2892 '数据结构':1679 '数据缺失或重复':2682 '整理决策卡问用户':3952 '文件':5421 '文件名':3052 '文本返回看起来通过':3894 '文档':1368 '文档存在性':3221 '文档更新询问':536,4961 '文档的冗余内容':5437 '文档补记':605 '文档路径':3399 '断言':3934 '断言作为':6330 '新':576,3085,3110,3981,4909,5751 '新发现':507,528,3074,4425,4429,4431,4524,4926,4931,4983,5038,5162,5252,6043,6051 '新发现不会夹带到当前修复':4942 '新发现不得直接修':5146 '新发现分流':5138 '新发现分流到':564 '新发现分流在用户确认后必须写进':6284 '新发现分流完成':5304 '新发现引用点':5268 '新发现必须分流':120 '新发现暂存':4553 '新发现的':273,5822 '新发现请下次验收时说':4899 '新增':1099,1283,1311,1513,1523,1537,4587,6200 '新增硬性步骤':4581 '新的调试方法论':5579 '新编号':5388 '新问题不会在本会话继续修':5023 '新问题可能很重要':4968 '新需求':151,275,572,588,1401,1789,5071,5224,5329,5824 '新需求一句话':1864 '新需求区':591,1794,1858,2987,5075,5230 '方式写':3359 '方案':2852 '方案确认':2614,2849 '无冲突':4694 '无法判定时向用户确认':1586 '无法复现':2607 '无法复现就不要修':5876 '无法复现就无法验证修复':2412 '无法完成的问题':2715 '无法确认则':3595 '无法自动获取':1197 '无独立':6183 '无编号':5242 '无论来自用户反馈':6066 '日志':71 '日志证据':1647,4020 '日志路径':1970 '日期':5440,6338 '旧':1303 '旧数据':2664 '旧项目兜底探测':2303 '旧项目没有统一入口时':2385 '时':84,290,2357,2955 '时发现新':3083 '时回应':4488 '时序敏感':2646 '时的回修纪律':3956 '时间戳':5243 '明显不共因':3014 '明确可执行':3360 '明确调用':3435,5977 '是':4126,4147,6267 '是假设编号':2802 '是可复现的失效行为':5214 '是否可用':1239 '是否合并':4563 '是否属于本轮功能范围':1651 '是否把新问题更新到':191 '是否符合预期':2762 '是否返回':2765 '是报告里有不可自动验证的项':4137 '暂不更新':5090 '暂停修':5692 '暂停本次修复等环境修好':4077 '暂存':519,5020,5467,6354 '暂存不合并':4741 '暂存决策':530,4528,4939,6055 '暂存的':5633 '暂存这个修复':4819 '暂无':1226 '暂无进行中会话':2124,2149 '暗示':3623,4213 '更干净':5690 '更新':403,436,1915,3199,3212,3987,4453,4907,4914,5706 '更新到文档':5085,5144 '更新待分流列表后重新询问':5117 '更深一层':2878,2881 '最后由批次汇总统一交给用户验收':119 '最小修复':3140 '最小变更':2933 '最少文件':2935 '最少行数':2936 '最终人工验收指南':5560 '最终以':1978 '最终用户可见结果':3312,5960 '最终由':3299 '最终结论':503,4420,4504,5434 '最终结论只能选一个':4543 '最终结论还没勾':4538 '最近':706 '最近变更':1427 '有':2350 '有交集即判冲突':1585 '有挂':486 '有界回':487,3929,5997 '服务后重启':3594 '服务挂了':4129 '未':124 '未修好':4972 '未匹配等':2189 '未发现统一':2295 '未复现':1881,5237,5344 '未检测到运行中的应用':955 '未跑完所有验证项':4105 '未达上限时不打扰用户':4245 '未达到自动闭环上限时':3957 '未通过':4886 '本':3778 '本会话新报告':1700,1732 '本会话继续修下一个':5675 '本地':2770 '本地应用':1242,3686 '本地正常线上不行':2671 '本批次':5537 '本次':136,538,1725,3277,3671,4703,5005,5027,6059 '本次修':390 '本次修哪个':1657 '本次修复合并到':4788 '本次修复完成':5622 '本次修复涉及':3136 '本次修复继续':3109 '本次修复范围推荐':1699 '本次终止':1824 '本步只在会话首次进入时执行一次':1340 '本节是':3439 '本身已经是最全的历史记录':5409 '权限':3540,6190 '权限状态':2767 '权限边界':2745,3850 '权限边界或数据可见性的':5968 '条':3343,3386,3473,4884,5902 '条人工验收指南':3407 '条件必填':3695 '条待修':5666 '条提交':708 '条边界':3348,5905 '来源':1731,1958,3552,5411 '来自':3558,4793,5305 '来自功能开发后的':1624 '来自用户反馈':2710,3835 '枚举完整性等结构性问题':5700 '架构':1382 '查':2546,2665,2683,2692,4798 '查事务':2654 '查共享状态并发访问':2647 '查变化':2542 '查可交互元素':2533 '查可选值缺少守卫':2650 '查失败请求':2551 '查字段映射':2661 '查环境变量':2672 '查询错误':2681 '查进程':2676 '标签化临时日志':2795 '标签化日志':2793 '标签化日志和断言':3184 '标签必须从':1574 '标记':1595,1608,3948,4011,5201 '标题':1639,5541 '校验器失败即':3883 '校验器路径':3777 '校验器输出':4116 '核心':1504 '核心机制':59 '根因':80,444,2883,2884,3174,3175,3268,3402,5894 '根因不明确':6362 '根因位置':5259 '根因定位完成':2861 '根因必须用':5855 '根因找到':6348 '根因确实跨这些文件':3144 '根因确认':629,2848 '根因追踪':424,2612,2616 '根因链':4891 '根因阶段必须检查并写入报告':2751 '根目录':690 '格式':5490 '格式没被破坏':4188 '格式规范':5767 '框架':799 '框架探测':804 '检查':5696 '检查工作区状态':1468 '检查最近变更':2636 '检查面':2752 '检查项':3457 '模块':1853 '模块边界':1384 '模式':100,3709 '模式下':4375 '模式收到前不合并':6033 '模式检查清单':2642 '模式进':476,3914 '模式需要用户填写该报告的最终结论':4338 '模板路径按':1119 '模糊反馈':158,276,573,595,5076,5235,5825 '模糊反馈原话':1880 '次':343,4007,4253 '次仍失败':6091 '次假设失败':5862 '正在调查的':5773 '正常结束':4840 '正式':2509 '正式合并前必须预演':4592 '正确':1361,2660 '步骤':4400 '每个':19,62,239,261,631,1054,3842,5563,6322 '每个修复原子提交':6312 '每份报告都要写清':5958 '每会话一次':355 '每条标注假设编号':2796 '每条验证项必须可以':3353 '每次一个':5804 '每次修复':367 '每次修复都暴露新问题':2924 '每次只修':224,5791 '每次提问结构':5768 '沉淀':600,5396 '沉淀纪律':6310 '没事了':5736 '没修好':5051 '没有':258,2735,2918,4237 '没有完整报告':3217 '没有弃用选项':4564 '没有截图':6021 '没有报告不创建':5887 '没有用户最终结论或批次最终结论不进':5911 '沿用其原编号':1911 '沿用还是重新排查':1466 '注意':4156 '注释即可':3010 '流程':2720 '流程总览':353 '测试':2771 '测试命令':2728 '测试数据是否足以展示用户问题':2701 '测试数据状态':3323 '测试框架':800 '测试框架探测':805 '测试过程与':5431 '测试过程与截图证据':3366,3487,3963,4114,4260 '浏览器':2667 '消除实际问题':2934 '涉及前端展示':5967 '涉及前端页面或交互':4164 '涉及文件':82,447,3276 '涉及页面展示':2744,3821 '深度断言':91,3416,3729 '清':4863 '清上下文':5682 '清单':718 '清点所有并行会话':5723 '清理':324,1327,4771,5742,6208,6263 '清理临时代码':3180 '清理的职责分给':4836 '渲染':2898 '满足任一条件即进入':4979 '漏掉':4109 '演进历史和设计决策背景见':213 '灰度':3852 '灰度发布':2747 '点击':3822 '点击登录头像立刻更新':4885 '然后':3732 '然后写入报告的前置事实':1948 '然后回':5683 '然后给你一段简短接力':5081 '然后输出简短接力':5106 '爆炸半径控制':3131 '特定':5585 '特性开关':2673 '状态':440,694,697,803,3203,3322,5449,5542,6372 '状态不同步':2651 '状态写为':4445 '状态同步':2894 '状态字段':3055 '状态改':6192 '状态更新为':3334 '状态枚举只能使用':5919 '状态输出':6163 '状态输出必须显示监听进程':2372 '状态这两个硬信号':6280 '独立':6,8,141,241,243,245,247,570,579,1839,3090,3206,3491,3513,5062,5212,5320,5328,6324 '独立端口':6157 '独立验证':3354 '环境一致性':3902,4398,5535 '环境一致性不是':6023 '环境不确定':4010 '环境中':44 '环境中的优先级':4301 '环境变量':2758 '环境探测':358,659 '环境校验':3935 '环境身份不确定':346 '环境身份摘要':1650 '环境身份无法判断':3945 '环境身份校验':89 '环境身份校验回填到报告里':3730 '环境身份疑问':6094 '环节无法自动化':4072 '现在开始':3418 '现有':716,720 '现象':69,408 '现象说不清':5236 '理由':1756,2912,5782 '生命周期':2656 '用':2105,2857,2903 '用于以后定位问题时回溯':6294 '用于前端页面':2434 '用于将来定位类似问题时回溯':5504 '用户不确认':557 '用户人工验收':494,4329 '用户勾了':4576 '用户勾了多个':4540 '用户勾的是':4507 '用户协作模式':5717 '用户原话':2713,3311,5959 '用户反馈':543 '用户只看':93 '用户在':2718 '用户在当前':4984 '用户填了':4545 '用户如果不认可可覆盖':5300 '用户想继续修下一个':607 '用户截图':1965 '用户打开文档填':500 '用户报告':1347,1851,1869 '用户接下来做什么':6385 '用户描述的关键词':1450 '用户改写后的描述':5174 '用户明确偏好':5750 '用户明确要求':6293 '用户最终结论':5035 '用户最终结论是':4981 '用户未填任何勾':4535 '用户未确认前不得默默入档':6289 '用户本会话报告的':1615 '用户看到':2714 '用户看到的现象':2865 '用户确认':551,5143 '用户确认后':140,150,157,194,1833 '用户确认才进':2914 '用户确认方案后才动手':5859 '用户确认范围':400 '用户结论':5013 '用户结论三选一':6039 '用户编辑域列表后才继续':6237 '用户要检查什么':3305 '用户说':508,2973,4486,4494 '用户走':4869 '用户选择':5097 '用户选择后的处理':5096 '用户问其他问题时正常回答':4485 '用户问题闭环断言':3310,3529,3531,3904,5039 '用户问题闭环断言必须存在':5957 '用户问题闭环检查':2703 '用统一':3578 '用自然语言':3622 '用错误消息':2621 '由用户主动选择':613 '由用户决定是否写入文档':2970 '画数据流':2630 '留给':3368 '留给用户':3376 '疑似同根':3091,5257 '症状':1773,1782,2871,3087 '症状一句话':1846 '登出时有一次':5324 '登录后头像还是旧的':4888 '登录头像不刷新':5494 '登录页右上角铃铛图标偶尔闪一下':5254 '登记':2059,2066 '登记于':1735 '登记到':1802 '登记失败':2187 '的':234,582,590,597,1317,1632,1765,1989,2102,2485,2986,3023,3780,4060,4119,4273,4917,5066,5074,5079,5124,6174,6229 '的修复记录':3990 '的判定':3819 '的另一个':3030 '的合并':6054 '的复现':2439 '的对应区':1837 '的待修区':144 '的待澄清区':160 '的心跳文件':1103 '的技术证据仍回到各自':5565 '的报告有':3543 '的报告链接':417 '的新需求区':153 '的方式':1349 '的日汇总习惯':5442 '的根因':1392 '的状态同时改':2195 '的状态同步改':6265 '的状态改':4852 '的症状描述':5587 '的登记':5721 '的登记仍有效':4867 '的窗口继续':1829 '的等价流程':4057 '的结论':5380 '的职责':1333,6271 '的证据':4973 '的责任在':326 '的过程案卷':2000 '的错误处理引发两个症状':3056 '的非前端项':4161 '的领地':4266 '的验收':5309 '的验证项':4881 '的默认处理':3076 '目录':1053,1070 '目录不存在':1322 '直接':3959 '直接原因':2873,2876 '直接回到':4903 '直接复用上下文':1344 '直接开始':1486 '直接按独立':5296 '直接描述':1617 '直接描述现象':1350 '直接调用':4287 '直觉再强也要先验证':222 '相关文件':1852 '相同优先级按登记时间':1695 '相对路径':2073 '看到':2722 '看哪条':3968 '看起来类似':1685 '真的要放弃走':6150 '瞬时失败常见':4048 '短':3284,3682 '短会话':52 '硬动作':5471 '硬性':1918,5879 '硬性关卡':4331 '硬性拒绝':3000 '硬性步骤':1538,2062 '硬性要求':2178,2349,5139 '硬性门禁':3447,4585 '硬约束':3039,6100 '确定':2013 '确定性复现是调查的核心':2411 '确实不可自动验证':4160 '确认':1698 '确认入档后开新会话接力':3129 '确认入档后必须给简短接力':6076 '确认共因':233 '确认共因的':5799 '确认同根':5276 '确认后必须逐条分类并写入':5152 '确认后才进':2853 '确认本次修复范围后':1919 '确认范围':301 '确认范围时为本次修复分配编号':1894 '磁盘':6189 '示例':5024 '示例已给出':1568 '禁止':1996,3756 '禁止把':4094 '禁止无限循环':352 '禁止行为':3362,5119 '禁止进入':3218,4240 '禁止顺手修':121 '种只适用于':4159 '移动端适配':3828 '稍后回来处理':4751 '空':1234,1594,1607 '空值传播':2648 '空态':2776 '空态原因':2768 '空数据':3350 '立刻':3733 '立即':2065 '立即停下':2947 '立即停止':2825 '立即回退':4645 '立即用':5680 '立即进入':4953 '立项':156,594,2990 '竞态条件':2644,5699 '章节逐条跑':4063 '端口':2340 '端口劫持':1300 '端口劫持是典型':2679 '端口必须来自项目':6158 '端口治理':15 '端口预检':421 '端点':3062 '端点失效':1683 '端点搜索':2624 '符合':5188 '第':4157,4882,6089 '等':3098,4555 '等价于':5679 '等到修完代码才创建报告':1997 '等原':2962 '等复盘或':4861 '等当前':3112 '等待批次最终验收包统一收口':4348 '等待用户信号':4467 '等待用户说':4469 '等待返回':3739 '等用户':6028 '等用户验收该':104 '类似':1463 '类别':5181 '类型':2890 '类型转换':2662 '类型需要':3555,3572,3690 '类条目':1416 '粘贴':4117 '粘贴到':5487 '粘贴错误':1351 '精确插入在':2107 '糟糕的修复比不修更糟':6369 '红旗信号':2916 '红线':620 '红绿证据':79,443,3405,5420,5897 '纪律':6117,6282 '纯':3860 '纯代码':2424,2573 '纯后端':3862 '纯脚本':3863 '线上数据是否足以让用户看到目标状态':2772 '组':6320 '经':231,265,5797 '结束会话':5653 '结束时':1313 '结束本次':561 '结构化证据':56 '结果':3761,5015 '结果填到':4294 '结果解析':3764 '结论':5271,5962 '给下一个会话保留判断空间':5394 '给出建议':5780 '给每条候选':1571 '给用户决策卡':4015 '给过长':5134 '绝不在当前修复内夹带':282 '绝不说':5866 '绝对路径':3678 '统一':806 '统一编排':4293 '继续':3143,4143 '继续会引发':5660 '继续修':4517,4568,5999,6149 '继续修复':3931 '继续回':5126 '继续处理批次中下一个':4462 '继续调查':2828 '缓存版本号':2669 '缓存过期':2663 '编号':149,1893,3673,5070,5184 '编号和一句话标题':5372 '编号已在':2011 '编号必须先有':633 '编号必须有':263 '编号用于':1901 '缺字段则先补齐报告':1652 '缺少该检查不得进入':5970 '罕见':3122,5187 '翻页时感觉':5342 '而是':1507,4441 '职责分离':3437 '脑里':5151 '自动':5972 '自动执行':360,662 '自动闭环':107,388,4340 '自动闭环可以批量登记':1529 '自动闭环或多会话批量修复':5515 '自动闭环或完整':1626 '自动闭环最多':6086 '自动闭环有上限':338 '自动闭环记录':3966 '自动验收':459,3426 '自动验收全过':4383 '自己':336 '自己先过一遍验证项':4075 '自己回':4247 '自己想到':2995 '至少':3341,3346 '至少一项':3047 '节':1205,1554,2122,3367,3488,3497,3967,4115,4261 '节末尾':2104 '若':3688,4066 '若不存在':3227 '若报告结构被破坏':4195 '若来自':386 '若没有':3870 '若项目提供':1287 '范围推荐':372,1500 '范围推荐必须先扫':6307 '草案':3298 '蔓延':211,5662 '行为':5099 '行号':3053 '补':3500 '补建':3232,3252 '补建原因':3234 '补建报告':3470 '补提交':3512 '补齐':3535 '补齐验证项':3480 '表格中':5483 '表格行数':3477 '被两个症状触发':3050 '被中断或目标不是浏览器页面时兜底':2501 '被占用':1723 '要一起修':3045 '要不要我把这些新问题更新到文档里':5060 '要么修到位':2920 '要么升级':2921 '要修就开新会话':5831 '见':3941 '规则':2470 '视觉':2436,3826,4305 '解决不了的给你标记冲突点':4814 '解决冲突':4764 '解决后回这里重跑':4815 '解析':1547,1552,4503 '解析成一条一条的条目':5158 '解析用户输入':1346 '解析结果':4221 '触发':2537,3606 '触发前置检查':3446 '触发条件':4978 '订阅该回调':5267 '让下一步真正执行':4646 '让我先':4803 '让我看冲突文件再决定':4826 '让用户决定':6196 '让用户决策':6251 '让用户开另一个会话继续':201 '记住我':5334 '记录':76 '记录来源':68 '设计':345,3944,4009,6093 '设计哲学':51 '证据':3502,3515,3971,5030 '证据不足默认为独立':295 '证据不足默认独立':650 '证据区所有验证项':3900 '证据区未被':3482 '证据区标':4140 '证据区缺少截图':3933 '证据和闭环轮次':3992 '证据完整性门禁':3766 '证据已写入':3493 '证据是什么':188 '证明它':5869 '证明方式':2724,3313,5961 '诊断':5715 '询问':5059 '询问合并方式':4676 '询问是否写入':548 '询问是否写入文档':5054 '询问是否把新问题更新到文档':6062 '该行':5485 '详见':5499 '说明流程违规':3228 '请人工验收':498 '请从这些新条目里选一个继续':5373 '请你做人工二次验收':4387 '请求':5326 '请用户决定':4073 '请用户确认':4197 '请用户确认开关策略':2790 '请用户给新描述':5116 '请确认':4544 '请稍候':3420 '请编辑功能域声明区':1136 '请说明理由':1820 '请选一个再告诉我验收了':4539 '读':1516,1545,3485,3494,4112,4518,4889 '读什么':1371 '读取':2459 '读取报告':4492,4499 '读取新发现':5156 '读报告':511,3474 '读报告的':3961 '调整范围':1813 '调查纪律':5842 '调用':455,3422,3449,3698 '调用后检查报告是否完整':4187 '调用失败':4037 '调用格式':3625 '调试':2217 '负责更新报告的工程事实和人工验收草案':3257 '贴代码位置':3051 '贴字段名':3057 '走':5758,5818 '走了合理':2778 '走回':4566,6147 '超出':3139 '超出能力':6366 '越位填写':3484 '越位填过就清空重来':3490 '跑自动验收':3412 '跨':1101 '跨会话登记的':1634 '路径':1233,3522,3640,3663,3675,6382 '路由':3825 '跳过都是违规':3444 '轮':6088 '输入':2631,3823 '输出':497,2633,3565,4362 '输出必须包含三件事':5008 '边界':4946 '边界情况':4534 '边界接力':17,171 '边界清晰':208 '边界确认':535,2969,4532,4960 '达到上限或有疑问则':489 '迁移独立':3526 '过度规定下个会话方案的接力':5135 '过滤后计数必须联动':5577 '过滤验证':2820 '过程中发现的新问题已经写入':5368 '返回后':3770 '还是':179,6069 '还没修好优先':4552 '还没追踪数据流就提方案':2922 '这个命令扫一遍':5727 '这个新发现和当前':3042 '这个问题与':1458 '这应该能修好':5867 '这是共因':3118 '这条':5602 '这条会触发未来什么具体行为':6345 '这条新发现是当前':287 '这样如果会话中还要继续修下一个':4864 '进':531,552,4511,4525,4529,4674,4680,4928 '进入':1806,3655,4480,5101 '进入主仓库':4594 '进入本阶段前必须满足':4349 '进程身份':2674,2900 '进行中会话':1204,1214,1318,1553,2103,2121,2130 '远程配置':2759 '违反单次修复原则':1819 '连续':4251 '连续回修失败':341 '连续失败':4005 '追到的根因':3272 '追加':3983,4911 '追加一行会话登记':308 '追加一行到列表':1875 '追加一行到表格':1841,1859 '追加到':2100 '追踪时内嵌':2643 '追踪调用链':2627 '适用于':4745 '适用于上下文已嘈杂的情况':2844 '选一个':2891 '选取':1576 '选项':5335,6145 '逐条亲自验证':4410 '逐条分析':566 '逐条分类':5177 '逐步截图':90 '逐项核对':3456 '逗号分隔':1581 '通俗解释':5777 '通用踩坑模式':5575 '通知用户':4372 '通过':1148,1492,2855,2964,3077,3615,6351 '通过但':2689 '通过后标记':112 '通过证据':3294 '通过验收后':3102 '避免':39 '避免长会话的':209 '那些条目是新登记的':5508 '那是':1331,4262 '那种东西写代码注释':6302 '部分更新':2653 '都不得继续修':182 '都不能交给用户验收':6025 '都以这句闭环断言为准':2731 '都只是证据':2738 '都在':2405 '配置':2741,3314,3536,3544,5964 '配置文件':2757 '配置漂移':2670,2895 '采集':2447 '里':1203,5664 '里声明功能域标签':1567 '里本会话的登记还在':5739 '重启并重新读取':3568 '重提':3979 '重新思考':3150 '重新聚焦':5770 '重新读取':3748 '重新走门禁':3997 '重新追根因':3975,4897 '重来':4249 '重构型':1578 '重查根因':3549 '重要规则':5788 '重试一次':4047 '重读报告':3740 '重跑':4135,4921 '针对每个验证项跑自动化测试':463 '铁律':218,4203,5844 '铃铛图标偶尔闪一下':5318 '错误':2548,4038 '错误写入报告':2462 '错误层级':2925 '错误恢复':3352 '闭环断言':2716,5016 '问题':2864,4017 '问题发现记录':1957,5410 '问题理解':362,1335 '间歇性':2645,6358 '防止':1298 '防重复排查':1393 '阶段由':4283 '阶段这些工具由':4289 '阻塞':5451,6361,6373 '阻塞核心流程且独立可定位':1757 '附证据':3092 '除非你能说出':5601 '除非明确共因':5678 '除非明确共因才本会话继续':612 '除非用户明确要共因地一起修':212 '除非用户明确要求且重新走':5129 '除非能说出':6344 '隔离':55,1488 '需求':3943 '需要你在':1565 '需要更了解系统的人':2833 '需要更多信息':6374 '需要线上确认':6360 '静态逻辑':4324 '非空时':2517 '靠':29 '页面':2719,2888 '页面并重新采集':2468 '项目':4319 '项目存在统一入口时必须使用它':6127 '项目文档清单':956 '项目文档路径':1257 '项目根':1104 '项目测试框架':4315 '顺便加':2974 '顺手重构':2938,2996,6300 '预期':3141 '预期效果':3307 '预期行为':1496 '预期行数':4194 '预演':323,4817,6249 '预演失败时':4780 '预演失败说明并行会话改到了相同文件':4781 '预演成功':4644 '预演通过时':4685 '预演避免撞车':35 '领取会话':2199 '领取开始就创建':65 '首次使用':1047,1117 '首次使用并行化':1564 '首次使用的项目由':6234 '首行':3288 '驱动修复':433 '验收':3660,3714 '验收了':509,4435,4470,4495,6029 '验收入口':1973,3295,5532 '验收入口与环境身份校验':4405,5423 '验收反馈中描述了当前功能不存在的行为':2991 '验收地址':4389 '验收完了':4472 '验收完没':4483 '验收未通过':4876 '验收标准':1377 '验收结论':4691 '验证':4997 '验证前':2466 '验证它':5868 '验证项':3344 '验证项列表':4110 '高中生能懂的语言':5778 '默认':3108,5599,5832 '默认不写':6343 '默认仍建议新会话':5133 '默认建议新会话或':204,609 '默认推荐':1660,5748 '默认推荐新会话或':5839 '默认新会话完成工作':5753 '默认独立':3065,6111 '默认硬性拒绝':2944","prices":[{"id":"60146d42-430f-4260-a1f7-64d59ac43159","listingId":"748678a0-db6f-49a1-94e2-c38da654ed51","amountUsd":"0","unit":"free","nativeCurrency":null,"nativeAmount":null,"chain":null,"payTo":null,"paymentMethod":"skill-free","isPrimary":true,"details":{"org":"yike-gunshi","category":"forge-skills","install_from":"skills.sh"},"createdAt":"2026-04-24T07:03:37.862Z"}],"sources":[{"listingId":"748678a0-db6f-49a1-94e2-c38da654ed51","source":"github","sourceId":"yike-gunshi/forge-skills/forge-bugfix","sourceUrl":"https://github.com/yike-gunshi/forge-skills/tree/main/skills/forge-bugfix","isPrimary":false,"firstSeenAt":"2026-04-24T07:03:37.862Z","lastSeenAt":"2026-04-25T19:02:44.190Z"}],"details":{"listingId":"748678a0-db6f-49a1-94e2-c38da654ed51","quickStartSnippet":null,"exampleRequest":null,"exampleResponse":null,"schema":null,"openapiUrl":null,"agentsTxtUrl":null,"citations":[],"useCases":[],"bestFor":[],"notFor":[],"kindDetails":{"org":"yike-gunshi","slug":"forge-bugfix","github":{"repo":"yike-gunshi/forge-skills","stars":11,"topics":["agent-skills","ai-development","claude-code","forge","skill-md","skillsmp"],"license":"mit","html_url":"https://github.com/yike-gunshi/forge-skills","pushed_at":"2026-04-25T10:22:48Z","description":"Forge — 文档驱动的 AI 辅助开发框架 | Document-driven AI development framework with 14 Skills covering brainstorm → PRD → design → engineering → QA → review → ship → retrospective","skill_md_sha":"1a93c3e1e58540b3cd07ec636f9f350cefc5ff93","skill_md_path":"skills/forge-bugfix/SKILL.md","default_branch":"main","skill_tree_url":"https://github.com/yike-gunshi/forge-skills/tree/main/skills/forge-bugfix"},"layout":"multi","source":"github","category":"forge-skills","frontmatter":{"name":"forge-bugfix","description":"一次修一个 bug + 独立 worktree + 独立 TDD + Bug 修复验收报告 + **多会话并行协调** + dev server 端口治理 + Pass 边界接力（v7.2）。\n每个 bug 从登记开始就创建结构化 Bug 修复验收报告。支持 3-4 个窗口同时修不同功能域的 bug，\n靠 `.forge/active.md` 心跳文件 + 功能域判重 + 合并前 merge 预演避免撞车；\n启动应用时优先使用项目统一 dev entrypoint，避免 worktree 抢端口或测到旧服务。\n在 Codex 环境中，前端复现和修复后自验优先使用 browser-use:browser 的 in-app browser；\nComputer Use 只作为 browser-use 不可用或非浏览器桌面应用的兜底。\n铁律：不做根因分析就不写修复代码 + 每个 bug 独立 worktree/TDD/commit/QA + 没有 Bug 修复验收报告不算完 +\n用户问题闭环断言、配置/开关/数据就绪检查、QA 截图证据完整性门禁缺一不可 +\n新发现禁止当场顺手修（原 bug Pass 后询问，用户确认才分流到 backlog）+ 多 bug 默认不串成长会话 +\n原 bug 已 Pass 后遇到任何新问题，必须先告知“本次 bug 已完成”，询问是否写入文档并给接力 prompt +\n**并行会话必须在 active.md 登记，同域归并会话、异域鼓励并行**。\n\n会话级（一次性）：P0 环境探测（+ 读 active.md 看其他会话）→ P1 问题理解 + 强制读 PRD / ENG / Bugfix 历史 / Memory。\n每次修复（可循环）：\n  P2 范围推荐（用户指定、QA 发现、backlog 候选、按功能域判重）→ P2.5 创建/更新 Bug 修复验收报告\n  → P3 创建 worktree + 写入 active.md + 复现 → P4 根因追踪 + 5 Whys + 方案确认\n  → P5 独立 TDD 驱动修复 + 原子提交 → P5.3 更新报告为待 QA 状态\n  → P6 调用 forge-qa 做自动验收 → P6.5 用户人工验收或批次最终验收等待\n  → P7 按三选一分流（Pass 合并 + merge 预演 / Fail 回 P5 / Pass + 新发现）\n  → P7.4 Pass 边界确认（询问是否把新问题写入文档 + 接力 prompt）\n  → P7.5 新发现分流到 backlog.md → P8 沉淀（active.md 由 forge-fupan 清理）。\n出口：强烈建议新会话或 /clear、/compact 后继续下一个 bug；\n  全部完成 → 建议 /forge-review、/forge-ship、/forge-fupan 或 /forge-status。\n\n触发方式：用户说\"bugfix\"、\"反馈个问题\"、\"修这个 bug\"、\"这里有问题\"、\"为什么不对\"、\"排查一下\"、\"investigate\"、\"forge-bugfix\"，\n或用户报告错误、异常行为、功能失效时主动建议使用。"},"skills_sh_url":"https://skills.sh/yike-gunshi/forge-skills/forge-bugfix"},"updatedAt":"2026-04-25T19:02:44.190Z"}}