Unfortunately, clang-cl only supports a very limited subset of CL's flags. And if you want to talk to clang directly you have to go through an extra layer of indirection by using -Xclang -flag. By using clang directly you get the whole power of clang without arbitrary limitations (and as a bonus you can now compiler your software on mac and linux).
By using clang-cl you are getting the advantage of the LLVM backend.
LLVM/Clang can target many different platforms besides windows and it is open source so it is sponsored by many large companies including Google Apple etc.
Google use it for Chrome for example (which includes windows) and have engineers working full time to meet their needs.
Intel, ARM, AMD and co have upstreamed many optimisations into LLVM also.
If you have a bug it probably will be resolved faster. Instead of waiting months for the next Visual Studio Release etc
In general, LLVM because of the intermediate bytecode language and well made libraries like libclang enables new kind of tooling.
Microsoft actually use LLVM themselves in many places and have a bunch of open source projects that use it, which is great
The would actually probably be better off retiring MSVC's c++ compiler and focus on clang along with everyone else because other companies are basically paying for the engineering for their platform with clang.
Unlike gcc the license for llvm/clang is more liberal so if they want private internal tooling they can still do that also.
Wanting to distribute something externally does not mean that you want to release it publicly. Lots of "internal" tools are distributed to teams at partner companies and contractors, for example.
And more generally, the internal tool of today can become the hit add-on to your existing product of tomorrow, or a new product line. You want to retain flexibility.
Legal departments aren't just being paranoid when they insist on avoiding GPL-licensed code if at all possible.
> both clang and GCC are viable bases from which you make your internal tooling.
License is not the only factor determining usability of a compiler wrt interfacing with external tools. GCC was deliberately designed to prevent such usage.
An (unusual) case I've found it useful for is doing LTO across boundaries with other languages whose compilers use LLVM. I've used it to enable inlining of C++ methods called from Rust (the C++ code in question was V8).
Unfortunately, clang-cl only supports a very limited subset of CL's flags. And if you want to talk to clang directly you have to go through an extra layer of indirection by using -Xclang -flag. By using clang directly you get the whole power of clang without arbitrary limitations (and as a bonus you can now compiler your software on mac and linux).
I tried using clang-cl recently but it produced a ton of linker errors for basic math functions. Does that mean clang-cl does not provide its own libc? And is there some guide that explains various C options on windows?
"opting in" to VS 2017 is recommended when building Chrome for 64-bit Windows to get improved incremental linking support. (We still link Chrome on Windows with link.exe even when compiling with Clang.)
> (We still link Chrome on Windows with link.exe even when compiling with Clang.)
I wasn't aware of this, I know Rui the COFF owner in lld puts in a lot of effort into lld for chrome link times.
Maybe he just uses it as a benchmark then :D
I actually caused a regression in migrating def code from lld to llvm with symbol mangling because we were missing a test case for this specific type of mangling and within hours it ended up on a chromium bug tracker and was fixed also within hours by Reid another googler on LLVM.
Yes, I should have been a bit more clear. You can link with lld (we have bots running that do this; we're even setting up a bot that enables ThinLTO). But lld support for emitting PDB files isn't quite there yet.
Not true anymore, I've updated the repository and article to work with 2017. Visual Studio 2017 doesn't require the -fms-compatibility flags anymore, in fact, it refuses to compile if you specify them. Since I was expecting these to be required I found no way to compile them.
Errr, use clang-cl, and "yes it is". That's the whole point of clang-cl :)