<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Jul 28, 2016, at 12:05 PM, Justin Lebar <<a href="mailto:jlebar@google.com" class="">jlebar@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div class=""><blockquote type="cite" class=""><blockquote type="cite" class="">The decision of whether or not to include these projects<br class="">affects only read-write consumers of these projects -- of which there<br class="">are relatively few people.<br class=""></blockquote><br class="">Maybe there are few, but the impact is non-insignificant. Also I think the opinions of the read-write consumers of the sub-projects being included should count for a lot<br class=""></blockquote><br class="">I agree.<br class=""><br class=""><blockquote type="cite" class="">as a read-write consumer I don’t like this proposal if it includes the runtime libraries.<br class=""></blockquote><br class="">Point well-taken.<br class=""><br class=""><blockquote type="cite" class="">The existence of subproject mirrors requires someone to write and maintain the tooling to keep those mirrors updated,<br class=""></blockquote><br class="">I think you will find on this thread no shortage of people willing to<br class="">maintain said mirrors in exchange for getting a monorepo as the<br class="">canonical source of truth.<br class=""></div></div></blockquote><div><br class=""></div><div>Ok. Money where my mouth is time.</div><div><br class=""></div><div>Submodule repo: </div><div><br class=""></div><div><a href="https://github.com/llvm-beanz/llvm-submodules" class="">https://github.com/llvm-beanz/llvm-submodules</a></div><div><br class=""></div><div>Bot auto-updating it:</div><div><br class=""></div><div><a href="http://beanz-bot.com:8180/jenkins/job/submodule-update/" class="">http://beanz-bot.com:8180/jenkins/job/submodule-update/</a></div><div><br class=""></div><div>If we go down this path improvements can be made to the bot so that each submodule update commit only includes one submodule update. That would be fairly simple to add.</div><br class=""><blockquote type="cite" class=""><div class=""><div class=""><br class=""><blockquote type="cite" class="">and those mirrors will have all the technical hurdles and drawbacks that a submodule repository would have.<br class=""></blockquote><br class="">I don't understand this.  The point of the mirrors is to allow people<br class="">to use a read-only multirepo workflow.  I agree that if one chose to<br class="">do so, one would bite all of the drawbacks of a multirepo workflow,<br class="">but...that's the point?  Maybe I'm missing something.<br class=""></div></div></blockquote><div><br class=""></div><div>What I’m referring to is that since we don’t have the ability to run server-side hooks on github the submodule repositories will have some complications because they can’t automatically be updated, and the infrastructure to do so would have multiple points of failure.</div><div><br class=""></div><div>This limitation in github hosting was discussed in at least one of the github related threads.</div><br class=""><blockquote type="cite" class=""><div class=""><div class=""><br class=""><blockquote type="cite" class="">The question here is: Do you make downstream single project users work off potentially unreliable mirrors, or do you make the people who need a mono-repo experience work off a potentially unreliable submodule repo?<br class=""></blockquote><br class="">I agree with the gist of this question, but I want to refine the<br class="">trade-off a bit.<br class=""><br class="">With a monorepo, downstream single-project users actually have two<br class="">options.  They can work off the mirrors, or they can just download the<br class="">whole thing.  So with the monorepo, downstream single-project users<br class="">are not forced to work off noncanonical mirrors.  They are only<br class="">"forced" to do so if they are unable or unwilling to download a 500mb<br class="">repo and throw away most of it.  Which I think may actually be<br class="">relatively few people.  But what do I know?<br class=""></div></div></blockquote><div><br class=""></div><div>I think we have evidence that many of our projects are used in isolation by relatively large numbers of users. Whether or not those users would be sufficiently inconvenienced to do something about a mono-repo is a harder thing to know.</div><div><br class=""></div><div>In the submodule approach this isn’t really an issue because users will continue to work as they always have with the per-project repositories, and the developers who need bisecting capabilities can clone the submodule repo, which can also be used as read-write for making changes to the subprojects.</div><br class=""><blockquote type="cite" class=""><div class=""><div class=""><br class="">Anyway my answer to this question has been and still is, that a<br class="">monorepo is strictly more powerful than a multirepo.</div></div></blockquote><blockquote type="cite" class=""><div class=""><div class=""><br class="">For one thing, we can atomically commit across subprojects using a<br class="">monorepo.  On IRC I've had a bunch of people just begging me for this.<br class=""><br class="">Putative scripts that allow monorepo users to commit to the multirepo<br class="">would not be able to translate cross-cutting commits into a single<br class="">commit in the umbrella repository without cooperation from the script<br class="">that translates commits to the multirepos into commits in the umbrella<br class="">repository (that's the one that contains all the multirepos as git<br class="">subrepositories).  It's possible -- it's turing complete --, but it<br class="">would be very complicated.<br class=""><br class="">Still more complicated would be writing a script that would allow<br class="">monorepo users to push to putative try bots that are based off the<br class="">multirepo.  Again anything is possible, but I have written and<br class="">maintained similar software in the past (for a significantly simpler<br class="">setup) and it was fragile as heck, and again this is going to require<br class="">extensive cooperation between us and the multirepo --> umbrella repo<br class="">script.</div></div></blockquote><div><br class=""></div><div>For cross-repository changes I am fairly certain you could construct something that can be pushed to a try bot based on the submodule repository. There is no technical reason that shouldn’t work, and I don’t even think the scripting around that would be terribly complicated. Admittedly that is more complicated than just writing a pull request to a single repository, but I suspect not much. I may look into that.</div><br class=""><blockquote type="cite" class=""><div class=""><div class=""><br class="">In contrast, as discussed earlier, if people want a multirepo-like<br class="">setup based on the monorepo, we can reduce this to a single command<br class="">run once when the repository is cloned.  It ends up being far less<br class="">fragile, and requiring far fewer (actually, zero) tricks on the server<br class="">side.<br class=""></div></div></blockquote><div><br class=""></div><div>The only thing a monorepo gets you that strictly isn’t possible without it is the ability to commit to multiple projects in a single commit. Personally I don’t think that is a big enough justification, but that is my opinion, not a fact.</div><br class=""><blockquote type="cite" class=""><div class=""><div class=""><br class=""><blockquote type="cite" class="">Instead, let’s talk about DragonEgg.<br class=""></blockquote><br class="">+1.<br class=""><br class=""><blockquote type="cite" class="">The DragonEgg project is, as far as I can tell, abandoned, but it is still an LLVM project that is tightly coupled to LLVM versions. So it meets criteria #1. I think it fails to meet criteria #2 because DragonEgg is basically abandoned and provides no real value to the community. Even though the burden of a dead project on the mono-repo is minuscule, I think there is no good reason to include DragonEgg.<br class=""></blockquote><br class="">If DragonEgg is abandoned, I think we should keep the history in our<br class="">repository and just delete it from head.<br class=""><br class="">My argument for keeping it in our history is: Suppose we go with a<br class="">monorepo, and suppose at some point in the future, some other LLVM<br class="">project -- say, lld -- became abandoned.  Would we rewrite our<br class="">monorepo history to erase all trace of lld, because it no longer<br class="">provides value to us?<br class=""><br class="">No, right?  lld's history is part of our history.  We'd just delete it<br class="">from head and move on with our lives.<br class=""><br class=""><blockquote type="cite" class="">My arguments are from the perspective of someone working on the runtime library projects, the burden is significant to be included in the llvm mono-repo. While the full history of LLVM is around 500MB, the full history of *all* the runtime projects is less than 100MB.  Developers working on libcxx or compiler-rt should not need to clone LLVM, and run commands to do sparse checkouts. That is more burden than we should incur. Further the setup cost of doing multiple sparse checkouts in order to approximate the workflows we have today with decoupled projects is, IMO, unnecessary and unreasonable.<br class=""></blockquote><br class="">OK, just to make sure I understand your point here, because this is<br class="">important, you are saying that you object to including libcxx and<br class="">compiler-rt in the llvm monorepo because:<br class=""><br class="">* It would consume an additional ~400mb of disk space, and<br class="">* It's unnecessary and unreasonable to ask libcxx etc. developers to<br class="">run a script when they check out the monorepo if they want a sparse<br class="">checkout and/or a setup that mirrors the multirepo.</div></div></blockquote><blockquote type="cite" class=""><div class=""><div class=""><br class="">I'm not trying to put words in your mouth or subtly change what you're<br class="">saying, so please let me know if I didn't get that right.<br class=""></div></div></blockquote><div><br class=""></div><div>I have a lot of arguments against the runtime libraries being included. First and foremost, they don’t meet the “tightly coupled” criteria. Also, yes, an extra 400 MB of disk space when the repository for libcxx is only ~20 MB is a big deal to me. You’re not talking about a 10% or 20% increase in repository size, you’re talking about a 20x increase in repository size. That is a burden.</div><div><br class=""></div><div>To me, needing to run a script to do sparse checkouts is also a burden. Similarly I think that running a script to bisect a submodule repository (which is my proposal) is also a burden. I can’t judge which burden is more significant because I don’t know how many people bisect. What I can say is that it is my belief that I’m not the only person who works on runtime projects in isolation. As a potential example (because I don’t want to put words into anyone’s mouth), Marshal Clow and Eric Fiselier have made *a ton* of contributions to libcxx over the last year, but neither of them are frequent contributors to LLVM or Clang.</div><div><br class=""></div><div>While it is true that Clang developers may want or need the runtime libraries, the runtime library developers frequently don’t need clang. I really don’t want a solution that makes the lives of Clang developers easier at the expense of other subprojects unless it is strictly necessary and for a common “greater good”.</div><div><br class=""></div><div>-Chris</div><br class=""><blockquote type="cite" class=""><div class=""><div class=""><br class="">Thanks again for all your time here.<br class=""><br class="">-Justin<br class=""><br class="">On Thu, Jul 28, 2016 at 11:28 AM, Chris Bieneman <<a href="mailto:beanz@apple.com" class="">beanz@apple.com</a>> wrote:<br class=""><blockquote type="cite" class=""><br class=""><blockquote type="cite" class="">On Jul 28, 2016, at 10:53 AM, Justin Lebar <<a href="mailto:jlebar@google.com" class="">jlebar@google.com</a>> wrote:<br class=""><br class="">Thanks again for your thoughts, Chris.<br class=""><br class=""><blockquote type="cite" class="">As a straw man I would suggest the following criteria for inclusion into the mono-repo:<br class=""><br class="">(1) Projects in the mono-repo must be tightly coupled to specific versions or commits of other projects in the mono-repo<br class=""></blockquote><br class="">I'm fine with that, fwiw.  That was in fact the original proposal.<br class=""></blockquote><br class="">That is the wording of the original proposal, but I disagree that it is the content of the original proposal. I don’t believe that Compiler-RT is tightly coupled to LLVM at all, which is a big source of my disagreement here.<br class=""><br class=""><blockquote type="cite" class="">I'm also fine if we decide to put everything inside the monorepo.  I<br class="">think Richard Smith had some good arguments for why they belong<br class="">together.<br class=""><br class="">But I am really surprised that you think this is such a big deal that<br class="">you would object to the whole monorepo if this decision doesn't go<br class="">your way.<br class=""></blockquote><br class="">I really hate your phrasing on this. I’m not objecting to this proposal just because some minor decision doesn’t go my way. I think this is a very crucial point of whether or not the monorepo solution’s benefit outweighs its cost.<br class=""><br class=""><blockquote type="cite" class="">The decision of whether or not to include these projects<br class="">affects only read-write consumers of these projects -- of which there<br class="">are relatively few people.<br class=""></blockquote><br class="">Maybe there are few, but the impact is non-insignificant. Also I think the opinions of the read-write consumers of the sub-projects being included should count for a lot, and as a read-write consumer I don’t like this proposal if it includes the runtime libraries.<br class=""><br class=""><blockquote type="cite" class=""> Read-only consumers *are entirely<br class="">unaffected by the decision*, as they can continue to use the read-only<br class="">subproject mirrors exactly as today.<br class=""></blockquote><br class="">The existence of subproject mirrors requires someone to write and maintain the tooling to keep those mirrors updated, and those mirrors will have all the technical hurdles and drawbacks that a submodule repository would have.<br class=""><br class="">The question here is: Do you make downstream single project users work off potentially unreliable mirrors, or do you make the people who need a mono-repo experience work off a potentially unreliable submodule repo?<br class=""><br class="">I think the only answer anyone can reasonably give to this is that we don’t have enough information to make a reasonable decision that maximizes the benefits to most users while minimizing the adverse impacts. Hence why I keep saying we need a survey to understand how *people* interact with the project and what kinds of workflows are important. I emphasize the word “people” in that last sentence because this decision impacts the contributors to the community, and downstream users. We need to take all perspectives into account when making this kind of infrastructure decision.<br class=""><br class=""><blockquote type="cite" class=""><br class=""><blockquote type="cite" class="">(2) The projects in the mono-repo most provide wide benefit to the community such that the overall community benefit outweighs the impacts of the project being in the repo<br class="">(3) Projects in the mono-repo must conform to some defined set of standards. LLVM’s coding standards might be a bit much, but something along those lines.<br class=""></blockquote><br class="">Would you mind explaining why you think the criteria for inclusion in<br class="">the monorepo should be different than the criteria for inclusion as an<br class="">LLVM subproject?<br class=""></blockquote><br class="">For starters, including things as LLVM subproject doesn’t require that they meet criteria #1 in my proposal. Simply put, they don’t need to be tightly coupled to LLVM. We have many examples of that.<br class=""><br class=""><blockquote type="cite" class=""><br class="">I think these are fine criteria -- for inclusion of code as an LLVM<br class="">subproject.  But it seems to me -- and maybe I'm wrong -- that the<br class="">reason you're proposing them is that there exist today LLVM<br class="">subprojects that are version-locked to other projects but you think do<br class="">not meet these criteria, and therefore you want to exclude them from<br class="">the monorepo.  Is that right?  lldb comes to mind, as it wasn't in<br class="">your list above.<br class=""><br class="">I understand that lldb is persona non grata in some circles.  But.<br class="">It's not right to use the source code migration as a tool to revisit<br class="">an old decision like this.  That is procedurally unjust.  The relevant<br class="">decision should be, "is LLDB an LLVM subproject that is version-locked<br class="">to other subprojects, or not?”<br class=""></blockquote><br class="">I really don’t want to debate LLDB. It is a hot issue for a lot of people, and I’d really prefer if we didn’t start a “let’s all rag on lldb” thread.<br class=""><br class="">Instead, let’s talk about DragonEgg. The DragonEgg project is, as far as I can tell, abandoned, but it is still an LLVM project that is tightly coupled to LLVM versions. So it meets criteria #1. I think it fails to meet criteria #2 because DragonEgg is basically abandoned and provides no real value to the community. Even though the burden of a dead project on the mono-repo is minuscule, I think there is no good reason to include DragonEgg.<br class=""><br class="">Do you disagree?<br class=""><br class=""><blockquote type="cite" class=""><br class="">If you feel strongly that we should reevaluate every project on the<br class="">basis of these last two criteria before including them in the<br class="">monorepo, would you mind elaborating on what exactly are the harms of<br class="">including a project that isn't up to snuff?<br class=""></blockquote><br class="">Every project that is added to the mono-repo will incur a small cost to developers in terms of the size it adds to the repository, and the tooling or workflow adjustments to handle the change. In most cases this will be minimal, even negligible. However I think the burden on runtime developers is significant.<br class=""><br class=""><blockquote type="cite" class=""> If you are aesthetically<br class="">displeased by a project, you can hide it using sparse checkouts.  And<br class="">nobody is going to make you build it.  At that point, the only cost I<br class="">can think of from including a project is the bytes on disk.  But since<br class="">the full history of all LLVM subprojects (excluding test-suite) is<br class="">500mb (*), surely you're not going to argue for the exclusion of (say)<br class="">lldb on the grounds of saving 25mb (or whatever)?<br class=""></blockquote><br class="">I won’t argue over lldb at all. My arguments are from the perspective of someone working on the runtime library projects, the burden is significant to be included in the llvm mono-repo. While the full history of LLVM is around 500MB, the full history of *all* the runtime projects is less than 100MB. Developers working on libcxx or compiler-rt should not need to clone LLVM, and run commands to do sparse checkouts. That is more burden than we should incur. Further the setup cost of doing multiple sparse checkouts in order to approximate the workflows we have today with decoupled projects is, IMO, unnecessary and unreasonable.<br class=""><br class="">Those arguments go away if you follow criteria that exclude runtime projects from the mono-repo.<br class=""><br class="">-Chris<br class=""><br class=""><blockquote type="cite" class=""><br class="">-Justin<br class=""><br class="">(*) I'd called it 1.2gb before, but Bruce Hoult set me straight.<br class=""><br class="">On Thu, Jul 28, 2016 at 10:21 AM, Chris Bieneman via llvm-dev<br class=""><<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""><blockquote type="cite" class=""><br class="">On Jul 28, 2016, at 12:59 AM, Renato Golin via llvm-dev<br class=""><<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""><br class="">On 28 Jul 2016 8:36 a.m., "David Chisnall via llvm-dev"<br class=""><<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""><blockquote type="cite" class="">This does not apply to libc++.  We support building the entire LLVM suite<br class="">with other C++ standard library implementations (at least libstdc++, and I<br class="">think also with Visual Studio’s implementation), so there is no dependency<br class="">of anything on libc++.  Similarly, we support building libc++ with other<br class="">compilers (in FreeBSD, we currently build it with gcc 6.1 for RISC-V, for<br class="">example, where the LLVM toolchain is not quite useable).<br class=""><br class="">The same applies to libunwind, to an even greater degree (where libc++<br class="">implements a standard API, libunwind implements a standard ABI).<br class=""></blockquote><br class="">I think the dependencies of lib* in LLVM are more conceptual than version<br class="">lock, but they're still there.<br class=""><br class="">I agree with you in all other points, mind you, but RT needs an unwind<br class="">library as much as it needs clang. Without them, RT "can" (and indeed does)<br class="">work, but we're not providing a complete solution.<br class=""><br class="">I won't *push* to bundle libunwind, libcxxabi (and ultimately libcxx) on<br class="">those merits alone, but my opinion is that we should. I can't see much use<br class="">in RT without them. That's why we're still defaulting to libgcc on Linux.<br class=""><br class="">Renato, I just want to point out that the Compiler-RT story is *WAY* more<br class="">complicated than it might seem from your comments here. Compiler-RT is<br class="">really two or three conceptually different things that happen to be in the<br class="">same project, and parts of it are very useful without libunwind, libcxxabi,<br class="">and libcxx.<br class=""><br class="">For example, the Compiler-RT sanitizers are used with GCC and libgcc. They<br class="">can be built to be used with libstdc++ as well as libc++ (although I do<br class="">think that loses some features).<br class=""><br class="">I would not object to a mono-repo that included LLVM, Clang, LLD, and<br class="">Clang-Tools-Extra. I strongly object to any mono-repo that includes any of<br class="">the runtime library projects. I also think that once you move away from the<br class="">“mono-repo including all” you need to identify criteria for how you<br class="">determine which projects get included, and potentially how you evaluate<br class="">adding projects to the mono-repo.<br class=""><br class="">As a straw man I would suggest the following criteria for inclusion into the<br class="">mono-repo:<br class=""><br class="">(1) Projects in the mono-repo must be tightly coupled to specific versions<br class="">or commits of other projects in the mono-repo<br class="">(2) The projects in the mono-repo most provide wide benefit to the community<br class="">such that the overall community benefit outweighs the impacts of the project<br class="">being in the repo<br class="">(3) Projects in the mono-repo must conform to some defined set of standards.<br class="">LLVM’s coding standards might be a bit much, but something along those<br class="">lines.<br class=""><br class="">Thoughts?<br class=""><br class="">-Chris<br class=""><br class="">My tuppence.<br class=""><br class="">Cheers,<br class="">Renato<br class=""><br class="">_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""><br class=""><br class=""><br class="">_______________________________________________<br class="">LLVM Developers mailing list<br class="">llvm-dev@lists.llvm.org<br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""><br class=""></blockquote></blockquote><br class=""></blockquote></div></div></blockquote></div><br class=""></body></html>