2013-02-07 20:36:29 +04:00
|
|
|
/*============================================================================
|
|
|
|
CMake - Cross Platform Makefile Generator
|
|
|
|
Copyright 2013 Stephen Kelly <steveire@gmail.com>
|
|
|
|
|
|
|
|
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 "cmExportTryCompileFileGenerator.h"
|
|
|
|
|
|
|
|
#include "cmGeneratedFileStream.h"
|
|
|
|
#include "cmGeneratorExpressionDAGChecker.h"
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
bool cmExportTryCompileFileGenerator::GenerateMainFile(std::ostream& os)
|
|
|
|
{
|
2013-10-30 01:21:20 +04:00
|
|
|
std::set<cmTarget const*> emitted;
|
|
|
|
std::set<cmTarget const*> emittedDeps;
|
2013-02-07 20:36:29 +04:00
|
|
|
while(!this->Exports.empty())
|
|
|
|
{
|
2013-10-30 01:21:20 +04:00
|
|
|
cmTarget const* te = this->Exports.back();
|
2013-02-07 20:36:29 +04:00
|
|
|
this->Exports.pop_back();
|
|
|
|
if (emitted.insert(te).second)
|
|
|
|
{
|
|
|
|
emittedDeps.insert(te);
|
|
|
|
this->GenerateImportTargetCode(os, te);
|
|
|
|
|
|
|
|
ImportPropertyMap properties;
|
|
|
|
|
2013-06-10 18:01:59 +04:00
|
|
|
#define FIND_TARGETS(PROPERTY) \
|
2013-10-29 12:22:32 +04:00
|
|
|
this->FindTargets("INTERFACE_" #PROPERTY, te, emittedDeps);
|
2013-06-10 18:01:59 +04:00
|
|
|
|
|
|
|
CM_FOR_EACH_TRANSITIVE_PROPERTY_NAME(FIND_TARGETS)
|
2013-02-07 20:36:29 +04:00
|
|
|
|
2013-12-31 17:34:16 +04:00
|
|
|
#undef FIND_TARGETS
|
|
|
|
|
2013-02-07 20:36:29 +04:00
|
|
|
this->PopulateProperties(te, properties, emittedDeps);
|
|
|
|
|
|
|
|
this->GenerateInterfaceProperties(te, os, properties);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string cmExportTryCompileFileGenerator::FindTargets(const char *propName,
|
2013-10-30 01:21:20 +04:00
|
|
|
cmTarget const* tgt,
|
|
|
|
std::set<cmTarget const*> &emitted)
|
2013-02-07 20:36:29 +04:00
|
|
|
{
|
|
|
|
const char *prop = tgt->GetProperty(propName);
|
|
|
|
if(!prop)
|
|
|
|
{
|
|
|
|
return std::string();
|
|
|
|
}
|
|
|
|
|
|
|
|
cmListFileBacktrace lfbt;
|
|
|
|
cmGeneratorExpression ge(lfbt);
|
|
|
|
|
|
|
|
cmGeneratorExpressionDAGChecker dagChecker(lfbt,
|
|
|
|
tgt->GetName(),
|
|
|
|
propName, 0, 0);
|
|
|
|
|
|
|
|
cmsys::auto_ptr<cmCompiledGeneratorExpression> cge = ge.Parse(prop);
|
|
|
|
|
|
|
|
cmTarget dummyHead;
|
|
|
|
dummyHead.SetType(cmTarget::EXECUTABLE, "try_compile_dummy_exe");
|
|
|
|
dummyHead.SetMakefile(tgt->GetMakefile());
|
|
|
|
|
|
|
|
std::string result = cge->Evaluate(tgt->GetMakefile(), this->Config,
|
|
|
|
false, &dummyHead, tgt, &dagChecker);
|
|
|
|
|
2013-10-30 01:21:20 +04:00
|
|
|
const std::set<cmTarget const*> &allTargets = cge->GetAllTargetsSeen();
|
|
|
|
for(std::set<cmTarget const*>::const_iterator li = allTargets.begin();
|
2013-02-07 20:36:29 +04:00
|
|
|
li != allTargets.end(); ++li)
|
|
|
|
{
|
|
|
|
if(emitted.insert(*li).second)
|
|
|
|
{
|
|
|
|
this->Exports.push_back(*li);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
void
|
2013-10-30 01:21:20 +04:00
|
|
|
cmExportTryCompileFileGenerator::PopulateProperties(cmTarget const* target,
|
2013-02-07 20:36:29 +04:00
|
|
|
ImportPropertyMap& properties,
|
2013-10-30 01:21:20 +04:00
|
|
|
std::set<cmTarget const*> &emitted)
|
2013-02-07 20:36:29 +04:00
|
|
|
{
|
|
|
|
cmPropertyMap props = target->GetProperties();
|
|
|
|
for(cmPropertyMap::const_iterator i = props.begin(); i != props.end(); ++i)
|
|
|
|
{
|
|
|
|
properties[i->first] = i->second.GetValue();
|
|
|
|
|
2013-08-19 13:57:13 +04:00
|
|
|
if(i->first.find("IMPORTED_LINK_INTERFACE_LIBRARIES") == 0
|
2013-08-21 10:55:30 +04:00
|
|
|
|| i->first.find("IMPORTED_LINK_DEPENDENT_LIBRARIES") == 0
|
|
|
|
|| i->first.find("INTERFACE_LINK_LIBRARIES") == 0)
|
2013-02-07 20:36:29 +04:00
|
|
|
{
|
|
|
|
const std::string libs = i->second.GetValue();
|
|
|
|
|
|
|
|
std::string evalResult = this->FindTargets(i->first.c_str(),
|
|
|
|
target, emitted);
|
|
|
|
|
|
|
|
std::vector<std::string> depends;
|
|
|
|
cmSystemTools::ExpandListArgument(evalResult, depends);
|
|
|
|
for(std::vector<std::string>::const_iterator li = depends.begin();
|
|
|
|
li != depends.end(); ++li)
|
|
|
|
{
|
2014-01-16 02:56:38 +04:00
|
|
|
cmTarget *tgt = target->GetMakefile()->FindTargetToUse(*li);
|
2013-02-07 20:36:29 +04:00
|
|
|
if(tgt && emitted.insert(tgt).second)
|
|
|
|
{
|
|
|
|
this->Exports.push_back(tgt);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-05-21 02:57:58 +04:00
|
|
|
std::string
|
|
|
|
cmExportTryCompileFileGenerator::InstallNameDir(cmTarget* target,
|
|
|
|
const std::string& config)
|
|
|
|
{
|
|
|
|
std::string install_name_dir;
|
|
|
|
|
|
|
|
cmMakefile* mf = target->GetMakefile();
|
|
|
|
if(mf->IsOn("CMAKE_PLATFORM_HAS_INSTALLNAME"))
|
|
|
|
{
|
|
|
|
install_name_dir =
|
|
|
|
target->GetInstallNameDirForBuildTree(config.c_str());
|
|
|
|
}
|
|
|
|
|
|
|
|
return install_name_dir;
|
|
|
|
}
|