|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| | version in PR11298.
I hear-by apologize for adding yet more code to this monstrosity.
llvm-svn: 143567 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | search logic. The Debian multiarch seems to have completely changed from
when these were originally added, and I'd like to remove a bunch of
them, but I'll be lazy and delay that until this logic is hoisted into
the driver where it belongs.
This should resolve PR11223.
llvm-svn: 143345 | 
| | 
| 
| 
| 
| 
| | paths). The -nostdinc behavior is now -nostdsysteminc + -nobuiltininc.
llvm-svn: 141691 | 
| | 
| 
| 
| 
| 
| 
| 
| | frontend removes the non-system directory to maintain gcc compatibility.  When
this happens NumAngled needs to be updated.
PR11097
llvm-svn: 141565 | 
| | 
| 
| 
| | llvm-svn: 141086 | 
| | 
| 
| 
| | llvm-svn: 140365 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This moves the existing code for CPATH into the driver and adds the environment lookup and path splitting there.
The paths are then passed down to cc1 with -I options (CPATH), added after the normal user-specified include dirs.
Language specific paths are passed via -LANG-isystem and the actual filtering is performed in the frontend.
I tried to match GCC's behavior as close as possible
Fixes PR8971.
llvm-svn: 140341 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | target triple to separate modules built under different
conditions. The hash is used to create a subdirectory in the module
cache path where other invocations of the compiler (with the same
version, language options, etc.) can find the precompiled modules.
llvm-svn: 139662 | 
| | 
| 
| 
| 
| 
| 
| 
| | where the compiler will look for module files. Eliminates the
egregious hack where we looked into the header search paths for
modules.
llvm-svn: 139538 | 
| | 
| 
| 
| 
| 
| | by Will Dietz. PR10692.
llvm-svn: 138753 | 
| | 
| 
| 
| | llvm-svn: 137834 |