|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | against an enum.
llvm-svn: 223422 | 
| | 
| 
| 
| 
| 
| | pair<iterator, bool> as per the C++ standard's associative container concept.
llvm-svn: 222335 | 
| | 
| 
| 
| 
| 
| | silent coverity warning CID 1231654
llvm-svn: 215897 | 
| | 
| 
| 
| 
| 
| | auroraux.org is not resolving.
llvm-svn: 215644 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The main subtlety here is that the Darwin tools still need to be given "-arch
arm64" rather than "-arch aarch64". Fortunately this already goes via a custom
function to handle weird edge-cases in other architectures, and it tested.
I removed a few arm64_be tests because that really isn't an interesting thing
to worry about. No-one using big-endian is also referring to the target as
arm64 (at least as far as toolchains go). Mostly they date from when arm64 was
a separate target and we *did* need a parallel name simply to test it at all.
Now aarch64_be is sufficient.
llvm-svn: 213744 | 
| | 
| 
| 
| 
| 
| 
| 
| | The changes in r204978 broke win32-macho targets. There were checks added for
MSVC and Itanium environments as special cases, and win32-macho needs to be
treated the same way.
llvm-svn: 210584 | 
| | 
| 
| 
| 
| 
| | This keeps Clang consistent with backend naming conventions.
llvm-svn: 209579 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This adds Clang support for the ARM64 backend. There are definitely
still some rough edges, so please bring up any issues you see with
this patch.
As with the LLVM commit though, we think it'll be more useful for
merging with AArch64 from within the tree.
llvm-svn: 205100 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This follows the LLVM change to canonicalise the Windows target triple
spellings.  Rather than treating each Windows environment as a single entity,
the environments are now modelled properly as an environment.  This is a
mechanical change to convert the triple use to reflect that change.
llvm-svn: 204978 | 
| | 
| 
| 
| 
| 
| | Newer FreeBSD doesnt ship with gcc and defaults to using libc++.
llvm-svn: 203700 | 
| | 
| 
| 
| 
| 
| | This is a follow-up to r203624 to address Anton's comment.
llvm-svn: 203668 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | of MinGW older than 4.7 with incompatible C++ libraries.
This patch makes clang look for all MinGW versions from 4.7:
  4.7.0, 4.7.1, 4.7.2, 4.7.3
  4.8.0, 4.8.1, 4.8.2.
llvm-svn: 197176 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Up until now we were expecting that when libc++ is installed alongside
clang the headers would be in lib/, which was true if the configure
build was used and false if the cmake build was.
We've now corrected the configure build to install in include/, and
with this change we'll be able to find the correct headers with both
build systems.
llvm-svn: 194834 | 
| | 
| 
| 
| | llvm-svn: 192982 | 
| | 
| 
| 
| | llvm-svn: 188638 | 
| | 
| 
| 
| | llvm-svn: 183903 | 
| | 
| 
| 
| 
| 
| | This is preparation for replacing Path.h with PathV2.h.
llvm-svn: 183781 | 
| | 
| 
| 
| | llvm-svn: 180766 | 
| | 
| 
| 
| 
| 
| | Patch by John Marino.
llvm-svn: 179334 | 
| | 
| 
| 
| | llvm-svn: 173871 | 
| | 
| 
| 
| 
| 
| 
| 
| | - The only group where it makes sense for the "ExternC" bit is System, so this
   simplifies having to have the extra isCXXAware (or ImplicitExternC, depending
   on what code you talk to) bit caried around.
llvm-svn: 173859 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | - This slightly decouples the path handling, since before the group sometimes
   dominated the "use sysroot" bit, but it was still passed in via the API.
 - No functionality change.
