GitHub:如何创建从分叉存储库到上游存储库的拉取请求,仅包括一些过去的提交
GitHub: How to create pull request from forked repository to upstream repo only including some past commits
我在 GitHub 上分叉了一个模板存储库 (T),并利用该模板在我自己的存储库 (X) 中做了一些工作。
由于我推送到 X 的自定义工作,现在回购 X 与回购 T 完全冲突。
除了使用模板进行自定义工作外,我还对模板进行了一些改进。
我创建了一个拉取请求,但它包含了自分叉以来我过去的所有提交。我只想在拉取请求中包括模板改进(我的提交历史中只有几个提交)。我怎样才能做到这一点?
您必须将模板更改(改进提交,您想要 merge to the upstream repo with a pull-request)与您的自定义提交分开。
更好的方法是使用两个不同的 git 存储库,但如果您更愿意只维护一个,则必须:
- 备份你的历史,创建一个新的临时分支
git checkout -b tempmaster
git checkout master # return to the previous one if master
- 如果之前没有,请将原始模板存储库 (T) 添加为上游远程:
git 远程添加上游 <a href="https://github.com/" rel="nofollow">https://github.com/</a>...
- 获取所有远程更改
git fetch --all
- 将当前分支硬重置为上游存储库
git reset --hard upstream/master # if master
- 从临时分支导入您的改进提交 (
git cherry-pick
) 并修复冲突。
- 完成后,推送新的 "rebased" 分支并创建拉取请求
- 现在您可以从此分支创建自己的自定义分支
git checkout -b myapp
并以相同的方式导入您的自定义提交。
修复后,当你想用上游更改更新你的分叉分支(master)时,使用 rebase:
git rebase upstream/master
我在 GitHub 上分叉了一个模板存储库 (T),并利用该模板在我自己的存储库 (X) 中做了一些工作。
由于我推送到 X 的自定义工作,现在回购 X 与回购 T 完全冲突。
除了使用模板进行自定义工作外,我还对模板进行了一些改进。
我创建了一个拉取请求,但它包含了自分叉以来我过去的所有提交。我只想在拉取请求中包括模板改进(我的提交历史中只有几个提交)。我怎样才能做到这一点?
您必须将模板更改(改进提交,您想要 merge to the upstream repo with a pull-request)与您的自定义提交分开。
更好的方法是使用两个不同的 git 存储库,但如果您更愿意只维护一个,则必须:
- 备份你的历史,创建一个新的临时分支
git checkout -b tempmaster git checkout master # return to the previous one if master
- 如果之前没有,请将原始模板存储库 (T) 添加为上游远程:
git 远程添加上游 <a href="https://github.com/" rel="nofollow">https://github.com/</a>...
- 获取所有远程更改
git fetch --all
- 将当前分支硬重置为上游存储库
git reset --hard upstream/master # if master
- 从临时分支导入您的改进提交 (
git cherry-pick
) 并修复冲突。 - 完成后,推送新的 "rebased" 分支并创建拉取请求
- 现在您可以从此分支创建自己的自定义分支
git checkout -b myapp
并以相同的方式导入您的自定义提交。
修复后,当你想用上游更改更新你的分叉分支(master)时,使用 rebase:
git rebase upstream/master