假设我的工作目录中有未提交的更改。我如何从这些补丁,而不必创建一个提交?
当前回答
我喜欢:
git format-patch HEAD~<N>
其中<N>是最后一次提交保存为补丁的数量。
该命令的具体使用方法在DOC中
乌利希期刊指南 在这里你可以找到如何应用它们。
UPD对于那些没有理解format-patch的人 添加别名:
git config --global alias.make-patch '!bash -c "cd ${GIT_PREFIX};git add .;git commit -m ''uncommited''; git format-patch HEAD~1; git reset HEAD~1"'
然后在项目存储库的任意目录下运行:
git make-patch
该命令将创建0001- uncommitted。在当前目录打补丁。Patch将包含下一个命令可见的所有更改和未跟踪的文件:
git status .
其他回答
Git差异为非阶段的变化。
Git diff——用于阶段性更改的缓存。
对于阶段性和非阶段性的更改,git diff HEAD。
uncomminetted
git diff --cached > name.patch
已提交(更有用)
git diff HEAD~commit_count > name.patch
Git diff和Git apply适用于文本文件,但不适用于二进制文件。
您可以轻松地创建一个完整的二进制补丁,但必须创建一个临时提交。一旦你做了临时提交,你可以创建补丁:
git format-patch <options...>
在你做了补丁之后,运行这个命令:
git reset --mixed <SHA of commit *before* your working-changes commit(s)>
这将回滚你的临时提交。最终的结果(有意地)使您的工作副本与您原来的更改相同。
在接收端,可以使用相同的技巧将更改应用到工作副本,而不需要提交历史记录。简单地应用补丁,git重置-混合<SHA的提交*之前*补丁>。
请注意,要使整个选项正常工作,您可能必须保持良好的同步。我曾经在应用补丁时看到过一些错误,因为做补丁的人没有像我那样做出那么多的更改。可能有办法让它工作,但我还没有深入研究。
下面是如何在Tortoise Git中创建相同的补丁(我不建议使用该工具):
提交您的工作更改 右键单击分支根目录,然后单击Tortoise Git -> Create Patch Serial 选择任何有意义的范围(因为:FETCH_HEAD将工作,如果你是良好同步) 创建补丁 右键单击分支根目录,然后单击Tortise Git -> Show Log 右键单击临时提交之前的提交,然后单击重置“<分支>”到此… 选择混合选项
以及如何应用它们:
右键单击分支根目录,然后单击Tortoise Git -> Apply Patch Serial 选择正确的补丁并应用它们 右键单击分支根目录,然后单击Tortise Git -> Show Log 在补丁提交之前右键单击提交,然后单击reset“<branch>”to this… 选择混合选项
我们还可以指定文件,只包括有相对变化的文件,特别是当它们跨越多个目录e.x时。
git diff ~/path1/file1.ext ~/path2/file2.ext...fileN.ext > ~/whatever_path/whatever_name.patch
我发现在答案或评论中没有说明这一点,这些都是相关的和正确的,所以选择添加它。明确的比含蓄的好!
我喜欢:
git format-patch HEAD~<N>
其中<N>是最后一次提交保存为补丁的数量。
该命令的具体使用方法在DOC中
乌利希期刊指南 在这里你可以找到如何应用它们。
UPD对于那些没有理解format-patch的人 添加别名:
git config --global alias.make-patch '!bash -c "cd ${GIT_PREFIX};git add .;git commit -m ''uncommited''; git format-patch HEAD~1; git reset HEAD~1"'
然后在项目存储库的任意目录下运行:
git make-patch
该命令将创建0001- uncommitted。在当前目录打补丁。Patch将包含下一个命令可见的所有更改和未跟踪的文件:
git status .
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别