diff options
author | Ruslan Baratov <ruslan_baratov@yahoo.com> | 2019-03-27 19:36:51 (GMT) |
---|---|---|
committer | Ruslan Baratov <ruslan_baratov@yahoo.com> | 2019-03-27 19:39:02 (GMT) |
commit | dda01904587627a3d2bda5b684f7bef1e62596bb (patch) | |
tree | 34b65ed71c604b1aaf6e46e92d15b7cebb66d1b8 /Source | |
parent | 390f14a24416f23801f5644eb51590f8317d35c7 (diff) | |
download | CMake-dda01904587627a3d2bda5b684f7bef1e62596bb.zip CMake-dda01904587627a3d2bda5b684f7bef1e62596bb.tar.gz CMake-dda01904587627a3d2bda5b684f7bef1e62596bb.tar.bz2 |
project: Add variable CMAKE_PROJECT_INCLUDE
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmProjectCommand.cxx | 42 | ||||
-rw-r--r-- | Source/cmProjectCommand.h | 1 |
2 files changed, 32 insertions, 11 deletions
diff --git a/Source/cmProjectCommand.cxx b/Source/cmProjectCommand.cxx index 2fe9fe8..de5d1ed 100644 --- a/Source/cmProjectCommand.cxx +++ b/Source/cmProjectCommand.cxx @@ -319,21 +319,41 @@ bool cmProjectCommand::InitialPass(std::vector<std::string> const& args, languages.emplace_back("CXX"); } this->Makefile->EnableLanguage(languages, false); - std::string extraInclude = "CMAKE_PROJECT_" + projectName + "_INCLUDE"; - const char* include = this->Makefile->GetDefinition(extraInclude); - if (include) { - bool readit = this->Makefile->ReadDependentFile(include); - if (!readit && !cmSystemTools::GetFatalErrorOccured()) { - std::string m = "could not find file:\n" - " "; - m += include; - this->SetError(m); - return false; - } + + if (!this->IncludeByVariable("CMAKE_PROJECT_INCLUDE")) { + return false; + } + + if (!this->IncludeByVariable("CMAKE_PROJECT_" + projectName + "_INCLUDE")) { + return false; } + return true; } +bool cmProjectCommand::IncludeByVariable(const std::string& variable) +{ + const char* include = this->Makefile->GetDefinition(variable); + if (!include) { + return true; + } + + const bool readit = this->Makefile->ReadDependentFile(include); + if (readit) { + return true; + } + + if (cmSystemTools::GetFatalErrorOccured()) { + return true; + } + + std::string m = "could not find file:\n" + " "; + m += include; + this->SetError(m); + return false; +} + void cmProjectCommand::TopLevelCMakeVarCondSet(const char* const name, const char* const value) { diff --git a/Source/cmProjectCommand.h b/Source/cmProjectCommand.h index 365d448..f1d03e7 100644 --- a/Source/cmProjectCommand.h +++ b/Source/cmProjectCommand.h @@ -36,6 +36,7 @@ public: cmExecutionStatus& status) override; private: + bool IncludeByVariable(const std::string& variable); void TopLevelCMakeVarCondSet(const char* name, const char* value); }; |