注意:拉取请求作者可以授予上游存储库维护者或具有上游存储库推送权限的人员在用户拥有的分支中对其拉取请求的比较分支进行提交的权限。有关更多信息,请参阅“允许对从分支创建的拉取请求分支进行更改”。
在本地修改活动拉取请求
-
在存储库名称下,单击 拉取请求.
-
在拉取请求列表中,单击要修改的拉取请求。
-
若要选择打开拉取请求的位置,请选择 代码下拉菜单,然后单击其中一个选项卡。
若要详细了解 GitHub CLI,请参阅“关于 GitHub CLI”。
若要本地签出拉取请求,请使用 gh pr checkout
子命令。将 pull-request
替换为拉取请求的编号、URL 或头部分支。
gh pr checkout PULL-REQUEST
在本地修改非活动拉取请求
如果请求的作者对请求没有反应或删除了他们的分支,仍然可以通过新的请求合并该请求中建议的更改。但是,如果你想对请求进行更改,而作者没有响应,你需要执行一些附加步骤来更新请求。
一旦请求被打开,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
的调用影响。