<div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Jan 16, 2020 at 1:30 PM David Greene via cfe-dev <<a href="mailto:cfe-dev@lists.llvm.org">cfe-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Joerg Sonnenberger via cfe-dev <<a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a>> writes:<br>
<br>
> One typical case for a patch series is if you need infrastructure in a<br>
> number of places in place first. Sending all changes at once allow<br>
> others to see where you are going, independent of whether the individual<br>
> pieces are acceptable immediately or not. Yes, this can mean later<br>
> patches need to be reworked for larger structural changes, but that<br>
> doesn't necessarily invalidate review remarks already made.<br>
<br>
I can certainly see the utility of this.  I've never tried it since<br>
posting patches via the web interface is not at all convenient and as<br>
I've mentioned before I can't get arcanist to work.  Does arcanist take<br>
care of organizing the series?<br>
<br>
How do reviews work?  Does each patch get a separate review page like<br>
any other patch?<br>
<br>
Let's say patch 3 in a series is approved and it could be committed<br>
without patches 1 and 2 (like Renato I question why this is a patch<br>
series if so, but let's assume it for argument's sake).  That means I<br>
need to rebase -i my branch in order to get patch 3 committed, right?<br>
<br>
Like Renato, I actually find that more burdensome than just putting<br>
patch 3 in its own branch in the first place and doing a separate review<br>
of it.  In other words, my definition of "patch series" is the same as<br>
Renato's: a linear series of commits each of which is dependent on the<br>
previous commits.  With that definition, "early approval" of later<br>
patches really doesn't help get things committed earlier.<br>
<br>
I definitely see the advantage of not invalidating existing review<br>
comments if the series is rebased/changed.  I confess I don't know how<br>
GitHub handles rebases (see my other post with questions about that).<br>
<br>
> The other case is reworking a pass to handle a couple of similar, but not<br>
> identical cases. It might not be possible to take out patch 2 in a<br>
> series in this case, but most often the review changes here are smaller<br>
> "stylistic" issues without huge impact on later steps.<br>
<br>
I'm sorry I don't really follow this.  How does it differ from the first<br>
case?  Are you saying you're grouping two similar but basically<br>
independent changes together?  I would think doing so violates the "one<br>
topic per review" principle (that's maybe not an LLVM policy per se,<br>
just the way I think to think about things).<br></blockquote><div>I'm not sure what that the line on "basically independent" is well-established, but sometimes syntactic merge conflicts on changes that are related but not semantically ordered occur. For the purposes of facilitating integration testing, allowing reviewers to reproduce a common state of the code base, etc. it can be helpful to create a patch series in Phabricator representing a local rebased linear history. Even if the submitter has a good solution for merging the changes together whenever they want to do integration testing, patches/PRs that are "pure" in terms of being based on some state of "master" is pushing work on reviewers who want to apply the patches to their own trees.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
                     -David<br>
_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@lists.llvm.org" target="_blank">cfe-dev@lists.llvm.org</a><br>
<a href="https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev" rel="noreferrer" target="_blank">https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev</a><br>
</blockquote></div></div>