-
Notifications
You must be signed in to change notification settings - Fork 127
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Generate Rebase-with-history Result based on Full Result #129
Comments
Thanks for your response Michael. Let me give a concrete example here using a similar diagram you used to demonstrate how imerge works (tried to capture the screen as well in case the indent/space doesn't work). Let's say currently our master has commit 0, 1, 2. And community has v1.0 containing commit A, B. After a full merge the diagram is like:
Then I have a branch merge-master-full persisting the above state. And I'll persist the rebase-with-history result to merge-master so merge-master is like:
Later on there is commit C in community branch v2.0, and we want to do imerge again on merge-master-full instead of merge-master since I can apply C gradually on B1 and B2, instead of directly on B2 so the result is:
Now I want to do a simplification using "rebase-with-history" to get a new merge-master. However imerge only knows that C1-C2 is in progress so it won't collapse A1/B1 and the end result will be:
And my desired result is:
So my question is really how to get this last stage from the "full" merge result which is generated through 2 imerge merge operations. I'll copy this to the issue post on github so that you can answer from there. 2018-05-30 12:28 GMT-07:00 Michael Haggerty mhagger@alum.mit.edu:
|
In this case, where there is only one commit But I suppose that often there will be commits The code equivalent in I wouldn't recommend starting from the |
Thanks a lot, Michael! I actually extended reparent command to accept an additional parameter (--commit-to-reparent) which can specify a commit other than HEAD for reparent. And the consequence will be reparenting all the way back from this target commit to HEAD. I'd like to send a pull request so that this new parameter can be supported from imerge - look forward to your input. |
Nice. Please @-mention me on the PR so that I don't overlook it. |
I've created this pull request: #130 |
I was thinking a little bit more about your style of using
(which has all of the information that you will need for subsequent merges) and the rebase-with-history:
(which, if I understand correctly, is the version that you work off of day-to-day). What if, instead, you could simplify to this:
Later on, if there are new commits
Would that have all of the properties that you are looking for? If you really need the rebase-with-history connections, you could alternatively simplify to
or even
, where you have a kind of "rebase-with-history" in both directions, but don't retain the internal commits (e.g., the parents of |
You're right - I only need this in fact:
I guess this also means we can use bisect for A2 and C2 so that imerge can run faster? How can we introduce this new merge/simplify mode so that bisect can be used for the inner commits? I guess it's still not that simple since without A1 generating B1 might also be difficult? We still need the merge result from A to A2 since rebase-with-history is a better simplify result which allows us to incrementally update the master in case there is any regression observed. |
Thinking about this again - is this actually achievable by calling imerge in both directions using rebase-with-history as the goal? Meaning that we imerge from community to master using rebase-with history which gives us this:
Then we do another imerge from master to community which gives:
Now if somehow we can reparent B2 to B1/A2 then we have the desired merge result. The problem with this approach is that we might need to resolve conflicts twice? |
Hi Michael,
First of all imerge is an extremely useful tool! Thanks for inventing it. In our case we develop on a project in parallel with its development in the open source community and we have to periodically merge our repo with the community repo.
To achieve this in a simple way we use imerge to do a full merge and persist that. Whenever there is new change from the community we do another imerge and persist the full result as well. This all works. Well the problem is that we don't want the full merge result to be in our master branch since the history is complex, which is useful just for the merge. We can call "simplify" command twice here - once with "rebase-with-history" and another with "full" but the second imerge is based on "full" so simplifying the second imerge won't change the history of the first imerge which is full.
Do you have any suggestion on how to solve this? I guess we'll have to use "git commit-tree" to modify the history, which is actually how "simplify" command generates the "rebase-with-history" result. But can't figure out how to do it manually.
Really appreciate your help in advance!
The text was updated successfully, but these errors were encountered: