Git patch的使用方法和场景

Posted Geek.Fan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Git patch的使用方法和场景相关的知识,希望对你有一定的参考价值。

        Git patch在同步不同分支的代码时应用较多,且比较灵活,方便我们对不同发行版本的版本管理和控制。比如修复了基线的一个bug,同步到各个版本的发布分支。本文介绍使用diff/apply生成和应用补丁。

        diff/apply的打patch方案:

        使用diff命令生成patch文件,后使用apply命令应用patch到分支,从而实现修改复刻。其大致流程如下:

# 生成补丁

git diff > commit.patch

# 检查补丁

git apply --check commit.patch

# 应用补丁

git apply commit.patch

git diff

        没有指定任何版本,那默认就是对lastCommit和working copy之间作比较。

        这里就会出现两种情况:如果当前的working copy已经commit过了,那么lastCommit就是目前working copy自身,所以diff不会输出任何内容;如果当前的working copy未commit,那么diff就会输出本次修改的内容。

git diff commitId

        指定了一个commitId,那就是对commitId和working copy之间作比较。同样的,如果你的working copy已经commit过了,那么这个命令会等价于git diff commitId lastCommitId。

git diff commitId1 commitId2

        指定了两个commitId(注意把时间早的commitId放在前面),这种情况就是对commitId1和commitId2之间作比较。

(1).本地修改未commit

希望把修改的内容生成patch,可以如下操作:

git diff > commit.patch

(2).对于已经add但是未commit的修改:

git diff --cached > commit.patch

(3).本地修改已commit

希望把最近一次的修改生成patch:

# 注意:commitId为倒数第二个提交ID

git diff commitId > commit.patch

apply应用patch

生成patch文件后,我们切换到希望应用patch的分支,然后按下面的步骤操作:

# 检查patch是否可以应用

git apply --check commit .patch

# 打单个补丁

git apply commit .patch

# 打多个补丁

git apply ../patch/*.patch

        打完补丁后再add/commit进行提交。

以上是关于Git patch的使用方法和场景的主要内容,如果未能解决你的问题,请参考以下文章

如何使用git 生成patch 和打入patch

如何使用git 生成patch 和打入patch 标签: gitpatch

git 生成patch和应用patch

git format-patch的使用

git applygit am打补丁.diff 和 .patch

Git的Patch功能