【问题标题】:GitHub: How to create pull request from forked repository to upstream repo only including some past commitsGitHub:如何创建从分叉存储库到上游存储库的拉取请求,仅包括一些过去的提交
【发布时间】:2016-10-09 13:06:50
【问题描述】:

我在 GitHub 上创建了一个模板存储库 (T),并在我自己的存储库 (X) 中使用该模板进行了一些工作。

由于我推送到 X 的自定义工作,现在 repo X 与 repo T 完全冲突。

除了对模板进行自定义工作之外,我还对模板进行了一些改进。

我创建了一个拉取请求,但它包含了自分叉以来我过去的所有提交。我只想在拉取请求中包含模板改进(只是在我的提交历史中间的几个提交)。我怎样才能做到这一点?

【问题讨论】:

    标签: git github pull-request git-fork


    【解决方案1】:

    您必须将模板更改(改进提交,您想要merge to the upstream repo with a pull-request)与您的自定义提交分开。

    更好的方法是使用两个不同的 git 存储库,但如果您希望只维护一个,则必须:

    1. 备份您的历史记录,创建一个新的临时分支 git checkout -b tempmaster git checkout master # return to the previous one if master
    2. 如果您之前没有这样做,请将原始模板存储库 (T) 添加为上游远程: git remote add upstream @987654322@...
    3. 获取所有远程更改 git fetch --all
    4. 将当前分支硬重置到上游存储库 git reset --hard upstream/master # if master
    5. 从 temp 分支导入您的改进提交 (git cherry-pick) 并修复冲突。
    6. 完成后,推送新的“rebased”分支并创建拉取请求
    7. 现在,您可以从此分支创建自己的自定义分支git checkout -b myapp,并以相同的方式导入您的自定义提交。

    一旦修复,当您想使用上游更改更新您的分叉分支(主)时,请使用 rebase: git rebase upstream/master

    【讨论】:

    • 我最终使用了单独的存储库。我联系了 GitHub 支持以分离分叉的存储库并重命名它。然后我再次分叉以提交模板更改。谢谢。
    猜你喜欢
    • 2021-12-11
    • 2017-04-05
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-02-17
    • 2021-03-16
    • 2011-04-23
    相关资源
    最近更新 更多