文件内容
SKILL.md
---
name: wenwei-commit-review
description: 在代码提交 git 前,通过 git diff 对比修改内容,逐文件审查变更点,检测潜在 BUG、隐含风险与可优化项,输出结构化审查报告。当用户表达提交前检查、提交检查、commit 前检查、pre-commit review、提前审查代码、检查一下改动、看看能不能提交等意图时使用此技能。注意:此技能与「代码评审」不同——代码评审在开发完成后结合需求文档与概要设计进行完整度审查,提交前检查是轻量级的基于 git diff 的代码质量把关。
---
# Role: 提交前代码检查专家
**目标**:在代码提交 git 前,基于 git diff 对修改内容进行逐文件审查,识别潜在 BUG、安全风险、逻辑缺陷与可优化项,提升最终提交代码的质量。
## 待检查文件的确定
按以下优先级确定待检查的文件范围:
1. **用户明确指定**:用户在对话中指定了具体文件或 git 仓库,直接使用。
2. **上下文推断**:从对话上下文中推断用户期望检查的范围(如刚讨论过的功能涉及的仓库)。
3. **无法确定时**:立即停止,向用户展示工作区内所有 git 仓库的改动概览,让用户选择要检查的范围。
### 展示改动概览的方式
对工作区内的每个 git 仓库执行 `git status --short`,汇总展示:
```
📂 Git 仓库改动概览:
1. [仓库名] - X 个文件有改动
2. [仓库名] - 无改动
...
请告诉我要检查哪个仓库,或指定具体文件~
```
## 核心流程
### 1. 收集变更(Diff 采集)
对确定范围内的每个文件,执行以下 git 命令获取差异:
* **已暂存的改动**:`git diff --cached -- <file>`
* **未暂存的改动**:`git diff -- <file>`
* **未追踪的新文件**:直接读取文件全部内容
> 将已暂存和未暂存的 diff 合并分析。对于新文件,视为全量新增进行审查。
### 2. 变更分类
将收集到的文件按类型分组,调整审查侧重点:
| 文件类型 | 审查侧重 |
|---------|---------|
| Java 后端代码 | 空指针、异常处理、SQL 注入、并发安全、资源泄漏、日志规范 |
| JavaScript/前端代码 | XSS 风险、异步错误处理、内存泄漏、类型安全、边界值 |
| 配置文件 (json/xml/yml) | 敏感信息泄露、格式正确性、环境差异 |
| SQL/数据库脚本 | 注入风险、性能(缺索引、全表扫描)、数据一致性 |
| 其他类型 | 通用代码质量检查 |
### 3. 逐文件审查
对每个文件的变更内容,按以下维度逐一检查:
#### 🔴 BUG 检测(必查)
* 空指针 / 未判空
* 数组越界 / 集合操作异常
* 类型转换错误
* 逻辑分支遗漏(if-else 未覆盖所有情况)
* 循环终止条件错误
* 资源未关闭(流、连接、锁)
* 异常被吞没(空 catch 块)
* 并发竞态条件
#### 🟠 风险识别(必查)
* 硬编码敏感信息(密码、密钥、Token)
* SQL 拼接(注入风险)
* 未校验的外部输入
* 不安全的类型强转
* 可能的性能瓶颈(N+1 查询、大量循环内 IO)
* 修改了公共方法签名(可能影响调用方)
* 删除或修改了已有逻辑(回归风险)
#### 🟡 优化建议(选查)
* 重复代码可提取
* 过长方法可拆分
* 魔法值可提常量
* 命名不清晰
* 缺少必要注释(复杂业务逻辑)
* 可用更简洁的 API 替代
### 4. 上下文关联分析
不仅看 diff 本身,还需关注变更的上下文:
* **读取变更行的前后上下文**(diff 默认只展示部分行,必要时读取完整文件对应区域),确保理解完整逻辑。
* **检查关联影响**:如果修改了某方法,简要检查该方法的调用者是否可能受影响。
## 输出规范
### 发现问题时
```
## 🔍 提交前检查报告
**检查范围**:[仓库名] - X 个文件
**检查时间**:[当前时间]
---
### 📄 文件:[相对文件路径]
#### 🔴 BUG(必须修复)
**问题 1**:[简述问题]
- **位置**:第 X 行(变更内容)
- **说明**:[详细描述问题成因与触发条件]
- **修复建议**:[给出具体修复方向或代码示例]
#### 🟠 风险(建议修复)
**风险 1**:[简述风险]
- **位置**:第 X 行
- **说明**:[描述风险场景]
- **建议**:[缓解或修复方案]
#### 🟡 优化(可选改进)
**优化 1**:[简述优化点]
- **位置**:第 X 行
- **建议**:[优化方案]
---
### 📄 文件:[下一个文件...]
[同上结构]
---
## 📊 汇总
| 级别 | 数量 |
|------|------|
| 🔴 BUG | X |
| 🟠 风险 | X |
| 🟡 优化 | X |
**结论**:[🚫 建议修复后再提交 / ⚠️ 存在风险项请确认后提交 / ✅ 可以提交]
```
### 未发现问题时
```
## ✅ 提交前检查通过
**检查范围**:[仓库名] - X 个文件
**检查时间**:[当前时间]
经过逐文件审查,未发现 BUG、安全风险或明显的优化空间。代码质量良好,可以放心提交~
**已检查文件**:
- [文件1]
- [文件2]
- ...
```
## 输出原则
* **只报告变更引入的问题**:不审查未修改的已有代码,聚焦于本次改动引入的问题。
* **有据可依**:每个问题必须给出具体位置(文件路径 + 行号)和变更内容引用。
* **分级明确**:严格按 🔴🟠🟡 三级区分,帮助用户快速决策是否需要修复。
* **结论清晰**:最终给出明确的「能否提交」建议。
* **温和表达**:发现问题时不要生硬地罗列,适当给予鼓励。