llvm-svn: 173855 | 
| | 
| 
| 
| | llvm-svn: 173854 | 
| | 
| 
| 
| | llvm-svn: 173853 | 
| | 
| 
| 
| | llvm-svn: 173411 | 
| | 
| 
| 
| | llvm-svn: 173409 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | uncovered.
This required manually correcting all of the incorrect main-module
headers I could find, and running the new llvm/utils/sort_includes.py
script over the files.
I also manually added quite a few missing headers that were uncovered by
shuffling the order or moving headers up to be main-module-headers.
llvm-svn: 169237 | 
| | 
| 
| 
| 
| 
| | reference-counted, and hold a reference to it in HeaderSearch.
llvm-svn: 166583 | 
| | 
| 
| 
| | llvm-svn: 163776 | 
| | 
| 
| 
| | llvm-svn: 161546 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | in the default search path. Compilers on *BSD OS's only include /usr/include by
default.
Contributed by Brad Smith <brad@comstyle.com>
llvm-svn: 161173 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | override whether headers are system headers by checking for prefixes of the
header name specified in the #include directive.
This allows warnings to be disabled for third-party code which is found in
specific subdirectories of include paths.
llvm-svn: 158418 | 
| | 
| 
| 
| 
| 
| | possibly even a regression for known bad versions), I'm reverting it.
llvm-svn: 153420 | 
| | 
| 
| 
| 
| 
| 
| 
| | regular expression instead.
Patch thanks to Nikola Smiljanic
llvm-svn: 153413 | 
| | 
| 
| 
| 
| 
| | Patch thanks to Nikola Smiljanic
llvm-svn: 152801 | 
| | 
| 
| 
| 
| 
| 
| 
| | Unconditionally define __C99FEATURES__ when using C++ on Solaris.  This is a
(hopefully temporary) work around for libc++ exposing C99-but-not-C++98
features in C++98 mode.
llvm-svn: 151889 | 
| | 
| 
| 
| 
| 
| | clang (and linking clang against it).
llvm-svn: 151632 | 
| | 
| 
| 
| 
| 
| | -lgcc_s.
llvm-svn: 150602 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | And remove HAVE_CLANG_CONFIG_H, now that the header is generated
in the autoconf build, too.
Reverts r149571/restores r149504, now that config.h is generated
correctly by LLVM's configure in all build configurations.
llvm-svn: 150487 | 
| | 
| 
| 
| 
| 
| 
| | (I was going to fix the TODO about DenseMap too, but
that would break self-host right now. See PR11922.)
llvm-svn: 149799 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | --with-gcc-toolchain
that just uses the new toolchain probing logic. This fixes linking with -m32 on
64 bit systems (the /32 dir was not being added to the search).
llvm-svn: 149652 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | into using non-absolute system includes (<foo>)...
... and introduce another hack that is simultaneously more heineous
and more effective. We whitelist Clang-supplied headers that augment
or override system headers (such as float.h, stdarg.h, and
tgmath.h). For these headers, Clang does not provide a module
mapping. Instead, a system-supplied module map can refer to these
headers in a system module, and Clang will look both in its own
include directory and wherever the system-supplied module map
suggests, then adds either or both headers. The end result is that
Clang-supplied headers get merged into the system-supplied module for
the C standard library.
As a drive-by, fix up a few dependencies in the _Builtin_instrinsics
module.
llvm-svn: 149611 | 
| | 
| 
| 
| 
| 
| | Too many weird build failures.
llvm-svn: 149571 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | And remove HAVE_CLANG_CONFIG_H, now that the header is generated
in the autoconf build, too. (clang r149497 / llvm r149498)
Also include the config.h header after all other headers, per
the LLVM coding standards.
It also turns out WindowsToolChain.cpp wasn't using the config
header at all, so that include's just deleted now.
llvm-svn: 149504 | 
| | 
| 
| 
| | llvm-svn: 148637 | 
| | 
| 
| 
| | llvm-svn: 148636 | 
| | 
| 
| 
| 
| 
| 
| 
| | Ruben Van Boxem.
(We should probably start doing some sort of autodetection like we do on Linux at some point.)
llvm-svn: 145326 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | the first (and diff-noisiest) step to making Linux header searching
tremendously more principled and less brittle. Note that this step
should have essentially no functional impact. We still search the exact
same set of paths in the exact same order. The only change here is where
the code implementing such a search lives.
This has one obvious negative impact -- we now pass a ludicrous number
of flags to the CC1 layer. That should go away as I re-base this logic
on the logic to detect a GCC installation. I want to do this in two
phases so the bots can tell me if this step alone breaks something, and
so that the diffs of the refactoring make more sense.
llvm-svn: 143822 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | encode the *exact* semantics which the header search paths internally
built by the Frontend layer have had, which is both non-user-provided,
and at times adding the implicit extern "C" bit to the directory entry.
There are lots of CC1 options that are very close, but none do quite
this, and they are all already overloaded for other purposes. In some
senses this makes the command lines more clean as it clearly indicates
which flags are exclusively used to implement internal detection of
"standard" header search paths.
Lots of the implementation of this is really crufty, due to the
surrounding cruft. It doesn't seem worth investing lots of time cleaning
this up as it isn't new, and hopefully *lots* of this code will melt
away as header search inside of the frontend becomes increasingly
trivial.
llvm-svn: 143798 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Windows. There are still FIXMEs and lots of problems with this code.
Some of them will be addressed shortly by my follow-up patches, but most
are going to wait until we isolate this code and can fix it properly.
This version should be no worse than what we had before.
llvm-svn: 143752 |