/*============================================================================ CMake - Cross Platform Makefile Generator Copyright 2000-2009 Kitware, Inc., Insight Software Consortium Distributed under the OSI-approved BSD License (the "License"); see accompanying file Copyright.txt for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the License for more information. ============================================================================*/ #include "cmIncludeCommand.h" // cmIncludeCommand bool cmIncludeCommand ::InitialPass(std::vector<std::string> const& args, cmExecutionStatus &) { if (args.size()< 1 || args.size() > 4) { this->SetError("called with wrong number of arguments. " "include() only takes one file."); return false; } bool optional = false; bool noPolicyScope = false; std::string fname = args[0]; std::string resultVarName; for (unsigned int i=1; i<args.size(); i++) { if (args[i] == "OPTIONAL") { if (optional) { this->SetError("called with invalid arguments: OPTIONAL used twice"); return false; } optional = true; } else if(args[i] == "RESULT_VARIABLE") { if (!resultVarName.empty()) { this->SetError("called with invalid arguments: " "only one result variable allowed"); return false; } if(++i < args.size()) { resultVarName = args[i]; } else { this->SetError("called with no value for RESULT_VARIABLE."); return false; } } else if(args[i] == "NO_POLICY_SCOPE") { noPolicyScope = true; } else if(i > 1) // compat.: in previous cmake versions the second // parameter was ignored if it wasn't "OPTIONAL" { std::string errorText = "called with invalid argument: "; errorText += args[i]; this->SetError(errorText); return false; } } if(fname.empty()) { this->Makefile->IssueMessage(cmake::AUTHOR_WARNING, "include() given empty file name (ignored)."); return true; } if(!cmSystemTools::FileIsFullPath(fname.c_str())) { // Not a path. Maybe module. std::string module = fname; module += ".cmake"; std::string mfile = this->Makefile->GetModulesFile(module.c_str()); if (!mfile.empty()) { fname = mfile.c_str(); } } std::string fname_abs = cmSystemTools::CollapseFullPath(fname, this->Makefile->GetCurrentSourceDirectory()); cmGlobalGenerator *gg = this->Makefile->GetGlobalGenerator(); if (gg->IsExportedTargetsFile(fname_abs)) { const char *modal = 0; std::ostringstream e; cmake::MessageType messageType = cmake::AUTHOR_WARNING; switch(this->Makefile->GetPolicyStatus(cmPolicies::CMP0024)) { case cmPolicies::WARN: e << cmPolicies::GetPolicyWarning(cmPolicies::CMP0024) << "\n"; modal = "should"; case cmPolicies::OLD: break; case cmPolicies::REQUIRED_IF_USED: case cmPolicies::REQUIRED_ALWAYS: case cmPolicies::NEW: modal = "may"; messageType = cmake::FATAL_ERROR; } if (modal) { e << "The file\n " << fname_abs << "\nwas generated by the export() " "command. It " << modal << " not be used as the argument to the " "include() command. Use ALIAS targets instead to refer to targets " "by alternative names.\n"; this->Makefile->IssueMessage(messageType, e.str()); if (messageType == cmake::FATAL_ERROR) { return false; } } gg->CreateGenerationObjects(); gg->GenerateImportFile(fname_abs); } std::string listFile = cmSystemTools::CollapseFullPath(fname.c_str(), this->Makefile->GetCurrentSourceDirectory()); if(optional && !cmSystemTools::FileExists(listFile.c_str())) { if (!resultVarName.empty()) { this->Makefile->AddDefinition(resultVarName, "NOTFOUND"); } return true; } bool readit = this->Makefile->ReadDependentFile(listFile.c_str(), noPolicyScope); // add the location of the included file if a result variable was given if (!resultVarName.empty()) { this->Makefile->AddDefinition(resultVarName, readit?fname_abs.c_str():"NOTFOUND"); } if(!optional && !readit && !cmSystemTools::GetFatalErrorOccured()) { std::string m = "could not find load file:\n" " "; m += fname; this->SetError(m); return false; } return true; }