部分参考我本人
写过的blog---Github提交PR与修改pr
- 一般情况下,第一次提pr都是先提一个issue来描述你的问题或者提议,以确保你的工作符合要求。但这不是必须的,完全可以直接fork仓库并提交pr。提issue很简单,操作如下:
- fork仓库后,在自己fork的仓库里面进行修改,然后点击自己fork仓库上面的pull request,将你的更改合并到原始仓库中,详情见下:
在fork里面进行修改操作操作:此时你fork完repo,并且在你本地已经将想PR的文件进行了更改后:
写好文件夹名,然后按'/'这个键,自动就生成了一个文件夹,然后在里面创建一个readme即可,(后面也能删了)
在文件夹里面上传本地写好的东西直接点这个upload
即可
想删除里面的某个文件夹或者里面的某个文件直接点这三个点,然后相应delete即可:
'your/folk_repo_utl'
查看方法:
git clone 'your/folk_repo_utl' # 克隆到本地
cd /path/to/your/local/folder # 进入你的本地文件夹
- 此处你可以在fork好的本地仓库进行增删减改操作
- 增删减改之后:
git init # 初始化为 Git 仓库
git add . # 添加文件夹中的所有文件到暂存区
git commit -m "Added new folder" # 替换为你的提交信息
git remote add origin 'your/folk_repo_utl' # 将本地仓库关联到已有的远程仓库
git push -u origin master # 推送到远程仓库的 master 分支
此时已经将本地修改好的仓库更新推送到fork仓库中。
- 从自己的fork仓库里面提pr
提pr的话,从自己fork里面,选择上面的new pull requests
开始提,注意看好base和head对应的仓库名,base是接受的原库,head是自己更改好的fork,然后提交即可
如果之前的repo已经有更新,但是你fork的时候没有拉取最新的更新:
git remote add upstream https://github.com/original-owner/original-repository.git
# 将原作者的仓库添加为远程仓库
git fetch upstream # 将原仓库拉取更新
git checkout master # 切换到master分支
git merge upstream/master # 合并原作者的仓库的更新
git push origin master # 将合并后的代码推送到自己的仓库
有时候在push
的时候连接犯病,我们可以用ssh
git remote add origin [email protected]:username/repo.git
然后再push
就可以了。
如果已经在fork的仓库中更新了文件,想要想原始仓库提交pr:
1.打开fork仓库,在页面顶部找到Pull requests标签,点击。
2.在右上角点击New pull request按钮。
3.在Comparing changes页面,会看到两个下拉菜单,左侧显示的是你fork仓库,右边是原始仓库,确保选择了正确的仓库,并选择要提交的分支(通常是master).
4.点击Create pull request按钮,并填写一个简短的标题和描述,描述修改。
5.确认无误后,点击Create pull request提交PR