【idea】idea 中 git 分支多个提交合并一个提交到新的分支
创始人
2025-01-15 04:35:52
0

一、方法原理讲解

我们在 dev 分支对不同的代码文件做了多次提交。现在我们想要把这些提交都合并到 test 分支。首先我们要明白四个 git 操作,

  • commit:命令用于将你的代码变更保存到本地代码仓库中,它创建了一个新的提交(commit)记录,记录了代码的变更内容以及相关的提交信息(如作者、时间、提交说明等)。
  • push:命令用于将本地仓库中的代码推送(上传)到远程代码仓库,将你的代码变更分享给其他开发者或者备份到远程服务器。
  • cherry pick:命令用于从一个分支中选择性地合并某个提交(commit)到当前分支,它允许你只合并需要的提交而不是整个分支的变更。
  • squash: 用于将多个连续的提交(commit)合并成一个提交,以便清理历史记录或整理提交信息。这个操作通常用于将多个相关的小提交合并成一个更有意义和完整性的大提交,以提高代码库的可读性和维护性。

从上面四个操作,要将A分支的多个提交合并一个提交到新的分支。我们得出两个方法,

  • 方法一:先把A分支已经提交的使用 squash 合并成一个commit,然后 push 到A远程,然后从A远程直接 cherrypick 这一个分支到B分支。
  • 方法二:先把A分支已经提交push到A远程,然后 cherrypick 到B分支本地进行 commit ,再将多个提交使用 squash 合并成一个提交 push 给B远程。

二、对多个提交合并到一个提交 squash

在这里插入图片描述

步骤2.1、选中最先提交的一个记录,右键选择 “Interactively Rebase from Here”

在这里插入图片描述会出现下面的窗口,有多个 action 方式,分别表示以下含义:

  • pick:git会应用这个补丁,以同样的提交信息(commit message)保存提交
  • reword:git会应用这个补丁,但需要重新编辑提交信息
  • edit:git会应用这个补丁,但会因为amending而终止
  • squash:git会应用这个补丁,但会与之前的提交合并
  • fixup:git会应用这个补丁,但会丢掉提交日志
  • exec:git会在shell中运行这个命令

步骤2.2、我们想要选择与之前的提交合并,因此我们选择 squash

在这里插入图片描述
第一个选择 squash 是会报错,因为不能与前面的合并。因此第一个我们还是选择 pick
在这里插入图片描述

步骤2.3、会让我们重新整理提交的备注。

在这里插入图片描述
然后我们就多了一个合并后的新的提交记录
在这里插入图片描述

三、挑选代码到新分支 cherrypick

我们演示以下把代码从 dev 分支选到 test 分支。

步骤3.1、使用 checkout 把代码切到 test

因为 cherrypick 命令是将分支提交挑选到当前分支,因此要先切换到test分支。
在这里插入图片描述

步骤3.2、idea 的 git 取消 cherrypick 自动推送远程

取消选择 file -》setting -》git -》Commit automatically on cherry-pick

在这里插入图片描述

步骤3.3、选中一个要转移的提交,右键选择 cherrypick

这里一定要注意提交记录的分支选择正确,要从 dev 挑选到 test,因此 branch 选择 dev,这里dev也分本地 local 和远程 origin。确认清楚这个提交在本地还是远程。
在这里插入图片描述

四、最后多个提交合并后 push 到远程

在这里插入图片描述
结果验证,日志中的分支选择 origin-》test,可以看到只有一条记录。
在这里插入图片描述

相关内容

热门资讯

反观!微信边锋辅助软件,心悦辅... 反观!微信边锋辅助软件,心悦辅助出售平台,黑科技教程(其实有挂)-哔哩哔哩亲,关键说明,微信边锋辅助...
有消息称!山西打锅子技巧,战皇... 有消息称!山西打锅子技巧,战皇大厅辅助那个可靠,黑科技教程(一贯存在有挂)-哔哩哔哩;1、超多福利:...
记者获悉!朋朋政和软件辅助,牛... 记者获悉!朋朋政和软件辅助,牛总管一定要牛辅助,黑科技教程(总是有挂)-哔哩哔哩;所有人都在同一条线...
现就发布提示!小逸碰胡辅助器,... 现就发布提示!小逸碰胡辅助器,顺欣茶楼辅助软件视频,技巧教程(一贯是真的挂)-哔哩哔哩1)顺欣茶楼辅...
据文件显示!财神十三张有挂辅助... 据文件显示!财神十三张有挂辅助吗,永胜联盟辅助软件,曝光教程(总是是真的挂)-哔哩哔哩财神十三张有挂...
随着!天天卡五星辅助,广东雀神... 随着!天天卡五星辅助,广东雀神挂件去哪买,技巧教程(确实真的是有挂)-哔哩哔哩1、这是跨平台的广东雀...
据报道!神殿娱乐控制系统,微信... 据报道!神殿娱乐控制系统,微信卡五星辅助,介绍教程(都是是有挂)-哔哩哔哩1、神殿娱乐控制系统系统规...
今日!天天互娱辅助器免费下载,... 今日!天天互娱辅助器免费下载,哈糖大菠萝辅助,必备教程(本来真的有挂)-哔哩哔哩1、全新机制【天天互...
做出回应!四川家园辅助器,决战... 做出回应!四川家园辅助器,决战卡五星辅助软件,实用技巧(一直真的有挂)-哔哩哔哩1、游戏颠覆性的策略...
此事引发广泛关注!微信小程序怎... 此事引发广泛关注!微信小程序怎么挂脚本,约局吧破解器,解说技巧(竟然真的有挂)-哔哩哔哩1、进入游戏...