diff options
author | Marc Chevrier <marc.chevrier@gmail.com> | 2020-11-23 10:51:11 (GMT) |
---|---|---|
committer | Marc Chevrier <marc.chevrier@gmail.com> | 2020-11-28 15:02:58 (GMT) |
commit | b6068ce407e541b13fc0484bc6b84e896c9913e8 (patch) | |
tree | fc30dd518d39f020bfaf75fb01044177a2ce1635 | |
parent | 3401403f69033446a5dcefd60dd8c375eaa58a44 (diff) | |
download | CMake-b6068ce407e541b13fc0484bc6b84e896c9913e8.zip CMake-b6068ce407e541b13fc0484bc6b84e896c9913e8.tar.gz CMake-b6068ce407e541b13fc0484bc6b84e896c9913e8.tar.bz2 |
Refactoring: enhance include file filtering
In preparation of support of 'CMAKE_DEPENDS_IN_PROJECT_ONLY'
when dependencies are generated by the compiler.
-rw-r--r-- | Source/cmLocalUnixMakefileGenerator3.cxx | 38 |
1 files changed, 14 insertions, 24 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx index e06dfac..3654e8f 100644 --- a/Source/cmLocalUnixMakefileGenerator3.cxx +++ b/Source/cmLocalUnixMakefileGenerator3.cxx @@ -9,12 +9,14 @@ #include <utility> #include <cm/memory> +#include <cm/string_view> #include <cm/vector> #include <cmext/algorithm> #include "cmsys/FStream.hxx" #include "cmsys/Terminal.h" +#include "cmCMakePath.h" #include "cmCustomCommand.h" // IWYU pragma: keep #include "cmCustomCommandGenerator.h" #include "cmFileTimeCache.h" @@ -1742,44 +1744,32 @@ class NotInProjectDir { public: // Constructor with the source and binary directory's path - NotInProjectDir(std::string sourceDir, std::string binaryDir) - : SourceDir(std::move(sourceDir)) - , BinaryDir(std::move(binaryDir)) + NotInProjectDir(cm::string_view sourceDir, cm::string_view binaryDir) + : SourceDir(sourceDir) + , BinaryDir(binaryDir) { } // Operator evaluating the predicate - bool operator()(const std::string& path) const + bool operator()(const std::string& p) const { + auto path = cmCMakePath(p).Normal(); + // Keep all relative paths: - if (!cmSystemTools::FileIsFullPath(path)) { + if (path.IsRelative()) { return false; } // If it's an absolute path, check if it starts with the source // directory: - return ( - !(IsInDirectory(SourceDir, path) || IsInDirectory(BinaryDir, path))); + return !(cmCMakePath(SourceDir).IsPrefix(path) || + cmCMakePath(BinaryDir).IsPrefix(path)); } private: - // Helper function used by the predicate - static bool IsInDirectory(const std::string& baseDir, - const std::string& testDir) - { - // First check if the test directory "starts with" the base directory: - if (!cmHasPrefix(testDir, baseDir)) { - return false; - } - // If it does, then check that it's either the same string, or that the - // next character is a slash: - return ((testDir.size() == baseDir.size()) || - (testDir[baseDir.size()] == '/')); - } - // The path to the source directory - std::string SourceDir; + cm::string_view SourceDir; // The path to the binary directory - std::string BinaryDir; + cm::string_view BinaryDir; }; } @@ -1862,7 +1852,7 @@ void cmLocalUnixMakefileGenerator3::WriteDependLanguageInfo( this->GetIncludeDirectories(includes, target, implicitLang.first, this->GetConfigName()); - std::string binaryDir = this->GetState()->GetBinaryDirectory(); + std::string const& binaryDir = this->GetState()->GetBinaryDirectory(); if (this->Makefile->IsOn("CMAKE_DEPENDS_IN_PROJECT_ONLY")) { std::string const& sourceDir = this->GetState()->GetSourceDirectory(); cm::erase_if(includes, ::NotInProjectDir(sourceDir, binaryDir)); |