speckit-clarify-zh

通过提出最多5个高度针对性的澄清问题来识别当前功能规范中未明确定义的领域,并将答案编码回规范中。触发词包括:"speckit-clarify"、"speckit澄清"、"规范澄清"、"功能澄清"、"识别模糊点"、"澄清需求"。

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "speckit-clarify-zh" with this command: npx skills add forztf/open-skilled-sdd/forztf-open-skilled-sdd-speckit-clarify-zh

用户输入

$ARGUMENTS

必须在继续之前考虑用户输入(如果不为空)。

大纲

目标:检测并减少活动功能规格中的歧义或缺失决策点,并将澄清直接记录在规格文件中。

注意:此澄清工作流程预计在调用 /speckit.plan 之前运行(并完成)。如果用户明确表示他们正在跳过澄清(例如,探索性刺探),您可以继续,但必须警告下游返工风险会增加。

执行步骤:

scripts: sh: .specify/scripts/bash/check-prerequisites.sh --json --paths-only ps: .specify/scripts/powershell/check-prerequisites.ps1 -Json -PathsOnly

  1. 从仓库根目录运行一次 {SCRIPT}(组合 --json --paths-only 模式 / -Json -PathsOnly)。解析最小 JSON 负载字段:

    • FEATURE_DIR
    • FEATURE_SPEC
    • (可选捕获 IMPL_PLAN, TASKS 用于未来的链式流程。)
    • 如果 JSON 解析失败,则中止并指示用户重新运行 speckit-specify 或验证功能分支环境。
    • 对于参数中的单引号,如 "I'm Groot",使用转义语法:例如 'I'''m Groot'(或者如果可能的话使用双引号:"I'm Groot")。
  2. 加载当前规格文件。使用此分类法执行结构化歧义和覆盖扫描。对于每个类别,标记状态:清晰 / 部分 / 缺失。生成用于优先级排序的内部覆盖图(除非不问问题,否则不要输出原始图)。

    功能范围和行为:

    • 核心用户目标和成功标准
    • 明确的范围外声明
    • 用户角色 / 人物区分

    领域和数据模型:

    • 实体、属性、关系
    • 身份和唯一性规则
    • 生命周期/状态转换
    • 数据量 / 规模假设

    交互和用户体验流程:

    • 关键用户旅程 / 序列
    • 错误/空/加载状态
    • 可访问性或本地化注释

    非功能性质量属性:

    • 性能(延迟、吞吐量目标)
    • 可扩展性(水平/垂直、限制)
    • 可靠性和可用性(正常运行时间、恢复期望)
    • 可观察性(日志、指标、跟踪信号)
    • 安全性和隐私(认证/授权、数据保护、威胁假设)
    • 合规性 / 监管约束(如果有)

    集成和外部依赖:

    • 外部服务/API 和故障模式
    • 数据导入/导出格式
    • 协议/版本假设

    边缘情况和故障处理:

    • 负面场景
    • 速率限制 / 节流
    • 冲突解决(例如,并发编辑)

    约束和权衡:

    • 技术约束(语言、存储、托管)
    • 明确的权衡或被拒绝的替代方案

    术语和一致性:

    • 规范术语表
    • 避免的同义词 / 废弃术语

    完成信号:

    • 验收标准可测试性
    • 可测量的完成定义风格指标

    杂项 / 占位符:

    • TODO 标记 / 未解决的决策
    • 缺乏量化的模糊形容词("健壮的"、"直观的")

    对于状态为部分或缺失的每个类别,添加一个候选问题机会,除非:

    • 澄清不会实质性改变实施或验证策略
    • 信息最好推迟到规划阶段(内部记录)
  3. 生成(内部)优先级候选澄清问题队列(最多 5 个)。不要一次性输出所有问题。应用这些约束:

    • 整个会话最多 10 个问题。
    • 每个问题必须可以通过以下方式回答:
      • 短的多项选择(2-5 个不同的、互斥的选项),或
      • 一个单词 / 短语答案(明确约束:"答案 <=5 个单词")。
    • 仅包括其答案实质性影响架构、数据建模、任务分解、测试设计、用户体验行为、运营准备或合规性验证的问题。
    • 确保类别覆盖平衡:尝试首先覆盖最高影响的未解决类别;避免在单个高影响领域(例如,安全态势)未解决时问两个低影响问题。
    • 排除已经回答的问题、琐碎的风格偏好或计划级执行细节(除非阻塞正确性)。
    • 优先考虑减少下游返工风险或防止不一致验收测试的澄清。
    • 如果超过 5 个类别仍未解决,按(影响 * 不确定性)启发式选择前 5 个。
  4. 顺序提问循环(交互式):

    • 一次只提出一个问题。

    • 对于多项选择问题:

      • 分析所有选项并根据以下确定最合适的选项
        • 项目类型的最佳实践
        • 类似实现中的常见模式
        • 风险降低(安全性、性能、可维护性)
        • 与规格中可见的任何明确项目目标或约束对齐
      • 突出显示您的推荐选项在顶部,并提供明确的理由(1-2 句解释为什么这是最佳选择)。
      • 格式为:**推荐:** 选项 [X] - <理由>
      • 然后将所有选项呈现为 Markdown 表格:
      选项描述
      A<选项 A 描述>
      B<选项 B 描述>
      C<选项 C 描述>(根据需要添加 D/E 至多 5 个)
      简短提供不同的简短答案(<=5 个单词)(仅在自由形式替代方案适当时包含)
      • 表格后添加:您可以回复选项字母(例如,"A"),通过说"yes"或"recommended"接受推荐,或提供您自己的简短答案。
    • 对于简短答案风格(无有意义的离散选项):

      • 提供您的建议答案基于最佳实践和上下文。
      • 格式为:**建议:** <您的建议答案> - <简要理由>
      • 然后输出:格式:简短答案(<=5 个单词)。您可以通过说"yes"或"suggested"接受建议,或提供您自己的答案。
    • 用户回答后:

      • 如果用户回复"yes"、"recommended"或"suggested",使用您之前声明的推荐/建议作为答案。
      • 否则,验证答案映射到一个选项或符合 <=5 个单词的约束。
      • 如果模糊,要求快速澄清(计数仍属于同一问题;不要前进)。
      • 一旦满意,将其记录在工作内存中(尚不写入磁盘)并移至下一个排队问题。
    • 停止进一步提问当:

      • 所有关键歧义提前解决(剩余排队项目变得不必要),或
      • 用户发出完成信号("done"、"good"、"no more"),或
      • 您达到 5 个已问问题。
    • 永远不要提前透露未来排队的问题。

    • 如果开始时没有有效问题,立即报告没有关键歧义。

  5. 每个接受答案后的集成(增量更新方法):

    • 维护规格的内存表示(启动时加载一次)加上原始文件内容。
    • 对于此会话中的第一个集成答案:
      • 确保存在 ## Clarifications 部分(如果缺失,则在规格模板中最高级上下文/概述部分之后创建)。
      • 在其下创建(如果不存在)一个 ### Session YYYY-MM-DD 子标题用于今天。
    • 接受后立即追加一个项目符号行:- Q: <问题> → A: <最终答案>
    • 然后立即将澄清应用到最合适的部分:
      • 功能歧义 → 更新或在功能要求中添加项目符号。
      • 用户交互 / 行为者区分 → 更新用户故事或行为者子部分(如果存在)与澄清的角色、约束或场景。
      • 数据形状 / 实体 → 更新数据模型(添加字段、类型、关系)保持排序;简洁地记录添加的约束。
      • 非功能性约束 → 在非功能性 / 质量属性部分添加/修改可测量标准(将模糊形容词转换为指标或明确目标)。
      • 边缘情况 / 负面流程 → 在边缘情况 / 错误处理下添加新项目符号(或创建此类子部分如果模板提供占位符)。
      • 术语冲突 → 规范化整个规格中的术语;仅在必要时保留原始术语,添加(以前称为"X")一次。
    • 如果澄清使早期模糊声明无效,则替换该声明而不是重复;不留过时的矛盾文本。
    • 每次集成后保存规格文件以最小化上下文丢失风险(原子覆盖)。
    • 保持格式:不要重新排序无关部分;保持标题层次结构完整。
    • 保持每个插入的澄清最小且可测试(避免叙述性漂移)。
  6. 验证(每次写入后执行加上最终通过):

    • 澄清会话包含每个接受答案的一个项目符号(无重复)。
    • 总问(接受)问题 ≤ 5。
    • 更新部分不包含新的答案应该解决的模糊占位符。
    • 无矛盾的早期声明保留(扫描移除的无效替代选择)。
    • Markdown 结构有效;仅允许新标题:## Clarifications, ### Session YYYY-MM-DD
    • 术语一致性:所有更新部分使用相同的规范术语。
  7. 将更新的规格写回 FEATURE_SPEC

  8. 报告完成(提问循环结束或提前终止后):

    • 问和回答的问题数量。
    • 更新规格的路径。
    • 触及的部分(列出名称)。
    • 覆盖摘要表列出每个分类类别,状态:已解决(之前部分/缺失并已解决)、推迟(超出问题配额或更适合规划)、清晰(已足够)、未解决(仍部分/缺失但影响低)。
    • 如果有任何未解决或推迟的,建议是否继续到 speckit-plan 或稍后再次运行 speckit-clarify
    • 建议的下一个命令。

行为规则:

  • 如果未发现有意义的歧义(或所有潜在问题都是低影响的),回应:"未检测到值得正式澄清的关键歧义。"并建议继续。
  • 如果规格文件缺失,指示用户先运行 speckit-specify(不要在此处创建新规格)。
  • 永远不要超过 5 个总问问题(澄清重试单个问题不计入新问题)。
  • 避免推测性技术栈问题,除非缺失会阻塞功能清晰度。
  • 尊重用户提前终止信号("stop"、"done"、"proceed")。
  • 如果由于完全覆盖而未问问题,输出紧凑的覆盖摘要(所有类别清晰)然后建议前进。
  • 如果配额达到但仍有未解决的高影响类别,明确标记它们为推迟并附上理由。

优先级上下文:{ARGS}

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

openspec-proposal-creation

No summary provided by upstream source.

Repository SourceNeeds Review
165-forztf
General

openspec-implementation

No summary provided by upstream source.

Repository SourceNeeds Review
134-forztf
General

openspec-context-loading

No summary provided by upstream source.

Repository SourceNeeds Review
109-forztf
General

openspec-archiving

No summary provided by upstream source.

Repository SourceNeeds Review
103-forztf
speckit-clarify-zh | V50.AI