How do I manage conflicts with git submodules?

前端 未结 8 964
死守一世寂寞
死守一世寂寞 2020-11-30 20:29

I have a git superproject that references several submodules and I am trying to lock down a workflow for the rest of the my project members to work within.

For this

相关标签:
8条回答
  • 2020-11-30 20:29

    If you want to use the upstream version:

    rm -rf <submodule dir>
    git submodule init
    git submodule update
    
    0 讨论(0)
  • 2020-11-30 20:32

    Got help from this discussion. In my case the

    git reset HEAD subby
    git commit
    

    worked for me :)

    0 讨论(0)
  • 2020-11-30 20:35

    Well, its not technically managing conflicts with submodules (ie: keep this but not that), but I found a way to continue working...and all I had to do was pay attention to my git status output and reset the submodules:

    git reset HEAD subby
    git commit
    

    That would reset the submodule to the pre-pull commit. Which in this case is exactly what I wanted. And in other cases where I need the changes applied to the submodule, I'll handle those with the standard submodule workflows (checkout master, pull down the desired tag, etc).

    0 讨论(0)
  • 2020-11-30 20:38

    I had this problem with git rebase -i origin/master to a branch. I wanted to take master's version of the submodule ref, so I simply did:

    git reset master path/to/submodule

    and then

    git rebase --continue

    That solved the problem for me.

    0 讨论(0)
  • 2020-11-30 20:44

    I struggled a bit with the answers on this question and didn't have much luck with the answers in a similar SO post either. So this is what worked for me - bearing in mind that in my case, the submodule was maintained by a different team, so the conflict came from different submodule versions in master and my local branch of the project I was working on:

    1. Run git status - make a note of the submodule folder with conflicts
    2. Reset the submodule to the version that was last committed in the current branch:

      git reset HEAD path/to/submodule

    3. At this point, you have a conflict-free version of your submodule which you can now update to the latest version in the submodule's repository:

      cd path/to/submodule
      git submodule foreach git pull origin SUBMODULE-BRANCH-NAME
    4. And now you can commit that and get back to work.

    0 讨论(0)
  • 2020-11-30 20:47

    I have not seen that exact error before. But I have a guess about the trouble you are encountering. It looks like because the master and one.one branches of supery contain different refs for the subby submodule, when you merge changes from master git does not know which ref - v1.0 or v1.1 - should be kept and tracked by the one.one branch of supery.

    If that is the case, then you need to select the ref that you want and commit that change to resolve the conflict. Which is exactly what you are doing with the reset command.

    This is a tricky aspect of tracking different versions of a submodule in different branches of your project. But the submodule ref is just like any other component of your project. If the two different branches continue to track the same respective submodule refs after successive merges, then git should be able to work out the pattern without raising merge conflicts in future merges. On the other hand you if switch submodule refs frequently you may have to put up with a lot of conflict resolving.

    0 讨论(0)
提交回复
热议问题