我如何将最后的N承诺集成到一个承诺中?
当前回答
如果您使用 TortoiseGit,您可以将函数结合到一个承诺:
打开 TortoiseGit 背景菜单 选择显示日志 标记日志视图中的相关任务 从背景菜单中选择组合到一个任务
此分類上一篇
此功能自动执行所有必要的单 git 步骤 不幸的是,仅适用于 Windows。
其他回答
我认为最简单的方式来做到这一点是通过创建一个基于大师的新分支,并进行功能分支的合并。
git checkout master
git checkout -b feature_branch_squashed
git merge --squash feature_branch
然后,你有所有的变化准备好进行。
如果你想写下新的承诺消息从滑板,这就足够了:
git reset --soft HEAD~3 &&
git commit
如果你想开始编辑新的承诺消息与现有承诺消息的折叠(即类似于什么一个 pick/squash/squash/.../squash git rebase -i 指示列表会开始你),那么你需要提取这些消息,并将它们转移到 git commit:
git reset --soft HEAD~3 &&
git commit --edit -m"$(git log --format=%B --reverse HEAD..HEAD@{1})"
两种方法都将过去三项承诺分成一个单一的新承诺,相同的方式。 软重定义只会重新点头到最后一项承诺,你不想分解。 无论指数还是工作树都不会被软重定义所触摸,让指数在你新承诺所需的状态(即它已经有所有从你即将“扔掉”的承诺的变化)。
如果你在一个遥远的分支(所谓的功能分支)从一个黄金储备(黄金_repo_name),那么这里是技巧将你的承诺分成一个:
Checkout the golden repo git checkout golden_repo_name 创建一个新的分支从它(黄金 repo)如下 git checkout -b dev-branch Squash merge 与您的本地分支 你已经 git merge --squash 功能分支 承诺您的变化(这将是唯一的承诺在 dev-branch) git commit -m "My feature complete" 将分支推到您的本地存储库 git push 起源 d
如果您正在与 GitLab 合作,您可以按下面的 Merge 请求中的 Squash 选项,承诺消息将是 Merge 请求的标题。
此分類上一篇
我建议尽可能避免吉特重新设置 - 特别是对于吉特新闻. 除非你真的需要自动化一个过程,基于几个承诺,有一个不那么异国情调的方式。
将被排除的承诺放在一个工作分支(如果它们还没有) - 使用 gitk 为此 查看目标分支(例如“主”) git merge --squash (工作分支名称) git commit
承诺的消息将基于 squash 预受欢迎。
推荐文章
- 本地存储库中的文件与源文件之间的差异
- 将Git存储库内容移动到另一个存储库,保存历史记录
- 如何在GitHub上创建自己的存储库?
- git中HEAD、master、origin的概念是什么?
- 我能把已经分裂的大块头和少不要脸的人分开吗?
- Git:从另一个分支复制目录中的所有文件
- 如何从Git存储库中删除所选的提交日志条目,同时保留它们的更改?
- Git说远程引用不存在时,我删除远程分支
- 获取所有git提交的列表,包括“丢失”的
- 如何查看某一天的所有提交?
- “git branch”和“git checkout -b”有什么区别?
- Git:“当前不在任何分支上。”是否有一种简单的方法可以在保持更改的同时回到分支上?
- 主分支和开发分支之间的“git拉取”或“git合并”
- 当VI在屏幕上等待提交消息时,我如何停止Git提交?
- 保存更改,同时将更改保存在Git的工作目录中