<br><br><div class="gmail_quote">On Tue, Oct 12, 2010 at 08:59, Brian Granger <span dir="ltr">&lt;<a href="mailto:ellisonbg@gmail.com">ellisonbg@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

<div class="im">&gt;&gt; I know some projects like to rebase absolutely everything to have a<br>
&gt;&gt; perfectly clean DAG. I don&#39;t feel like way and think the non-rebased<br>
&gt;&gt; merges of coffee cup handle branches is just fine.<br>
&gt;<br>
&gt; Those are valid points.  Let me try to clarify my perspective and why<br>
&gt; I suggested the rebasing.  Compare the two screenshots:<br>
&gt;<br>
&gt; - <a href="http://imgur.com/nBZI2" target="_blank">http://imgur.com/nBZI2</a>: merged branch where I rebased right before pushing<br>
&gt; - <a href="http://imgur.com/7bNOy" target="_blank">http://imgur.com/7bNOy</a>: merged branch (yellow) where I did NOT<br>
&gt; rebase before pushing.<br>
&gt;<br>
&gt; I find the former much easier to follow than the latter, because all<br>
&gt; related commits are topologically together.<br>
<br>
</div>Definitely, but I do agree with Hans that this is really a problem<br>
with the viewer, not the DAG itself.  But, I definitely agree with you<br>
that the rebased version is much cleaner.<br>
<div class="im"><br>
&gt; These branches aren&#39;t meant for third-parties to follow, since they<br>
&gt; are being proposed for merging into trunk, so I don&#39;t see the rebasing<br>
&gt; as an issue fort third-parties.  In fact, even without rebasing,<br>
&gt; following these branches is never a good idea since people are likely<br>
&gt; to regularly prune their repo from obsolete branches (I know I do, and<br>
&gt; I&#39;ve seen others do it as well).  So I think for these types of<br>
&gt; branches, the argument of possible headaches for downstream users of<br>
&gt; the branches isn&#39;t very compelling.<br>
<br>
</div>I don&#39;t think the cost of rebasing is something that users/third<br>
parties pay, but rather a cost that we, as developers pay.  Consider<br>
the following:<br>
<br>
1. I work in branch foo, rebase it on top of master and then post on<br>
github as a pull request.<br>
2. People comment on the work and I have to make additional commits to<br>
address the comments.<br>
3. If we always try to rebase, I have to create a *new* foo2 branch<br>
that has my recent commits rebased and post that to guithub.  But<br>
because it is a new branch, I have to submit a new pull request and<br>
the discussion has to continue in a manner that is disconnected from<br>
the original foo pull request.<br></blockquote><div><br></div><div>3. is not actually true.  You can rebase and push on top of the old branch, preserving the pull-request/discussion. I did this with some of my branches in pyzmq.  The commits change, so the ordering ends up different, but it certainly works.  And, if you want to preserve the old commits in their original state, you can check out &#39;mybranch&#39; and push it as &#39;mybranch-save&#39; before rebasing.</div>

<div><br></div><div>See <a href="http://github.com/zeromq/pyzmq/pull/31">http://github.com/zeromq/pyzmq/pull/31</a> for what a pull review looks like where a rebase has happened in the middle.  What&#39;s lost is the ordering relationship of commits/comments, which is certainly not ideal, but is quite manageable for small feature branches.</div>

<div><br></div><div>-MinRK</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
4. This creation of new branches has to be repeated for each<br>
comment/edit/rebase cycle.<br>
<br>
This is a significant cost for developers, and I simply don&#39;t think it<br>
is worth the effort. Not to mention that creating/deleting lots of<br>
branches is error prone.<br>
<br>
This is not to say I don&#39;t think that sometimes rebasing is a great<br>
idea.  It definitely is. But, I think we want to continue to use<br>
non-rebased merges as a part of our regular workflow. I should say<br>
that if rebasing didn&#39;t have this extra cost for developers, I would<br>
be totally fine with it being the norm in most cases.<br>
<div class="im"><br>
&gt; I also don&#39;t think the rebased verion is a much less clear reflection<br>
&gt; of the original history, as all commits in the rebased version retain<br>
&gt; their original message and timestamp, so one can easily see when<br>
&gt; things happened.<br>
<br>
</div>I agree.<br>
<div class="im"><br>
&gt; But if everyone prefers the alternative, I won&#39;t push particularly<br>
&gt; hard in this direction.  I think that in this instance, making the<br>
&gt; group happy is more important than making me happy :)  I&#39;d just like<br>
&gt; to understand what actual downsides you guys see in rebasing *in these<br>
&gt; specific circumstances* (I&#39;m not advocating rebasing trunk, for<br>
&gt; example).<br>
<br>
</div>For simple pull requests where there are no additional commits, I<br>
think rebasing is just fine.  It is mostly in the more complex<br>
review/commit/rebase cycles.<br>
<br>
Cheers,<br>
<br>
Brian<br>
<br>
&gt; Cheers,<br>
<div class="im">&gt;<br>
&gt; f<br>
&gt;<br>
<br>
<br>
<br>
--<br>
Brian E. Granger, Ph.D.<br>
Assistant Professor of Physics<br>
Cal Poly State University, San Luis Obispo<br>
<a href="mailto:bgranger@calpoly.edu">bgranger@calpoly.edu</a><br>
<a href="mailto:ellisonbg@gmail.com">ellisonbg@gmail.com</a><br>
_______________________________________________<br>
</div><div><div></div><div class="h5">IPython-dev mailing list<br>
<a href="mailto:IPython-dev@scipy.org">IPython-dev@scipy.org</a><br>
<a href="http://mail.scipy.org/mailman/listinfo/ipython-dev" target="_blank">http://mail.scipy.org/mailman/listinfo/ipython-dev</a><br>
</div></div></blockquote></div><br>