|
|
|
/*============================================================================
|
|
|
|
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->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;
|
|
|
|
}
|
|
|
|
|
|
|
|
|