diff options
author | Sebastian Holtermann <sebholt@xwmw.org> | 2017-02-15 18:30:08 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2017-02-21 15:12:51 (GMT) |
commit | 4c60099fea2b06229900cc16fed907185c4fe2ef (patch) | |
tree | 098e98162f01838777b4fca0fc7a988f4c77f444 /Source | |
parent | 815a05cf12499b42acea70b5a9534e10e1701417 (diff) | |
download | CMake-4c60099fea2b06229900cc16fed907185c4fe2ef.zip CMake-4c60099fea2b06229900cc16fed907185c4fe2ef.tar.gz CMake-4c60099fea2b06229900cc16fed907185c4fe2ef.tar.bz2 |
Autogen: Acquire and store header extensions in Init()
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmQtAutoGenerators.cxx | 82 | ||||
-rw-r--r-- | Source/cmQtAutoGenerators.h | 29 |
2 files changed, 50 insertions, 61 deletions
diff --git a/Source/cmQtAutoGenerators.cxx b/Source/cmQtAutoGenerators.cxx index 97d1299..e84b04d 100644 --- a/Source/cmQtAutoGenerators.cxx +++ b/Source/cmQtAutoGenerators.cxx @@ -246,9 +246,9 @@ bool cmQtAutoGenerators::Run(const std::string& targetDirectory, // Read old settings this->SettingsFileRead(mf.get(), targetDirectory); // Init and run - this->Init(); + this->Init(mf.get()); if (this->QtMajorVersion == "4" || this->QtMajorVersion == "5") { - if (!this->RunAutogen(mf.get())) { + if (!this->RunAutogen()) { return false; } } @@ -488,7 +488,7 @@ bool cmQtAutoGenerators::SettingsFileWrite(const std::string& targetDirectory) return success; } -void cmQtAutoGenerators::Init() +void cmQtAutoGenerators::Init(cmMakefile* makefile) { this->AutogenBuildSubDir = this->AutogenTargetName; this->AutogenBuildSubDir += "/"; @@ -503,6 +503,9 @@ void cmQtAutoGenerators::Init() this->ProjectSourceDir, this->ProjectBinaryDir); + // Acquire header extensions + this->HeaderExtensions = makefile->GetCMakeInstance()->GetHeaderExtensions(); + // Compose moc includes list std::list<std::string> mocIncludes; { @@ -564,7 +567,7 @@ void cmQtAutoGenerators::Init() mocIncludes.end()); } -bool cmQtAutoGenerators::RunAutogen(cmMakefile* makefile) +bool cmQtAutoGenerators::RunAutogen() { // the program goes through all .cpp files to see which moc files are // included. It is not really interesting how the moc file is named, but @@ -583,22 +586,17 @@ bool cmQtAutoGenerators::RunAutogen(cmMakefile* makefile) std::set<std::string> uicHeaderFiles; // Parse sources - { - const std::vector<std::string>& headerExtensions = - makefile->GetCMakeInstance()->GetHeaderExtensions(); - - for (std::vector<std::string>::const_iterator it = this->Sources.begin(); - it != this->Sources.end(); ++it) { - const std::string& absFilename = *it; - // Parse source file for MOC/UIC - if (!this->ParseSourceFile(absFilename, headerExtensions, mocsIncluded, - uisIncluded, this->MocRelaxedMode)) { - return false; - } - // Find additional headers - this->SearchHeadersForSourceFile(absFilename, headerExtensions, - mocHeaderFiles, uicHeaderFiles); + for (std::vector<std::string>::const_iterator it = this->Sources.begin(); + it != this->Sources.end(); ++it) { + const std::string& absFilename = *it; + // Parse source file for MOC/UIC + if (!this->ParseSourceFile(absFilename, mocsIncluded, uisIncluded, + this->MocRelaxedMode)) { + return false; } + // Find additional headers + this->SearchHeadersForSourceFile(absFilename, mocHeaderFiles, + uicHeaderFiles); } // Parse headers @@ -656,7 +654,7 @@ bool cmQtAutoGenerators::MocRequired(const std::string& text, * @brief Tests if the file should be ignored for moc scanning * @return True if the file should be ignored */ -bool cmQtAutoGenerators::MocSkip(const std::string& absFilename) +bool cmQtAutoGenerators::MocSkip(const std::string& absFilename) const { if (this->MocEnabled()) { // Test if the file name is on the skip list @@ -670,7 +668,7 @@ bool cmQtAutoGenerators::MocSkip(const std::string& absFilename) /** * @brief Tests if the file name is in the skip list */ -bool cmQtAutoGenerators::UicSkip(const std::string& absFilename) +bool cmQtAutoGenerators::UicSkip(const std::string& absFilename) const { if (this->UicEnabled()) { // Test if the file name is on the skip list @@ -686,7 +684,6 @@ bool cmQtAutoGenerators::UicSkip(const std::string& absFilename) */ bool cmQtAutoGenerators::ParseSourceFile( const std::string& absFilename, - const std::vector<std::string>& headerExtensions, std::map<std::string, std::string>& mocsIncluded, std::map<std::string, std::vector<std::string> >& uisIncluded, bool relaxed) { @@ -700,8 +697,8 @@ bool cmQtAutoGenerators::ParseSourceFile( } else { // Parse source contents for MOC if (success && !this->MocSkip(absFilename)) { - success = this->ParseContentForMoc( - absFilename, contentsString, headerExtensions, mocsIncluded, relaxed); + success = this->ParseContentForMoc(absFilename, contentsString, + mocsIncluded, relaxed); } // Parse source contents for UIC if (success && !this->UicSkip(absFilename)) { @@ -741,7 +738,6 @@ void cmQtAutoGenerators::ParseContentForUic( */ bool cmQtAutoGenerators::ParseContentForMoc( const std::string& absFilename, const std::string& contentsString, - const std::vector<std::string>& headerExtensions, std::map<std::string, std::string>& mocsIncluded, bool relaxed) { if (this->Verbose) { @@ -789,8 +785,8 @@ bool cmQtAutoGenerators::ParseContentForMoc( // Include: moc_FOO.cxx // Remove the moc_ part const std::string incRealBasename = incBasename.substr(4); - const std::string headerToMoc = FindMatchingHeader( - scannedFileAbsPath, incRealBasename, incSubDir, headerExtensions); + const std::string headerToMoc = this->FindMatchingHeader( + scannedFileAbsPath, incRealBasename, incSubDir); if (!headerToMoc.empty()) { mocsIncluded[headerToMoc] = incString; if (relaxed && (incRealBasename == scannedFileBasename)) { @@ -803,7 +799,7 @@ bool cmQtAutoGenerators::ParseContentForMoc( err << "AutoMoc: Error: " << absFilename << "\n" << "The file includes the moc file \"" << incString << "\", but could not find header \"" << incRealBasename << '{' - << JoinExts(headerExtensions) << "}\"\n"; + << JoinExts(this->HeaderExtensions) << "}\"\n"; this->LogError(err.str()); return false; } @@ -813,8 +809,8 @@ bool cmQtAutoGenerators::ParseContentForMoc( if (relaxed) { // Mode: Relaxed if (!requiresMoc || (incBasename != scannedFileBasename)) { - const std::string headerToMoc = FindMatchingHeader( - scannedFileAbsPath, incBasename, incSubDir, headerExtensions); + const std::string headerToMoc = this->FindMatchingHeader( + scannedFileAbsPath, incBasename, incSubDir); if (!headerToMoc.empty()) { // This is for KDE4 compatibility: fileToMoc = headerToMoc; @@ -922,9 +918,8 @@ bool cmQtAutoGenerators::ParseContentForMoc( } void cmQtAutoGenerators::SearchHeadersForSourceFile( - const std::string& absFilename, - const std::vector<std::string>& headerExtensions, - std::set<std::string>& mocHeaderFiles, std::set<std::string>& uicHeaderFiles) + const std::string& absFilename, std::set<std::string>& mocHeaderFiles, + std::set<std::string>& uicHeaderFiles) const { std::string basepaths[2]; { @@ -941,8 +936,8 @@ void cmQtAutoGenerators::SearchHeadersForSourceFile( for (const std::string* bpit = cmArrayBegin(basepaths); bpit != cmArrayEnd(basepaths); ++bpit) { for (std::vector<std::string>::const_iterator heit = - headerExtensions.begin(); - heit != headerExtensions.end(); ++heit) { + this->HeaderExtensions.begin(); + heit != this->HeaderExtensions.end(); ++heit) { const std::string hname = (*bpit) + (*heit); if (cmsys::SystemTools::FileExists(hname.c_str())) { // Moc headers @@ -1588,12 +1583,12 @@ std::string cmQtAutoGenerators::ChecksumedPath(const std::string& sourceFile, * appending different header extensions * @return True on success */ -bool cmQtAutoGenerators::FindHeader( - std::string& header, const std::string& testBasePath, - const std::vector<std::string>& headerExtensions) const +bool cmQtAutoGenerators::FindHeader(std::string& header, + const std::string& testBasePath) const { - for (std::vector<std::string>::const_iterator ext = headerExtensions.begin(); - ext != headerExtensions.end(); ++ext) { + for (std::vector<std::string>::const_iterator ext = + this->HeaderExtensions.begin(); + ext != this->HeaderExtensions.end(); ++ext) { std::string testFilePath(testBasePath); testFilePath += '.'; testFilePath += (*ext); @@ -1607,17 +1602,16 @@ bool cmQtAutoGenerators::FindHeader( std::string cmQtAutoGenerators::FindMatchingHeader( const std::string& basePath, const std::string& baseName, - const std::string& subDir, - const std::vector<std::string>& headerExtensions) const + const std::string& subDir) const { std::string header; do { if (!subDir.empty()) { - if (FindHeader(header, basePath + subDir + baseName, headerExtensions)) { + if (this->FindHeader(header, basePath + subDir + baseName)) { break; } } - if (FindHeader(header, basePath + baseName, headerExtensions)) { + if (this->FindHeader(header, basePath + baseName)) { break; } } while (false); diff --git a/Source/cmQtAutoGenerators.h b/Source/cmQtAutoGenerators.h index 50df9f8..e6f9160 100644 --- a/Source/cmQtAutoGenerators.h +++ b/Source/cmQtAutoGenerators.h @@ -42,26 +42,23 @@ private: } // - Init and run - void Init(); - bool RunAutogen(cmMakefile* makefile); + void Init(cmMakefile* makefile); + bool RunAutogen(); // - Content analysis bool MocRequired(const std::string& text, std::string& macroName); - bool MocSkip(const std::string& absFilename); - bool UicSkip(const std::string& absFilename); + bool MocSkip(const std::string& absFilename) const; + bool UicSkip(const std::string& absFilename) const; bool ParseSourceFile( const std::string& absFilename, - const std::vector<std::string>& headerExtensions, std::map<std::string, std::string>& includedMocs, std::map<std::string, std::vector<std::string> >& includedUis, bool relaxed); - void SearchHeadersForSourceFile( - const std::string& absFilename, - const std::vector<std::string>& headerExtensions, - std::set<std::string>& absHeadersMoc, - std::set<std::string>& absHeadersUic); + void SearchHeadersForSourceFile(const std::string& absFilename, + std::set<std::string>& absHeadersMoc, + std::set<std::string>& absHeadersUic) const; void ParseHeaders( const std::set<std::string>& absHeadersMoc, @@ -76,7 +73,6 @@ private: bool ParseContentForMoc(const std::string& absFilename, const std::string& contentsString, - const std::vector<std::string>& headerExtensions, std::map<std::string, std::string>& includedMocs, bool relaxed); @@ -119,12 +115,10 @@ private: const char* baseSuffix) const; bool MakeParentDirectory(const std::string& filename); - bool FindHeader(std::string& header, const std::string& testBasePath, - const std::vector<std::string>& headerExtensions) const; - std::string FindMatchingHeader( - const std::string& basePath, const std::string& baseName, - const std::string& subDir, - const std::vector<std::string>& headerExtensions) const; + bool FindHeader(std::string& header, const std::string& testBasePath) const; + std::string FindMatchingHeader(const std::string& basePath, + const std::string& baseName, + const std::string& subDir) const; // - Target names std::string OriginTargetName; @@ -165,6 +159,7 @@ private: std::map<std::string, std::vector<std::string> > RccInputs; // - Utility cmFilePathChecksum fpathCheckSum; + std::vector<std::string> HeaderExtensions; cmsys::RegularExpression RegExpQObject; cmsys::RegularExpression RegExpQGadget; cmsys::RegularExpression RegExpMocInclude; |