From 65c49e0e26488931e6ec27a1d352c07d43171f22 Mon Sep 17 00:00:00 2001 From: Sebastian Holtermann Date: Thu, 12 Sep 2019 10:28:14 +0200 Subject: Autogen: Sanitize include and search directories --- Source/cmQtAutoGenInitializer.cxx | 50 ++++++++++++++++++++++++++++++++------- 1 file changed, 41 insertions(+), 9 deletions(-) diff --git a/Source/cmQtAutoGenInitializer.cxx b/Source/cmQtAutoGenInitializer.cxx index a5fc5e3..7bf56df 100644 --- a/Source/cmQtAutoGenInitializer.cxx +++ b/Source/cmQtAutoGenInitializer.cxx @@ -122,6 +122,41 @@ bool StaticLibraryCycle(cmGeneratorTarget const* targetOrigin, } return cycle; } + +/** Sanitizes file search paths */ +class SearchPathSanitizer +{ +public: + SearchPathSanitizer(cmMakefile* makefile) + : SourcePath_(makefile->GetCurrentSourceDirectory()) + { + } + std::vector operator()( + std::vector const& paths) const; + +private: + std::string SourcePath_; +}; + +std::vector SearchPathSanitizer::operator()( + std::vector const& paths) const +{ + std::vector res; + res.reserve(paths.size()); + for (std::string const& srcPath : paths) { + // Collapse relative paths + std::string path = cmSystemTools::CollapseFullPath(srcPath, SourcePath_); + // Remove suffix slashes + while (cmHasSuffix(path, '/')) { + path.pop_back(); + } + // Accept only non empty paths + if (!path.empty()) { + res.emplace_back(std::move(path)); + } + } + return res; +} } // End of unnamed namespace cmQtAutoGenInitializer::InfoWriter::InfoWriter(std::string const& filename) @@ -456,16 +491,16 @@ bool cmQtAutoGenInitializer::InitMoc() // Moc includes { + SearchPathSanitizer sanitizer(this->Makefile); auto GetIncludeDirs = - [this](std::string const& cfg) -> std::vector { + [this, &sanitizer](std::string const& cfg) -> std::vector { // Get the include dirs for this target, without stripping the implicit - // include dirs off, see - // https://gitlab.kitware.com/cmake/cmake/issues/13667 + // include dirs off, see issue #13667. std::vector dirs; bool const appendImplicit = (this->QtVersion.Major >= 5); this->LocalGen->GetIncludeDirectoriesImplicit( dirs, this->GenTarget, "CXX", cfg, false, appendImplicit); - return dirs; + return sanitizer(dirs); }; // Default configuration include directories @@ -531,11 +566,8 @@ bool cmQtAutoGenInitializer::InitUic() std::string const usp = this->GenTarget->GetSafeProperty("AUTOUIC_SEARCH_PATHS"); if (!usp.empty()) { - cmExpandList(usp, this->Uic.SearchPaths); - std::string const& srcDir = this->Makefile->GetCurrentSourceDirectory(); - for (std::string& path : this->Uic.SearchPaths) { - path = cmSystemTools::CollapseFullPath(path, srcDir); - } + this->Uic.SearchPaths = + SearchPathSanitizer(this->Makefile)(cmExpandedList(usp)); } } // Uic target options -- cgit v0.12