<div dir="ltr"><div dir="ltr"><div dir="ltr">A short update: All the build files I had locally are now upstreamed in llvm/utils/gn. If you want to give it a try, see llvm/utils/gn/README.rst (<a href="https://reviews.llvm.org/D56375" target="_blank">https://reviews.llvm.org/D56375</a> is pending to remove the "nothing works yet" disclaimers). It's still a bit rough around the edges, but on my Mac and Linux boxes check-clang check-lld check-llvm all work, with the AArch64, ARM X86 targets hooked up (and PowerPC and WebAssembly out for review).<div><br></div><div>GN is much more convenient to use if a small and hidden .gn file is in the root directory. I discovered that the new monorepo has a way to add files in the root dir, so I'm planning to move llvm/utils/gn/.gn to the root directory in <a href="https://reviews.llvm.org/D56419" target="_blank">https://reviews.llvm.org/D56419</a> . This does _not_ mean that the GN build is any more supported than before (i.e. "not supported at all"). I thought this was a pretty harmless change but I got pushback almost immediately after sending it out, so I'd like to mention it here so that it doesn't look like I'm trying to sneak this in.<br></div></div></div></div><br><div class="gmail_quote"><div dir="ltr">On Wed, Oct 31, 2018 at 2:18 PM Nico Weber <<a href="mailto:thakis@chromium.org" target="_blank">thakis@chromium.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"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div>Hi,</div><div><br></div><div>first things first: If you're happy with cmake, you can stop reading now. Nobody is proposing that LLVM moves off cmake, and nobody is proposing anything that's causing people using cmake more work.</div><div><br></div><div>At the LLVM conference, I gave a lightning talk [1] about using GN [2] to build LLVM and clang. cmake is great for many use cases, but in my opinion local day-to-day development isn't one of them. So I wrote GN build files for LLVM and clang, enough to make `ninja check-llvm check-clang check-lld` build everything needed for these three test suites and that all tests pass. This works on Linux, Mac, Win hosts targeting X86, ARM, AArch64. You can see them at [3].</div><div><br></div><div>I had been worried that it would be a lot of work to keep the build files up to date, but I've been using this for all my LLVM/clang/lld development the last 8 months, and it turned out to not be a big problem -- LLVM's build files don't change very often, and GN build files are a pleasure to work with in my opinion.</div><div><br></div><div>I gave the lightning talk just to talk about my personal workflow, but there was a lot of interest. We had a roundtable on the next day, and about 20 people said they'd be interested in using this for their development too. The main request was that the .gn files are checked in upstream, so that we can collaborate on keeping them working. Two to three orgs even said they'd be interested in moving their buildbots to GN.</div><div><br>As mentioned at the top, the intention here is not to replace cmake, only to offer an opt-in alternative for people who are interested in it. Keeping the GN build going would be the responsibility of people using it, not of the general LLVM community. If this fails to find use and bitrots, we can easily remove it again.</div><div><br>Are there any concerns with checking in GN files? I've put some initial docs for the GN build at <a href="https://reviews.llvm.org/D53944" target="_blank">https://reviews.llvm.org/D53944</a> ; it describes what the GN build is and is not, what its advantages are (speed and easier configurability), and some points about the philosophy behind the LLVM GN build.</div><div><br></div><div>If folks are generally ok with GN files living in-tree, I'll start sending patches for gradually adding gn files through the regular review process.</div><div><br></div><div>If having a BUILD.gn file in every directory being confusing is a concern, GN has the concept of a "secondary tree" so that all GN files could be below llvm/gn/tree/{llvm,clang,lld,...}.</div><div dir="ltr"><br></div><div>Cheers,</div><div>Nico</div><div dir="ltr"><br></div><div dir="ltr">1: <a href="https://llvm.org/devmtg/2018-10/talk-abstracts.html#lt2" target="_blank">https://llvm.org/devmtg/2018-10/talk-abstracts.html#lt2</a></div><div dir="ltr">2: <a href="https://gn.googlesource.com/gn" target="_blank">https://gn.googlesource.com/gn</a> , <a href="https://is.gd/gn_intro" target="_blank">https://is.gd/gn_intro</a></div><div dir="ltr">3: <a href="https://github.com/llvm-project/llvm-project-20170507/compare/master...nico:gn" target="_blank">https://github.com/llvm-project/llvm-project-20170507/compare/master...nico:gn</a> , click "Files Changed" to see the GN files.</div></div></div></div></div></div></div>
</blockquote></div>