cmake/Source/cmExportTryCompileFileGenerator.cxx

153 lines
4.8 KiB
C++
Raw Normal View History

2013-03-16 19:13:01 +02: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"
2015-11-17 17:22:37 +01:00
#include "cmGlobalGenerator.h"
2016-03-13 13:35:51 +01:00
#include "cmLocalGenerator.h"
2013-03-16 19:13:01 +02:00
#include "cmGeneratorExpressionDAGChecker.h"
//----------------------------------------------------------------------------
2015-11-17 17:22:37 +01:00
cmExportTryCompileFileGenerator::cmExportTryCompileFileGenerator(
2016-03-13 13:35:51 +01:00
cmGlobalGenerator* gg,
const std::vector<std::string>& targets,
cmMakefile* mf)
2015-11-17 17:22:37 +01:00
{
2016-03-13 13:35:51 +01:00
gg->CreateImportedGenerationObjects(mf, targets, this->Exports);
2015-11-17 17:22:37 +01:00
}
2013-03-16 19:13:01 +02:00
bool cmExportTryCompileFileGenerator::GenerateMainFile(std::ostream& os)
{
2016-03-13 13:35:51 +01:00
std::set<cmGeneratorTarget const*> emitted;
std::set<cmGeneratorTarget const*> emittedDeps;
2013-03-16 19:13:01 +02:00
while(!this->Exports.empty())
{
2016-03-13 13:35:51 +01:00
cmGeneratorTarget const* te = this->Exports.back();
2013-03-16 19:13:01 +02:00
this->Exports.pop_back();
if (emitted.insert(te).second)
{
emittedDeps.insert(te);
this->GenerateImportTargetCode(os, te);
ImportPropertyMap properties;
2013-11-03 12:27:13 +02:00
#define FIND_TARGETS(PROPERTY) \
2014-08-03 19:52:23 +02:00
this->FindTargets("INTERFACE_" #PROPERTY, te, emittedDeps);
2013-11-03 12:27:13 +02:00
CM_FOR_EACH_TRANSITIVE_PROPERTY_NAME(FIND_TARGETS)
2013-03-16 19:13:01 +02:00
2014-08-03 19:52:23 +02:00
#undef FIND_TARGETS
2013-03-16 19:13:01 +02:00
this->PopulateProperties(te, properties, emittedDeps);
this->GenerateInterfaceProperties(te, os, properties);
}
}
return true;
}
2015-04-27 22:25:09 +02:00
std::string cmExportTryCompileFileGenerator::FindTargets(
2016-03-13 13:35:51 +01:00
const std::string& propName,
cmGeneratorTarget const* tgt,
std::set<cmGeneratorTarget const*> &emitted)
2013-03-16 19:13:01 +02:00
{
const char *prop = tgt->GetProperty(propName);
if(!prop)
{
return std::string();
}
2015-04-27 22:25:09 +02:00
cmGeneratorExpression ge;
2013-03-16 19:13:01 +02:00
2015-04-27 22:25:09 +02:00
cmGeneratorExpressionDAGChecker dagChecker(
2013-03-16 19:13:01 +02:00
tgt->GetName(),
propName, 0, 0);
cmsys::auto_ptr<cmCompiledGeneratorExpression> cge = ge.Parse(prop);
cmTarget dummyHead;
2016-03-13 13:35:51 +01:00
dummyHead.SetType(cmState::EXECUTABLE, "try_compile_dummy_exe");
dummyHead.SetMakefile(tgt->Target->GetMakefile());
2013-03-16 19:13:01 +02:00
2016-03-13 13:35:51 +01:00
cmGeneratorTarget gDummyHead(&dummyHead, tgt->GetLocalGenerator());
2013-03-16 19:13:01 +02:00
2016-03-13 13:35:51 +01:00
std::string result = cge->Evaluate(tgt->GetLocalGenerator(), this->Config,
false, &gDummyHead,
tgt, &dagChecker);
const std::set<cmGeneratorTarget const*> &allTargets =
cge->GetAllTargetsSeen();
for(std::set<cmGeneratorTarget const*>::const_iterator li =
allTargets.begin(); li != allTargets.end(); ++li)
2013-03-16 19:13:01 +02:00
{
if(emitted.insert(*li).second)
{
this->Exports.push_back(*li);
}
}
return result;
}
//----------------------------------------------------------------------------
void
2016-03-13 13:35:51 +01:00
cmExportTryCompileFileGenerator::PopulateProperties(
const cmGeneratorTarget* target,
ImportPropertyMap& properties,
std::set<cmGeneratorTarget const*> &emitted)
2013-03-16 19:13:01 +02:00
{
2016-03-13 13:35:51 +01:00
std::vector<std::string> props = target->GetPropertyKeys();
for(std::vector<std::string>::const_iterator i = props.begin();
i != props.end(); ++i)
2013-03-16 19:13:01 +02:00
{
2016-03-13 13:35:51 +01:00
properties[*i] = target->GetProperty(*i);
if(i->find("IMPORTED_LINK_INTERFACE_LIBRARIES") == 0
|| i->find("IMPORTED_LINK_DEPENDENT_LIBRARIES") == 0
|| i->find("INTERFACE_LINK_LIBRARIES") == 0)
2013-03-16 19:13:01 +02:00
{
2016-03-13 13:35:51 +01:00
std::string evalResult = this->FindTargets(*i,
2013-03-16 19:13:01 +02:00
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)
{
2016-03-13 13:35:51 +01:00
cmGeneratorTarget *tgt =
target->GetLocalGenerator()->FindGeneratorTargetToUse(*li);
2013-03-16 19:13:01 +02:00
if(tgt && emitted.insert(tgt).second)
{
this->Exports.push_back(tgt);
}
}
}
}
}
2015-11-17 17:22:37 +01:00
2013-11-03 12:27:13 +02:00
std::string
2015-11-17 17:22:37 +01:00
cmExportTryCompileFileGenerator::InstallNameDir(cmGeneratorTarget* target,
2013-11-03 12:27:13 +02:00
const std::string& config)
{
std::string install_name_dir;
2015-11-17 17:22:37 +01:00
cmMakefile* mf = target->Target->GetMakefile();
2013-11-03 12:27:13 +02:00
if(mf->IsOn("CMAKE_PLATFORM_HAS_INSTALLNAME"))
{
install_name_dir =
2015-04-27 22:25:09 +02:00
target->GetInstallNameDirForBuildTree(config);
2013-11-03 12:27:13 +02:00
}
return install_name_dir;
}