CANN/cannbot-skills Git差异统计
Diff 变更统计
【免费下载链接】cannbot-skillsCANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。项目地址: https://gitcode.com/cann/cannbot-skills
使用git diff获取 PR 变更文件列表和统计信息。
1. merge-base 模式
适用 skill:code-review、gitcode-pr-handler、gitcode-issue-gen
先通过 merge-base 计算出基准 commit,再与 PR 分支比较。
# 前提:已计算 MERGE_BASE # MERGE_BASE=$(git merge-base base_branch pr_{pr_number})变更统计
# 每个文件的新增/删除行数 git diff --numstat $MERGE_BASE pr_{pr_number} # 文件变更类型(新增/修改/删除/重命名) git diff --name-status $MERGE_BASE pr_{pr_number} # 变更文件列表和统计 git diff --stat $MERGE_BASE pr_{pr_number}按类型筛选
# 新增文件 git diff --diff-filter=A --name-only $MERGE_BASE pr_{pr_number} # 修改文件 git diff --diff-filter=M --name-only $MERGE_BASE pr_{pr_number} # 删除文件 git diff --diff-filter=D --name-only $MERGE_BASE pr_{pr_number}单文件 diff
# 查看某个文件的详细变更 git diff $MERGE_BASE pr_{pr_number} -- {file_path}2. triple-dot 模式
适用 skill:pr-to-design-doc、gitcode-toolkit (PR 创建流程)
使用 triple-dot 语法origin/${BASE_BRANCH}...HEAD比较分支差异。
# 前提:已检出 PR 分支并确定 BASE_BRANCH变更统计
# 每个文件的新增/删除行数 git diff --numstat "origin/${BASE_BRANCH}...HEAD" # 文件变更类型(新增/修改/删除/重命名) git diff --name-status "origin/${BASE_BRANCH}...HEAD" # 变更文件列表和统计 git diff --stat "origin/${BASE_BRANCH}...HEAD"按类型筛选
# 新增文件 git diff "origin/${BASE_BRANCH}...HEAD" --diff-filter=A --name-only # 修改文件 git diff "origin/${BASE_BRANCH}...HEAD" --diff-filter=M --name-only # 删除文件 git diff "origin/${BASE_BRANCH}...HEAD" --diff-filter=D --name-only单文件 diff
# 查看某个文件的详细变更 git diff "origin/${BASE_BRANCH}...HEAD" -- path/to/file.py3. 两种模式对比
| 特性 | merge-base 模式 | triple-dot 模式 |
|---|---|---|
| 语法 | $MERGE_BASE pr_{n} | origin/${BASE_BRANCH}...HEAD |
| 前提条件 | 需先计算 merge-base | 需已检出 PR 分支 + 确定 BASE_BRANCH |
| 精确度 | 精确到 commit 级别 | 同样精确 |
| 适用场景 | 需要精确变更范围(review、描述生成) | 本地已有 PR 分支(文档生成、PR 创建) |
【免费下载链接】cannbot-skillsCANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。项目地址: https://gitcode.com/cann/cannbot-skills
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考
