Re: Help understanding "rebase"

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

 



Brandon Casey venit, vidit, dixit 10.03.2009 22:30:
> John M. Dlugosz wrote:
>> Here is the situation:  An old topic branch containing 3 commits.  A dev
>> branch that has recently been merged.  To catch up the topic's work
>> before adding it to dev, I expected that rebase would do what I ended up
>> doing manually, detailed below.
>>
>> Instead, it crunched away for a long time and gave errors applying patches.
>>
>> So I did it manually by checking out dev, then cherry-picking each of
>> the three commits. Actually, this left it on top of dev, but suppose I
>> had created a new branch at dev, cherry-picked the stuff from the old
>> topic branch, and then deleted the old topic branch.  Now I have a new
>> topic branch with the rebased changes, albeit with a different branch
>> name.  Point is, there were no conflicts and the changes were simple, so
>> cherry-picking each node was clean.
>>
>> So, what did the rebase command try to do?  I think it may have
>> something to do with finding a common root between the topic and dev,
>> which, due to the merge, was a long way back.  Something like this:
>>
>>       o--o--   ...  --o
>>      /                 \
>>     A--...--B--   ... --C--D <== dev
>>              \
>>                   q--r--s  <== topic
>>
>>
>> I was able to cherry-pick q,r,s on top of D without any issues.  So why
>> did rebase get in such a tizzy?
> It may help those who know the internals of git-rebase if you supplied the
> commands you used and your git version.
> 
> So, you're saying you did
> 
>    git checkout topic
>    git rebase dev
> 
> or the equivalent
> 
>    git rebase dev topic
> 
> ?  Are you sure you didn't get the arguments to rebase reversed?
> 
> -brandon
> 

That happens very easily: You want to rewrite dev using rebase, so you
check out dev. You want to rebase the topic branch, so you run "git
rebase topic". Very logical, but the wrong way round... The doc is
clear, though.

A useful mnemonic is that git rebase A B is about the commits A..B (B
defaulting to the current branch), and that the new B after rebasing will be

B' = C + (A..B)

where C is the value of --onto, which defaults to A. The point of rebase
is that A + (A..B) does not equal B in general, even though A..B=^A B ;)

git rebase A does not rewrite/rebase A! I'll think about a concise first
paragraph for git-rebase.txt.

Michael
--
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