其中-i的意思是--interactive,即弹出交互式的界面让用户编辑完成合并操作,[startpoint] [endpoint]则指定了一个编辑区间,如果不指定[endpoint],则该区间的终点默认是当前分支HEAD所指向的commit(注:该区间指定的是一个前开后闭的区间)。
在查看到了log日志后,我们运行以下命令:
或者
上面未被注释的部分列出的是我们本次rebase操作包含的所有提交,下面注释部分是git为我们提供的命令说明。每一个commit id 前面的pick表示指令类型,git 为我们提供了以下几个命令:
pick:保留该commit(缩写:p) reword:保留该commit,但我需要修改该commit的注释(缩写:r) edit:保留该commit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e) squash:将该commit和前一个commit合并(缩写:s) fixup:将该commit和前一个commit合并,但我不要保留该提交的注释信息(缩写:f) exec:执行shell命令(缩写:x) drop:我要丢弃该commit(缩写:d)
rebase -i命令执行
1、git rebase -i HEAD~3
2、编辑合并信息
3、修改commit信息
4、commit信息预览
5、commit合并结果
6、可以看到master上之后又1条提交记录了,而develop上还有3个提交记录
还是要通过 git push -f 命令将合并的commit结果提交的远程仓库中。
如果develop分支也想要变成master分支这种合并效果,记住不要使用git merge 命令,还时会出现分叉的情况。继续使用 git rebase master命令。
自动合并多个commit记录
命令介绍
git commit –fixup 自动在commit消息前添加fixup!关键字。
git rebase -i –autosquash 使用rebase自动合并被标记为fixup!的commit,其实是根据sha值来的。
命令操作
1.继续修复如下图所示对应的bug
2、修改完之后执行 git commit --fixup 需要合并的commit id
3、commit fixup 之后的效果
4、执行git rebase -i --autosquash 需要合并commit id的父级commit id
或者
5、执行rebaseautosquash结果
到此这篇关于Git rebase命令使用实战的文章就介绍到这了,更多相关Git rebase命令内容请搜索七叶笔记以前的文章或继续浏览下面的相关文章希望大家以后多多支持七叶笔记!