<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Jul 27, 2016 at 10:21 AM, Justin Lebar via llvm-dev <span dir="ltr"><<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">Thanks for your thoughts, Chris.<br>
<span class="gmail-"><br>
> As supporting evidence of this, I was discussing this thread yesterday around the office yesterday and had quite a few people responding something along the lines of “they’re proposing what?”.<br>
<br>
</span>I hope they'll join us in this thread.<br>
<br>
Ultimately a survey is going to be strongly biased in favor of "don't<br>
change anything".  There is a strong psychological bias to weight<br>
losses more than gains, so if one doesn't engage with the issue, it's<br>
only natural to conclude "keep it as similar as possible to what it is<br>
today -- that is safe."  But that line of thinking does not<br>
necessarily lead us to the best outcome.<br>
<br>
We've heard in thread from a lot of developers about how a monorepo<br>
would improve their workflow.</blockquote><div><br></div><div>I'd just like to point out that having LLVM upstream use a monorepo would probably not hugely help my workflow (or it might hinder it for some period of time, as I adapt).</div><div>This is even though earlier in this thread I was saying that a monorepo is actually a big improvements for certain things.</div><div>My main use of a monorepo is for internal development, where we merge private patches daily and a unified history to bisect is important.</div><div><br></div><div>The current situation is that llvm-project is available, and if you need its benefits, you can use it. That does not necessarily mean that those benefits are needed / are an improvement for everyday development.</div><div>The same goes for vendors' private workflow repositories. They can base them off of llvm-project. What upstream does is pretty much irrelevant. Our official toolchain repository for PS4 does not use llvm-project, but instead a subtree merged monorepo with the upstream git repos in its history, so there is a layer of indirection here anyway.</div><div><br></div><div>Also, moving to git as the repository of record is also something that, even as someone who uses exclusively git, I am not necessarily in favor of. In my personal experience (and I'm sure others disagree!), it seems like the current thing is working well enough. So, broadly speaking, if it came to a vote for "should LLVM move to git as the repository of record" I would probably vote no.</div><div><br></div><div>For example, my personal preference, all things said and done, is that if we move to git, we just continue the history of the existing git mirrors (e.g. <a href="http://llvm.org/git/llvm.git">http://llvm.org/git/llvm.git</a>, <a href="http://llvm.org/git/clang.git">http://llvm.org/git/clang.git</a>, etc.) and set up some sort of automation that adds a thing in the same format as git-svn does with a monotonically increasing "fake" SVN number. Each developer with commit access would be able to push to a particular special branch on the server, and then automation cherry picks the commit into the repo adding the "fake git-svn" info. The server-side automation is the only thing that can commit to the official `master` branch of each git repo.</div><div>The result is that:</div><div>- people have to habituate themselves to `git push master:myusername/master` instead of `git svn dcommit`</div><div>- nothing else changes<br></div><div><br></div><div><br></div><div>Making a community-wide change to workflow is no small task. Nor should we expect that, even with our best intentions and best efforts, that any proposed change will actually end up being an overall improvement for the community.</div><div>I think Phabricator is a good example where the community has largely changed workflow: compatibility with the existing workflow is paramount to gaining traction without making a *very* expensive change. Even then, we have not "made the leap" to obsolete the existing workflow -- there is no need.</div><div>Another example is svn -> git-svn. At some point in the past, everybody was using SVN. That number has dwindled enough that now we can consider making git the repository of record.</div><div><br></div><div>My personal preference would be for somebody to stand up, implement an alternative that is compatible with the existing thing (e.g. people can use it and it will commit into the current SVN on their behalf, or whatever). If it turns out to be better, then people will gradually move to it and eventually the fact that it commits to SVN will just be of historical interest.</div><div><br></div><div>My suspicion is that if somebody sets up a monorepo with perfect bidirectional integration with the existing workflow and add it as an option to the getting started page (as with the git-svn workflow), people will generally not move to it. The discussion of whether a monorepo (or any of the other changes discussed in this thread) is worth it is essentially equivalent to whether people would move of their own accord to the alternative if it had perfect bidirectional integration with the current state of things. Do we really think we can answer determine this with a discussion or survey?</div><div><br></div><div>(I consider new contributors coming into the project and just going with the new stuff as a form of "moving" to the alternative)</div><div><br></div><div>That is, I really think that the onus should be on the people proposing the change to make it work in practice. Discussion of alternatives should be done with the aim of exploring the design space so that somebody can step up and implement things, rather than trying to make a final decision or come to a proposal to be voted on.</div><div>One key factor that can doom *any* proposal is that it is unimplementable, nobody steps up to implement it, or is poorly implemented. In that sense, a proposal in the absence of an implementation is only a partial indication of what we'll actually get.</div><div><br></div><div>-- Sean Silva</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">  I would love to hear from some<br>
developers who are actually affected in the way you describe, rather<br>
than just considering the hypothetical.<br>
<br>
My expectation is that the effect of the monorepo on said developers<br>
would be relatively small -- we're talking about 1gb of disk space.  I<br>
understand that there's a "yuck" factor to this, but inasmuch as there<br>
aren't other concrete effects, this is just change aversion.  And<br>
essentially all of the other effects of the monorepo can be hidden via<br>
sparse checkouts, as we've discussed.<br>
<br>
Maybe I am wrong.  But I don't think we're going to get to the bottom<br>
of it without actually engaging with people who are actually affected<br>
in the way you posit.<br>
<span class="gmail-"><br>
> While admittedly you do get a linear history with using the mono-repository, that isn’t the only way to solve the problem, and I don’t really think that the benefit (not needing to write some tooling) justifies the increased burden applied to contributors that don’t use the full LLVM family of projects.<br>
<br>
</span>I think the trade-off you're considering here (cost to developers who<br>
use llvm plus a version-locked subrepo vs. cost to developers who<br>
don't want an llvm clone) is the right one.  But as someone who has<br>
extensively used git submodules and repo (a wrapper script), I<br>
strongly disagree with the judgement that a monorepo would not be a<br>
significant improvement.<br>
<br>
Our primary disagreement, I think, is over how much cost there is to<br>
"writing some tooling".  To me, this is a significant barrier standing<br>
in the way of developer productivity.  Here at Google I did a quick<br>
survey, and more than half of us don't have scripts of the sort that<br>
Justin Bogner described.  We are all just floundering around rebasing<br>
clang and llvm until it compiles.  It *sucks*.<br>
<br>
I suggest that saying that all of these developers are "doing it<br>
wrong" is not helpful.  Not everyone has the git and python/bash chops<br>
to write the necessary scripts.  Not everyone has the personality to<br>
obsessively script around stuff, or the desire to maintain said<br>
scripts.  Not everyone works on llvm/clang so much that it's worth<br>
adopting a special-snowflake workflow.  And some of us -- myself<br>
included -- have extensive git scripts which work with the standard<br>
git workflow but would be completely broken by adding a custom level<br>
of indirection around git.<br>
<br>
When put this way, maybe it's clear that it's actually a niche set of<br>
people for whom "script around the brokenness" is a good solution.<br>
<br>
As I've said a bunch of times above, we have to weigh a cost paid by<br>
all of us every time we type a command that starts with "git" --<br>
something we do tens or hundreds of times a day -- versus the one-time<br>
cost of asking people to download 1gb of data.<br>
<div class="gmail-HOEnZb"><div class="gmail-h5"><br>
On Wed, Jul 27, 2016 at 9:47 AM, Chris Bieneman via llvm-dev<br>
<<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br>
> I’m just now catching up on this massive thread after being on vacation last<br>
> week, and I have a few thoughts I’d like to share.<br>
><br>
> First and foremost please don’t consider lack of dissent on the thread as<br>
> presence of consensus. The various git-related threads on LLVM-dev lately<br>
> have been so active and contentious that I think a lot of people are zoning<br>
> out on the conversations. As supporting evidence of this, I was discussing<br>
> this thread yesterday around the office yesterday and had quite a few people<br>
> responding something along the lines of “they’re proposing what?”.<br>
><br>
> I think it would be great for us to have several different proposals for how<br>
> the git-transition could work, and have a survey to get people’s opinions. I<br>
> know this has been discussed repeatedly, and I want to put in my vote in<br>
> favor of having a survey that takes into account multiple different<br>
> approaches.<br>
><br>
> WRT the actual proposal in this thread, I’m strongly opposed to a<br>
> mono-repository. While I understand the argument that the full clone’s cost<br>
> on disk space is minimal compared to an LLVM object directory, what about<br>
> for contributors that contribute to the smaller runtimes projects but *not*<br>
> to LLVM or Clang. A contributor that only contributes to libcxx or<br>
> compiler-rt being forced to do a full clone of all the LLVM projects in<br>
> order to push a patch kinda sucks.<br>
><br>
> I want to point out a few workflows people may not be considering.<br>
><br>
> Clang can be built against an installed LLVM. I know this workflow is used<br>
> by some people because I’ve broken it in the past and had to fix it. With a<br>
> mono-repo this workflow gets a bit more complicated because you’d need to do<br>
> sparse checkouts, and it probably means we should just nuke the workflow<br>
> entirely because there is no real value added by having it.<br>
><br>
> Compiler-RT’s sanitizers are used with GCC; no LLVM required. While for the<br>
> common use case maintaining sparse repository mirrors would limit impact of<br>
> this on users, should any GCC user want to contribute to Compiler-RT, you’re<br>
> forcing them to clone a much larger repository than necessary.<br>
><br>
> The same problem with Compiler-RT’s sanitizers also applies to libcxx,<br>
> libcxxabi, libunwind, and potentially any other runtime library projects<br>
> that we may create in the future.<br>
><br>
> Beyond all that I want to point out that the git multi-repository story is<br>
> basically the same thing we have today with SVN except for the absence of a<br>
> monotonically increasing number that corresponds across repositories. While<br>
> admittedly you do get a linear history with using the mono-repository, that<br>
> isn’t the only way to solve the problem, and I don’t really think that the<br>
> benefit (not needing to write some tooling) justifies the increased burden<br>
> applied to contributors that don’t use the full LLVM family of projects.<br>
><br>
> I think we have some pretty strong evidence in the form of the github fork<br>
> counts (<a href="https://github.com/llvm-mirror/" rel="noreferrer" target="_blank">https://github.com/llvm-mirror/</a>) that most people aren’t using all<br>
> of the LLVM projects. In fact, by that evidence Clang (the second most<br>
> popular project) is forked less than 2/3 as many times as LLVM.<br>
><br>
> -Chris<br>
><br>
><br>
> On Jul 26, 2016, at 11:31 AM, Renato Golin via llvm-dev<br>
> <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br>
><br>
> On 26 July 2016 at 19:28, Sanjoy Das via llvm-dev<br>
> <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br>
><br>
> Even if it were possible, I would still keep my upstream checkout<br>
> separate just as a safety measure, to keep from sending private stuff<br>
> upstream by accident.<br>
><br>
><br>
> Just FYI, this is our (Azul's) workflow as well, and for similar<br>
> reasons.<br>
><br>
><br>
> Same here.<br>
><br>
> cheers,<br>
> --renato<br>
> _______________________________________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a><br>
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
><br>
><br>
><br>
> _______________________________________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a><br>
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
><br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</div></div></blockquote></div><br></div></div>