Re: Anomalous conflicts during git rebase

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2007.12.28 12:33:41 -0600, adr3nald0s@xxxxxxxxx wrote:
> Daniel Barkalow <barkalow@xxxxxxxxxxxx> writes:
> 
> > On Fri, 28 Dec 2007, adr3nald0s@xxxxxxxxx wrote:
> >
> >> When you say it linearizes history how is this done.
> >
> > Rebase takes a list of commits that are in the current branch and 
> > aren't in the origin branch as what it's going to work on; these are 
> > ordered in some arbitrary way such that children always follow parents. It 
> > then resets to the origin branch's commit, and, in sequence, cherry-picks 
> > each of the commits in the working list.
> 
> Thanks again for the clear explanation.
> 
> > In theory, of course, it could try to resolve conflicts by looking through 
> > the rest of the list for merges which would have those conflicts and using 
> > what that merge did.  
> 
> Given the implementation, this would be just plain ugly.  I would not
> want to attempt to implement something like this, nor would I expect
> anyone else to do so.

I wouldn't make sense either. The conflict resolution that was done in
the merge commit might need stuff from commits that haven't been rebased
yet. For example a new function that was introduced later, it was
available for the merge, but is still missing from the rebased linear
history.

That said, what _might_ make sense is to teach interactive rebase with
-p to use "cherry-pick -m1" or whatever instead of "merge" to recreate
the merge commits (or maybe it does that already now? didn't check...).
That way, it wouldn't have to rely on rerere being enabled to avoid the
repeated resolving of the merge conflicts. I'm not sure how that would
need to interact with new changes introduces into one of the rewritten
branches.

Björn
-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux