diff options
author | Brad King <brad.king@kitware.com> | 2006-09-28 13:49:40 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2006-09-28 13:49:40 (GMT) |
commit | 0b135767d6670c9b9fc51d50f7e222394383a374 (patch) | |
tree | bc723a2265803fc9a05f2dffc4d45fba905b8d8b | |
parent | c717db3b88350c4795ceaed5c049cbb2b65bc4ce (diff) | |
download | CMake-0b135767d6670c9b9fc51d50f7e222394383a374.zip CMake-0b135767d6670c9b9fc51d50f7e222394383a374.tar.gz CMake-0b135767d6670c9b9fc51d50f7e222394383a374.tar.bz2 |
BUG: Do not filter system directories for include file dependencies.
-rw-r--r-- | Source/cmLocalGenerator.cxx | 26 | ||||
-rw-r--r-- | Source/cmLocalGenerator.h | 3 | ||||
-rw-r--r-- | Source/cmLocalUnixMakefileGenerator3.cxx | 2 |
3 files changed, 18 insertions, 13 deletions
diff --git a/Source/cmLocalGenerator.cxx b/Source/cmLocalGenerator.cxx index a3b48b3..95eb666 100644 --- a/Source/cmLocalGenerator.cxx +++ b/Source/cmLocalGenerator.cxx @@ -1096,7 +1096,8 @@ const char* cmLocalGenerator::GetIncludeFlags(const char* lang) } //---------------------------------------------------------------------------- -void cmLocalGenerator::GetIncludeDirectories(std::vector<std::string>& dirs) +void cmLocalGenerator::GetIncludeDirectories(std::vector<std::string>& dirs, + bool filter_system_dirs) { // Need to decide whether to automatically include the source and // binary directories at the beginning of the include path. @@ -1170,18 +1171,21 @@ void cmLocalGenerator::GetIncludeDirectories(std::vector<std::string>& dirs) } } - // Do not explicitly add the standard include path "/usr/include". - // This can cause problems with certain standard library - // implementations because the wrong headers may be found first. - emitted.insert("/usr/include"); - if(const char* implicitIncludes = this->Makefile->GetDefinition - ("CMAKE_PLATFORM_IMPLICIT_INCLUDE_DIRECTORIES")) + if(filter_system_dirs) { - std::vector<std::string> implicitIncludeVec; - cmSystemTools::ExpandListArgument(implicitIncludes, implicitIncludeVec); - for(unsigned int k = 0; k < implicitIncludeVec.size(); ++k) + // Do not explicitly add the standard include path "/usr/include". + // This can cause problems with certain standard library + // implementations because the wrong headers may be found first. + emitted.insert("/usr/include"); + if(const char* implicitIncludes = this->Makefile->GetDefinition + ("CMAKE_PLATFORM_IMPLICIT_INCLUDE_DIRECTORIES")) { - emitted.insert(implicitIncludeVec[k]); + std::vector<std::string> implicitIncludeVec; + cmSystemTools::ExpandListArgument(implicitIncludes, implicitIncludeVec); + for(unsigned int k = 0; k < implicitIncludeVec.size(); ++k) + { + emitted.insert(implicitIncludeVec[k]); + } } } diff --git a/Source/cmLocalGenerator.h b/Source/cmLocalGenerator.h index 1f273b9..66b47e5 100644 --- a/Source/cmLocalGenerator.h +++ b/Source/cmLocalGenerator.h @@ -170,7 +170,8 @@ public: std::vector<cmStdString>* fullPathLibs=0); /** Get the include flags for the current makefile and language. */ - void GetIncludeDirectories(std::vector<std::string>& dirs); + void GetIncludeDirectories(std::vector<std::string>& dirs, + bool filter_system_dirs = true); /** Compute the language used to compile the given source file. */ const char* GetSourceFileLanguage(const cmSourceFile& source); diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx index 2eac5ab..a0ff5dc 100644 --- a/Source/cmLocalUnixMakefileGenerator3.cxx +++ b/Source/cmLocalUnixMakefileGenerator3.cxx @@ -467,7 +467,7 @@ void cmLocalUnixMakefileGenerator3::WriteDirectoryInformationFile() infoFileStream << "SET(CMAKE_C_INCLUDE_PATH\n"; std::vector<std::string> includeDirs; - this->GetIncludeDirectories(includeDirs); + this->GetIncludeDirectories(includeDirs, false); for(std::vector<std::string>::iterator i = includeDirs.begin(); i != includeDirs.end(); ++i) { |