diff options
Diffstat (limited to 'lib/Frontend/InitHeaderSearch.cpp')
| -rw-r--r-- | lib/Frontend/InitHeaderSearch.cpp | 15 | 
1 files changed, 15 insertions, 0 deletions
diff --git a/lib/Frontend/InitHeaderSearch.cpp b/lib/Frontend/InitHeaderSearch.cpp index 3f7e6825140c..8178f7a9362a 100644 --- a/lib/Frontend/InitHeaderSearch.cpp +++ b/lib/Frontend/InitHeaderSearch.cpp @@ -40,6 +40,7 @@ class InitHeaderSearch {    std::vector<std::pair<IncludeDirGroup, DirectoryLookup> > IncludePath;    typedef std::vector<std::pair<IncludeDirGroup,                        DirectoryLookup> >::const_iterator path_iterator; +  std::vector<std::pair<std::string, bool> > SystemHeaderPrefixes;    HeaderSearch &Headers;    bool Verbose;    std::string IncludeSysroot; @@ -57,6 +58,12 @@ public:                 bool isCXXAware, bool isUserSupplied,                 bool isFramework, bool IgnoreSysRoot = false); +  /// AddSystemHeaderPrefix - Add the specified prefix to the system header +  /// prefix list. +  void AddSystemHeaderPrefix(StringRef Prefix, bool IsSystemHeader) { +    SystemHeaderPrefixes.push_back(std::make_pair(Prefix, IsSystemHeader)); +  } +    /// AddGnuCPlusPlusIncludePaths - Add the necessary paths to support a gnu    ///  libstdc++.    void AddGnuCPlusPlusIncludePaths(StringRef Base, @@ -210,6 +217,8 @@ void InitHeaderSearch::AddDefaultCIncludePaths(const llvm::Triple &triple,      switch (os) {      case llvm::Triple::FreeBSD:      case llvm::Triple::NetBSD: +    case llvm::Triple::OpenBSD: +    case llvm::Triple::Bitrig:        break;      default:        // FIXME: temporary hack: hard-coded paths. @@ -623,6 +632,8 @@ void InitHeaderSearch::Realize(const LangOptions &Lang) {    bool DontSearchCurDir = false;  // TODO: set to true if -I- is set?    Headers.SetSearchPaths(SearchList, NumQuoted, NumAngled, DontSearchCurDir); +  Headers.SetSystemHeaderPrefixes(SystemHeaderPrefixes); +    // If verbose, print the list of directories that will be searched.    if (Verbose) {      llvm::errs() << "#include \"...\" search starts here:\n"; @@ -660,6 +671,10 @@ void clang::ApplyHeaderSearchOptions(HeaderSearch &HS,    Init.AddDefaultIncludePaths(Lang, Triple, HSOpts); +  for (unsigned i = 0, e = HSOpts.SystemHeaderPrefixes.size(); i != e; ++i) +    Init.AddSystemHeaderPrefix(HSOpts.SystemHeaderPrefixes[i].Prefix, +                               HSOpts.SystemHeaderPrefixes[i].IsSystemHeader); +    if (HSOpts.UseBuiltinIncludes) {      // Set up the builtin include directory in the module map.      llvm::sys::Path P(HSOpts.ResourceDir);  | 
