注意
拉取请求作者可以授予上游仓库维护者或拥有上游仓库推送访问权限的用户权限,以对其拉取请求的比较分支(在用户拥有的分支中)进行提交。 有关更多信息,请参阅“允许更改从分支创建的拉取请求分支”。
在本地修改活动的拉取请求
-
在您的仓库名称下,单击 拉取请求.
-
在拉取请求列表中,单击您想要修改的拉取请求。
-
要选择要在其中打开拉取请求的位置,请选择 代码下拉菜单,然后单击其中一个选项卡。
要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。
要本地检出拉取请求,请使用gh pr checkout
子命令。将PULL-REQUEST
替换为拉取请求的编号、URL 或头部分支。
gh pr checkout PULL-REQUEST
本地修改未激活的拉取请求
如果拉取请求的作者没有回应请求或已删除他们的fork,仍然可以通过新的拉取请求合并该拉取请求中提出的更改。但是,如果您想更改拉取请求并且作者没有回应,则需要执行一些额外步骤来更新拉取请求。
拉取请求一旦打开,GitHub 就会远程存储所有更改。换句话说,即使在合并拉取请求之前,存储库中也可用拉取请求中的提交。您可以获取打开的拉取请求并将其重新创建为自己的拉取请求。
任何人都可以使用以前打开的拉取请求来继续处理它、对其进行测试,甚至可以使用其他更改打开新的拉取请求。但是,只有具有推送访问权限的协作者才能合并拉取请求。
-
在您的仓库名称下,单击 问题或 拉取请求.
-
在“拉取请求”列表中,点击您要合并的拉取请求。
-
找到未激活拉取请求的 ID 号。这是拉取请求标题后紧跟的一串数字。
-
打开终端终端Git Bash。
-
根据 ID 号获取拉取请求的引用,在此过程中创建一个新的分支。
git fetch origin pull/ID/head:BRANCH_NAME
-
切换到基于此拉取请求的新分支。
[main] $ git switch BRANCH_NAME > Switched to a new branch 'BRANCH_NAME'
-
此时,您可以对该分支执行任何操作。您可以运行一些本地测试,或将其他分支合并到该分支。
-
准备好后,您可以将新分支推送到远程。
[pull-inactive-pull-request] $ git push origin BRANCH_NAME > Counting objects: 32, done. > Delta compression using up to 8 threads. > Compressing objects: 100% (26/26), done. > Writing objects: 100% (29/29), 74.94 KiB | 0 bytes/s, done. > Total 29 (delta 8), reused 0 (delta 0) > To https://github.com/USERNAME/REPOSITORY.git > * [new branch] BRANCH_NAME -> BRANCH_NAME
-
创建一个新的拉取请求,包含您的新分支。
错误:推送某些引用失败
远程refs/pull/
命名空间为只读。如果您尝试向其中推送任何提交,将会看到此错误。
! [remote rejected] HEAD -> refs/pull/1/head (deny updating a hidden ref)
error: failed to push some refs to '[email protected]:USERNAME/REPOSITORY.git'
提示
移除或重命名远程引用时,您的本地refs/pull/origin/
命名空间不会受到对git-remote
的调用的影响。