Ray*_*ond 5 git github pull-request git-fork
我在 GitHub 上创建了一个模板存储库 (T),并使用该模板在我自己的存储库 (X) 中做了一些工作。
由于我推送到 X 的自定义工作,现在 repo X 与 repo T 完全冲突。
除了对模板进行自定义工作之外,我还对模板进行了一些改进。
我创建了一个拉取请求,但它包含自分叉以来我过去的所有提交。我只想在拉取请求中包含模板改进(在我的提交历史记录中间只包含一些提交)。我怎样才能做到这一点?
您必须将模板更改(改进提交,您想要通过pull-request 合并到上游存储库)与自定义提交分开。
更好的方法是使用两个不同的 git 存储库,但如果您只想维护一个,则必须:
git checkout -b tempmaster
git checkout master # return to the previous one if master
git remote add upstream https://github.com/...
git fetch --all
git reset --hard upstream/master # if master
git cherry-pick从临时分支导入您的改进提交 ( ) 并修复冲突。git checkout -b myapp并以相同的方式导入您的自定义提交。修复后,当您想要使用上游更改更新分叉分支(主分支)时,请使用 rebase:
git rebase upstream/master