开源社区必会
1 fork仓库并提交之后给开源社区提交pr
1.1 fork开源仓库
①登录github,找到开源仓库A,然后点击fork
这样,就会在你自己github账号下创建一个同名的仓库B(仓库名可修改)
②然后本地修改,提交到自己的github账号下的那个B仓库
1.2 将本地多个commit合并为1个
一般来说,开源社区提交pr都是需要合并为一个commit的
- 比如,我现在有4个commit:
85d5d8fa468b06bb9a62fafde01d80cbb7396682 # 我改的
621ca4121f971d9604e395556763551427d799d9 # 我改的
f744d2e91916ab7831f3a7695d1d1825916db164 # 我改的
5c135e49e683563fa470d7f5c281050ec1d73af9 # 我改的
295ac3b842b4ecb6eff1c9954a281a4606a8bc84 # 别人改的
- 我现在想把我提交的commit合并为1个
8403afe13664d6bb7f5a5557716a030e9389a944 # 我改的
295ac3b842b4ecb6eff1c9954a281a4606a8bc84 # 别人改的
- 具体操作方法
1.2.1 方法一:合并commitID
先从版本库回退内容到暂存区,再重新提交工作区的内容
- 思路:使用 git reset --soft 回退版本库和暂存区的版本,同时保留工作区的变动,之后再重新提交工作区的内容就好了。
# 查看前10个commit【找到别人最后一次提交的位置】
git log -10
# 从版本库恢复文件到暂存区,不改动工作区的内容
git reset --soft 295ac3b842b4ecb6eff1c9954a281a4606a8bc84 # 别人改的commitID
# add已经跟踪的文件
git add -u
# 提交
git commit -m "修改信息"
# 强制push以替换远程仓的commitID
git push --force
如果push失败,出现Reject,则需要开启分支强制合入的选项,取消分支保护。
- Settings -> Repository -> Protected Branches -> Protected branch (找到分支) -> Unprotect
1.2.2 方法二:git rebase
# 查看前10个commit
git log -10
# 将4个commit压缩成一个commit
git rebase -i HEAD~4
# add已经跟踪的文件
git add -u
# 提交
git commit -m "修改信息"
# 强制push以替换远程仓的commitID
git push --force
注意:
git rebase
会临时
创建一个新分支
进行,如果弄着出错了,可以 git checkout 原分支名 切换回原分支之后重新 git rebase。
git rebase具体演示:
我想合并前四个 commit 到最后一个。如下所示:
①git log 查看历史提交信息
②git rebase -i HEAD~n
使用 git rebase -i HEAD~5 压缩5个commit为1个,或者git rebase -i 51efaef517abdbf674478de6073c12239d78a56a (第一个commit的id)
vim编辑器,按i编辑,将后4个commit的pick修改为fixup,保留第一个pick。按esc键,输入:wq保存退出。
-
pick:使用commit。
-
reword:使用commit,修改commit信息。
-
squash:使用commit,将commit信息合入上一个commit。
-
fixup:使用commit,丢弃commit信息。
操作完之后,发现commit都合并成了一个。
③git push --force 提交
1.3 提交pr
A:代表开源社区的仓库,B:代表你自己fork下来的仓库
- 在自己fork下来的B仓库中,创建一个pull request:
- 填写pr信息
- 填写注释信息
参考:
https://blog.csdn.net/Spade_/article/details/108698036
https://blog.csdn.net/u012435142/article/details/89491388