<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div></div><div><br></div><div><br>On Aug 9, 2016, at 6:56 PM, Eric Fiselier <<a href="mailto:eric@efcs.ca">eric@efcs.ca</a>> wrote:<br><br></div><blockquote type="cite"><div><div dir="ltr"><div style="font-size:12.8px">By "in-tree" all I mean is the libc++ source directory exists within llvm/projects, nothing more.</div><div style="font-size:12.8px"><br></div><div style="font-size:12.8px">(1) from a build system perspective we need to be able to build libcxx using just-built clang which means an out-of-tree style configuration even if it seems in-tree to the user.</div><div style="font-size:12.8px"><br></div><div style="font-size:12.8px">True. I'm currently working on supporting a just-built Clang and my plan was for the in-tree libc++ to recursively add itself as an external project.</div><div style="font-size:12.8px">As you said this is technically "out-of-tree" but not to the users perspective.</div></div></div></blockquote><div><br></div><div>This almost works with the new LLVM runtimes directory. I have some WIP patches to libcxx that I need to finish to get it fully there, but that isn't relevant to the discussion at hand.</div><br><blockquote type="cite"><div><div dir="ltr"><div style="font-size:12.8px"><br></div><div style="font-size:12.8px"><br></div><div style="font-size:12.8px"><span style="font-size:12.8px">(2) lots of people use libcxx without clang. Removing support for libcxx building out of tree is unreasonable for end users. It might be reasonable for developers, but end users need that ability.</span><br></div><div style="font-size:12.8px"><br></div><div style="font-size:12.8px">Not sure what Clang has to do with this. The only difference is that end-users would have to checkout libc++ inside LLVM, not beside it.</div></div></div></blockquote><div><br></div><div>Today end users don't need to check out LLVM at all, and forcing users (like OS distributions) to check out LLVM when they aren't using it would be highly undesirable, and I don't see a justification.</div><div><br></div><div>-Chris</div><br><blockquote type="cite"><div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Aug 9, 2016 at 7:14 PM, Chris Bieneman <span dir="ltr"><<a href="mailto:beanz@apple.com" target="_blank">beanz@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="auto"><span class=""><div></div><div><br></div><div><br>On Aug 9, 2016, at 6:01 PM, Eric Fiselier <<a href="mailto:eric@efcs.ca" target="_blank">eric@efcs.ca</a>> wrote:<br><br></div><blockquote type="cite"><div><div dir="ltr"><div>I don't see who would benefit from having libc++/libc++abi in the megarepo since they are not coupled to either LLVM or Clang. Upstream changes to other projects have no effect on libc++ and vise-versa so there is no need to keep them in sync.<br></div><div><br></div><div>For this reason libc++ should stay a separate repository, which can be included in the megarepo as a sub-module. This avoids concerns about increasing the cost of checking out and building libc++.</div><div><br></div><div>There has also been a secondary discussion about libc++ supporting out-of-tree builds, I'm unconvinced by arguments about the cost of cloning LLVM when you only want libc++. Building and testing libc++ already requires a LLVM checkout somewhere on the machine for LIT and CMake modules, so the additional cost is already there. I would be OK dropping out-of-tree support for libc++ since they are hard to configure correctly and offer little benefit over in-tree builds. </div></div></div></blockquote><div><br></div></span><div>Two reasons libcxx needs to support out of tree builds.</div><div><br></div><div>(1) from a build system perspective we need to be able to build libcxx using just-built clang which means an out-of-tree style configuration even if it seems in-tree to the user.</div><div>(2) lots of people use libcxx without clang. Removing support for libcxx building out of tree is unreasonable for end users. It might be reasonable for developers, but end users need that ability.</div><span class="HOEnZb"><font color="#888888"><div><br></div><div>-Chris</div></font></span><div><div class="h5"><br><blockquote type="cite"><div><div dir="ltr"><div><br></div><div>/Eric</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Aug 9, 2016 at 5:32 PM, Chris Bieneman 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:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Can we please stop with the attempts at persuading me to a mono-repo approach? I really hate that my voicing criticism has resulted in a big “let’s sway beanz” effort.<br>
<br>
Justin, the reality is I don’t think the benefits of a mono-repo justify the costs if it includes all projects. I think the cost of a mono-repo which excludes the runtime projects is lower, so I dislike it less. I can even see (and agree with) some arguments in favor of LLVM, Clang and LLD being in the same repository, but I don’t see it as solving a problem that needs to be solved.<br>
<br>
Mehdi’s performance data and git-svn workflow does *nothing* to win me over to your argument. All it says is that if we do your proposal I *might* be able to keep the same git-svn workflows I use today. I say “might” because nobody has addressed my original concerns about whether or not that workflow would be dropped if we move to a PR based model, or how we would support something similar in a PR model. I also think that the mono-repo might discourage pull requests to the runtimes projects from users that don’t use clang, which concerns me. Either way Mehdi’s information isn’t going to get me to support your idea over the other proposal which offers me actual workflow improvements.<br>
<br>
It isn’t even going to get me to a “meh”. While I don’t think the proposal should be valued based on whether or not it gives me specifically benefit, if it provides no benefit to me maintaining the status quo is better than a change from my perspective.<br>
<br>
All that aside, I really don’t think anyone should be investing that much time trying to appease me. While I am a loud voice, and I’m flattered that people seem to want to make me change my opinions they are in fact just opinions and preferences.<br>
<br>
At the end of the day we need some empirical data to drive this decision, and I don’t consider the anecdotes on these threads to be that data. While it is useful to hear the first hand opinions of people, it would be great if we had some actual data. Even with quantifiable data it is unlikely that I would consider the mono-repo an ideal workflow for myself, but it *could* be the right solution for the community. I would like to think that as a community we will all be able to put the “greater good” above our own preferences.<br>
<br>
-Chris<br>
<div><div><br>
<br>
> On Aug 9, 2016, at 2:12 PM, Justin Lebar via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
><br>
>> Sorry, I was specially replying to 'I think we'd be thrilled with a<br>
> "meh" from your corner.’. I didn’t feel like that was helping the<br>
> conversation along.<br>
><br>
> Sorry if I offended anyone with this or sent the wrong message. I was<br>
> trying to say, beanz was originally a strong, categorical opponent to<br>
> the monorepo. After some discussion, he became not strongly opposed<br>
> to a monorepo, so long as it didn't contain the runtime libraries.<br>
> Now Mehdi had a proposal that I was hoping would take him to<br>
> "not-strongly-opposed" to a monorepo that did contain the runtime<br>
> libraries. Given where we came from, I would be very happy with that<br>
> outcome.<br>
><br>
> On Tue, Aug 9, 2016 at 1:58 PM, Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" target="_blank">mehdi.amini@apple.com</a>> wrote:<br>
>><br>
>> On Aug 9, 2016, at 1:57 PM, Pete Cooper <<a href="mailto:peter_cooper@apple.com" target="_blank">peter_cooper@apple.com</a>> wrote:<br>
>><br>
>><br>
>> On Aug 9, 2016, at 1:55 PM, Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" target="_blank">mehdi.amini@apple.com</a>> wrote:<br>
>><br>
>><br>
>> On Aug 9, 2016, at 1:38 PM, Pete Cooper via llvm-dev<br>
>> <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
>><br>
>><br>
>> On Aug 9, 2016, at 11:27 AM, Justin Lebar via llvm-dev<br>
>> <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
>><br>
>> (2) If I’m stuck using git-svn I kinda feel like there is no real point in<br>
>> changing anything.<br>
>><br>
>><br>
>> No real point *for you specifically*.<br>
>><br>
>> But the vast majority of people would not be stuck using git-svn. And<br>
>> in addition the LLVM project would not be stuck using svn, with all<br>
>> the baggage, hosting issues, workflow issues (for people other than<br>
>> you), etc.<br>
>><br>
>> The bar by which this proposal should be measured is not "is it a net<br>
>> gain for beanz?" :) I think we'd be thrilled with a "meh" from your<br>
>> corner.<br>
>><br>
>> Justin, I don’t think this conversation is really going anywhere.<br>
>><br>
>><br>
>> I’m not sure what you’re referring to exactly, but in the context of "this<br>
>> thread isn’t getting anywhere”, I strongly disagree.<br>
>><br>
>> Sorry, I was specially replying to 'I think we'd be thrilled with a "meh"<br>
>> from your corner.’. I didn’t feel like that was helping the conversation<br>
>> along.<br>
>><br>
>><br>
>> OK, I agree with you then :)<br>
>><br>
>><br>
>> I agree with everything else you say about actually talking about the<br>
>> different proposals. I hope my point is well received that we really do<br>
>> need to eventually describe the impact to daily workflow, once the proposals<br>
>> are far enough along to do so.<br>
>><br>
>><br>
>> I agree with you also on this. I voiced in the past (on IRC toward<br>
>> Justin/David probably) that the proposal should include examples of workflow<br>
>> and how they translate to whatever the proposal will be.<br>
>><br>
>> Cheers,<br>
>><br>
>> —<br>
>> Mehdi<br>
>><br>
>><br>
>><br>
>> Pete<br>
>><br>
>><br>
>> I believe that the recent workflow tests I performed (see my last emails in<br>
>> this thread) are proof that this thread has been productive, and I believe<br>
>> discussing here and hearing concerns from people (Chris and others) are<br>
>> necessary before getting a proposal fleshed out and having a survey.<br>
>><br>
>> Having a survey without getting to the end of *what* we want to survey about<br>
>> is non-sense to me.<br>
>><br>
>> (That may miss your point, but your point wasn’t clear either…).<br>
>><br>
>> —<br>
>> Mehdi<br>
>><br>
>><br>
>><br>
>><br>
>> Renato already mentioned talking about this at the conference, and there has<br>
>> also been talk of a survey. I think we need those to see how the community<br>
>> actually feel about the proposals here.<br>
>><br>
>> Chris may be the only vocal advocate of an alternative to your proposal, but<br>
>> then there are people like me who are quiet because we are waiting for the<br>
>> survey to appear.<br>
>><br>
>> I would have been much more vocal if I thought we were actually going to<br>
>> adopt the monorepo, but for now I believe it is still only a proposal.<br>
>><br>
>> Full disclosure, I don’t want a monorepo. I think it optimizes for the use<br>
>> case where people want to bisect, and I don’t think its reasonable to push<br>
>> on everyone to have a monorepo for those who want to bisect. The submodules<br>
>> repo has already been demonstrated as one potential solution to this which<br>
>> would allow those who want to bisect to do so, while everyone else can<br>
>> continue to work more or less as they do today.<br>
>><br>
>> In terms of the proposals, I think you, Mehdi, Chris, and a number of others<br>
>> have proven that there is almost no technical solution beyond our reach.<br>
>> What we do have are proposals which optimize for different use cases. Given<br>
>> this, I think the most useful thing from my point of view (and hopefully to<br>
>> others) would be for those advocating each different solution to actual give<br>
>> short examples of each of the different use cases and how to support them.<br>
>><br>
>> For example:<br>
>><br>
>> Monorepo, pushing a change to compiler-rt:<br>
>> 1: Git commit …<br>
>> 2: Git pull --rebase<br>
>> 3: test<br>
>> 4 a: Git push /* no commits to any other project so the push works */. Goto<br>
>> 5<br>
>> 4 b: Git push /* someone committed to some other project in the monorepo.<br>
>> Goto 2 */<br>
>> 5: Done<br>
>><br>
>> I know that this example appears negative in the case where someone else<br>
>> committed to another project and a rebase is required, but thats exactly the<br>
>> point. This is showing that this particular scenario is potentially a<br>
>> problem compared to today and/or other proposals. A similar workflow could<br>
>> (should) be written for the sparse checkout monorepo, GitHub monorepo with<br>
>> svn, and submodules cases. The submodules case will likely show that<br>
>> bisecting is more complex than on the monorepo, while pushing is simpler.<br>
>><br>
>> Similarly, the submodules workflow probably isn’t capable of a single commit<br>
>> to llvm and clang in the revlock case while the monorepo is, but we as a<br>
>> community need to decide whether we want to optimize for that or not. I<br>
>> don’t have any data to suggest that revlock commits are frequent/infrequent<br>
>> or even a problem in general, and I don’t think we should optimize for that<br>
>> case unless its worth doing so.<br>
>><br>
>> Only by actually showing the use cases we care about can the community make<br>
>> an educated decision about what these proposals actually mean to our daily<br>
>> workflow. We can then choose what we are optimizing for. I personally want<br>
>> to have a very simple list of repo’s to clone from (or just one!) and for<br>
>> pushing to be easy, because those are the actions I perform the most often.<br>
>> Others will have different use cases they care about and they can choose the<br>
>> proposal which suits them best.<br>
>><br>
>> Cheers,<br>
>> Pete<br>
>><br>
>><br>
>> On Tue, Aug 9, 2016 at 11:22 AM, Chris Bieneman <<a href="mailto:beanz@apple.com" target="_blank">beanz@apple.com</a>> wrote:<br>
>><br>
>><br>
>> On Aug 9, 2016, at 10:08 AM, Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" target="_blank">mehdi.amini@apple.com</a>> wrote:<br>
>><br>
>><br>
>> On Aug 8, 2016, at 6:02 PM, Chris Bieneman <<a href="mailto:beanz@apple.com" target="_blank">beanz@apple.com</a>> wrote:<br>
>><br>
>><br>
>><br>
>> On Aug 8, 2016, at 5:09 PM, Mehdi Amini <<a href="mailto:mehdi.amini@apple.com" target="_blank">mehdi.amini@apple.com</a>> wrote:<br>
>><br>
>><br>
>> On Jul 27, 2016, at 12:50 PM, Chris Bieneman via llvm-dev<br>
>> <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
>><br>
>><br>
>> On Jul 27, 2016, at 10:21 AM, Justin Lebar <<a href="mailto:jlebar@google.com" target="_blank">jlebar@google.com</a>> wrote:<br>
>><br>
>> Thanks for your thoughts, Chris.<br>
>><br>
>> As supporting evidence of this, I was discussing this thread yesterday<br>
>> around the office yesterday and had quite a few people responding something<br>
>> along the lines of “they’re proposing what?”.<br>
>><br>
>><br>
>> 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>
>><br>
>> I don’t agree with this assertion. I believe that if you put forth multiple<br>
>> proposals, and have an articulate discussion of the merits and costs of each<br>
>> solution you can create a survey that can help inform decision making. I<br>
>> suppose we can agree to disagree.<br>
>><br>
>><br>
>> We've heard in thread from a lot of developers about how a monorepo<br>
>> would improve their workflow. 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>
>><br>
>><br>
>> Ok, let me describe a few workflows I’ve used in the last year that are (in<br>
>> my mind) adversely impacted by a mono-repo.<br>
>><br>
>> Case Study 1 - Simple development on a sub-project<br>
>><br>
>> I build LLVM + Clang + Compiler-RT using the just-built Clang to build<br>
>> Compiler-RT. I iterate on some complicated Compiler-RT changes over a period<br>
>> of a day. Once my Compiler-RT changes are done I rebase the compiler-rt<br>
>> repo, rebuild compiler-rt then commit.<br>
>><br>
>> With a mono-repo rebasing the checkout means rebasing the whole tree. So,<br>
>> either I have to wrangle some crazy git or CMake foo, or when I run “ninja<br>
>> compiler-rt” after the rebase it will rebuild LLVM and Clang too. That kinda<br>
>> sucks.<br>
>><br>
>> What this example illustrates to me is that today we have loosely coupled<br>
>> projects with an occasional rev lock. Moving to a mono-repo enforces a tight<br>
>> coupling that isn’t strictly required today.<br>
>><br>
>> Case Study 2 - Working on a sub-project in isolation across many platforms<br>
>><br>
>> I did a lot of work on Compiler-RT last year that had no direct dependency<br>
>> on any other LLVM project. During the development I was working with a<br>
>> Compiler-RT checkout and a build directory of just Compiler-RT. Every once<br>
>> in a while (or every other day as it were) I would make a change that would<br>
>> break a configuration that I wasn’t directly developing on. My workflow for<br>
>> handling those cases was:<br>
>><br>
>> (1) Spin up a VM on a VPS that closely matched the configuration I broke<br>
>> (2) Checkout Compiler-RT<br>
>> (3) Reproduce, debug, fix the failure<br>
>> (4) Commit the patch from the VM<br>
>><br>
>> In a mono-repository doing this would require checking out *all*<br>
>> sub-projects, not just Compiler-RT. I imagine this probably isn’t a common<br>
>> workflow, but it is one I use that would be adversely impacted by needing to<br>
>> checkout a full LLVM. Now, you might say I could check out the sub-project<br>
>> mirror, but then I can’t commit from the VM, which kinda sucks.<br>
>><br>
>><br>
>> So for the “I spin a VM and want to make a commit but don’t want to download<br>
>> a few hundred MBs with a git clone” story, it turns out that the github<br>
>> bridge with SVN helps to optimize with a “lean” checkout:<br>
>><br>
>> I fork the unified repo here:<br>
>> <a href="https://github.com/joker-eph/llvm-project/commits/master" rel="noreferrer" target="_blank">https://github.com/joker-eph/l<wbr>lvm-project/commits/master</a> and then: svn co<br>
>> <a href="https://github.com/joker-eph/llvm-project/trunk/compiler-rt" rel="noreferrer" target="_blank">https://github.com/joker-eph/l<wbr>lvm-project/trunk/compiler-rt</a><br>
>><br>
>> So that’s a net “no regression” compared to the current state :)<br>
>><br>
>><br>
>> Is the github SVN interface's "co" magically as fast as a git clone?<br>
>><br>
>><br>
>> $ time svn co <a href="https://github.com/joker-eph/llvm-project/trunk/compiler-rt" rel="noreferrer" target="_blank">https://github.com/joker-eph/l<wbr>lvm-project/trunk/compiler-rt</a><br>
>> ….<br>
>> real 0m8.539s user 0m0.919s sys 0m1.917s<br>
>> $ time git clone <a href="https://github.com/joker-eph/compiler-rt.git" rel="noreferrer" target="_blank">https://github.com/joker-eph/c<wbr>ompiler-rt.git</a><br>
>> real 0m5.487s user 0m1.208s sys 0m0.825s<br>
>><br>
>><br>
>> That’s actually not terrible! Color me impressed.<br>
>><br>
>><br>
>><br>
>> If not, it is a performance regression because today I use git clone and<br>
>> git-svn on my VMs just like on my physical machines, and either way it adds<br>
>> some crazy complexity.<br>
>><br>
>><br>
>> No problem, I get it, exactly same workflow as today:<br>
>><br>
>><br>
>> Yep. Which isn’t bad. I do however have two concerns.<br>
>><br>
>> (1) What happens if we move to pull request-based workflows? Do we still<br>
>> support this workflow?<br>
>> (2) If I’m stuck using git-svn I kinda feel like there is no real point in<br>
>> changing anything. I dislike this workflow less than the earlier proposals,<br>
>> but I see no reason to move to this instead of staying on SVN (other than<br>
>> the hosting issues which could be solved in other ways).<br>
>><br>
>> -Chris<br>
>><br>
>><br>
>> # Clone from the single read-only git repo<br>
>> $ git clone <a href="https://github.com/joker-eph/compiler-rt.git" rel="noreferrer" target="_blank">https://github.com/joker-eph/c<wbr>ompiler-rt.git</a><br>
>> …<br>
>> # Configure the SVN remote and initialize the svn metadata<br>
>> $ cd compiler-rt<br>
>> $ git svn init <a href="https://github.com/joker-eph/llvm-project/trunk/compiler-rt" rel="noreferrer" target="_blank">https://github.com/joker-eph/l<wbr>lvm-project/trunk/compiler-rt</a><br>
>> —username=<br>
>> $ git config svn-remote.svn.fetch :refs/remotes/origin/master<br>
>> $ git svn rebase -l<br>
>> ...<br>
>> # Remove and empty file and commit with git<br>
>> $ git rm empty<br>
>> $ git commit -m "remove empty file"<br>
>> # commit/push with svn to the unified git repo<br>
>> $ git svn dcommit<br>
>> Committing to <a href="https://github.com/joker-eph/llvm-project/trunk/compiler-rt" rel="noreferrer" target="_blank">https://github.com/joker-eph/l<wbr>lvm-project/trunk/compiler-rt</a><br>
>> ...<br>
>> D empty<br>
>> Committed r354148<br>
>><br>
>><br>
>> Here is the commit:<br>
>> <a href="https://github.com/joker-eph/llvm-project/commit/5f7e977c8cf3c33153d91be9b556143b49911ebe" rel="noreferrer" target="_blank">https://github.com/joker-eph/l<wbr>lvm-project/commit/5f7e977c8cf<wbr>3c33153d91be9b556143b49911ebe</a><br>
>><br>
>><br>
>> —<br>
>> Mehdi<br>
>><br>
>><br>
>><br>
>><br>
>><br>
>><br>
>><br>
>><br>
>><br>
>> While admittedly you do get a linear history with using the mono-repository,<br>
>> that isn’t the only way to solve the problem, and I don’t really think that<br>
>> the benefit (not needing to write some tooling) justifies the increased<br>
>> burden applied to contributors that don’t use the full LLVM family of<br>
>> projects.<br>
>><br>
>><br>
>> 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.<br>
>><br>
>><br>
>> I actually think there are *a lot* more considerations we need to be making<br>
>> for an infrastructure change like this. While it is true that our SCM<br>
>> hosting strategy primarily impacts developers, it also impacts our users. We<br>
>> should be conscious of the impact to downstream users in making<br>
>> infrastructure changes like this. That is part of why the idea of a survey<br>
>> holds appeal to me; it would give us the opportunity to get feedback from a<br>
>> much wider audience than the current “people on llvm-dev who haven’t been<br>
>> scared away”.<br>
>><br>
>> 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>
>><br>
>> I actually think we’re both talking about solutions that require tooling,<br>
>> and while we *could* be disagreeing over how much effort each tooling<br>
>> initiative would require (I think they’re pretty close, so I don’t care to<br>
>> have that argument), my actual disagreement with your proposal is that it is<br>
>> a change that impacts developers and users universally and I don’t think<br>
>> that it is justified. Simply put, I don’t feel that the benefits are<br>
>> substantial enough to warrant the kind of disruptive change you’re<br>
>> proposing.<br>
>><br>
>><br>
>> I suggest that saying that all of these developers are "doing it<br>
>> wrong" is not helpful.<br>
>><br>
>><br>
>> Maybe I’m missing something, but I don’t think I said anyone was “doing it<br>
>> wrong”. Bisecting across multiple git repositories isn’t a great experience.<br>
>> But neither is bisecting across a half dozen separate folders in an SVN<br>
>> repository. Both the submodule solution and the mono-repo solution solve<br>
>> this problem equivalently well.<br>
>><br>
>> 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>
>><br>
>> I’m not sure what “brokenness” you’re referring to. We have a collection of<br>
>> loosely connected projects by design. As a result of that intentional design<br>
>> certain workflows will be impacted. I don’t think that is brokenness. I<br>
>> think our loose coupling is a feature even if it makes some workflows<br>
>> harder.<br>
>><br>
>> -Chris<br>
>><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>
>><br>
>> On Wed, Jul 27, 2016 at 9:47 AM, Chris Bieneman via llvm-dev<br>
>> <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
>><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-mirro<wbr>r/</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" target="_blank">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" target="_blank">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>
>> ______________________________<wbr>_________________<br>
>> LLVM Developers mailing list<br>
>> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/<wbr>mailman/listinfo/llvm-dev</a><br>
>><br>
>><br>
>><br>
>> ______________________________<wbr>_________________<br>
>> LLVM Developers mailing list<br>
>> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/<wbr>mailman/listinfo/llvm-dev</a><br>
>><br>
>><br>
>> ______________________________<wbr>_________________<br>
>> LLVM Developers mailing list<br>
>> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/<wbr>mailman/listinfo/llvm-dev</a><br>
>><br>
>><br>
>> ______________________________<wbr>_________________<br>
>> LLVM Developers mailing list<br>
>> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/<wbr>mailman/listinfo/llvm-dev</a><br>
>><br>
>><br>
>> ______________________________<wbr>_________________<br>
>> LLVM Developers mailing list<br>
>> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/<wbr>mailman/listinfo/llvm-dev</a><br>
>><br>
>><br>
>><br>
>><br>
> ______________________________<wbr>_________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/<wbr>mailman/listinfo/llvm-dev</a><br>
<br>
______________________________<wbr>_________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">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/<wbr>mailman/listinfo/llvm-dev</a><br>
</div></div></blockquote></div><br></div>
</div></blockquote></div></div></div></blockquote></div><br></div>
</div></blockquote></body></html>