2015-07-07 23:37:56 +03:00
|
|
|
/*============================================================================
|
|
|
|
CMake - Cross Platform Makefile Generator
|
|
|
|
Copyright 2000-2015 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 "cmLocalCommonGenerator.h"
|
|
|
|
|
2015-07-08 18:27:22 +03:00
|
|
|
#include "cmMakefile.h"
|
|
|
|
|
2016-06-16 17:54:20 +03:00
|
|
|
cmLocalCommonGenerator::cmLocalCommonGenerator(
|
|
|
|
cmGlobalGenerator* gg, cmMakefile* mf, cmOutputConverter::RelativeRoot wd)
|
2016-05-16 17:34:04 +03:00
|
|
|
: cmLocalGenerator(gg, mf)
|
2016-06-16 17:54:20 +03:00
|
|
|
, WorkingDirectory(wd)
|
2015-07-07 23:37:56 +03:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
cmLocalCommonGenerator::~cmLocalCommonGenerator()
|
|
|
|
{
|
|
|
|
}
|
2015-07-08 18:27:22 +03:00
|
|
|
|
|
|
|
void cmLocalCommonGenerator::SetConfigName()
|
|
|
|
{
|
|
|
|
// Store the configuration name that will be generated.
|
2016-05-16 17:34:04 +03:00
|
|
|
if (const char* config = this->Makefile->GetDefinition("CMAKE_BUILD_TYPE")) {
|
2015-07-08 18:27:22 +03:00
|
|
|
// Use the build type given by the user.
|
|
|
|
this->ConfigName = config;
|
2016-05-16 17:34:04 +03:00
|
|
|
} else {
|
2015-07-08 18:27:22 +03:00
|
|
|
// No configuration type given.
|
|
|
|
this->ConfigName = "";
|
2016-05-16 17:34:04 +03:00
|
|
|
}
|
2015-07-08 18:27:22 +03:00
|
|
|
}
|
2016-06-16 18:14:18 +03:00
|
|
|
|
|
|
|
std::string cmLocalCommonGenerator::GetTargetFortranFlags(
|
|
|
|
cmGeneratorTarget const* target, std::string const& config)
|
|
|
|
{
|
|
|
|
std::string flags;
|
|
|
|
|
|
|
|
// Enable module output if necessary.
|
|
|
|
if (const char* modout_flag =
|
|
|
|
this->Makefile->GetDefinition("CMAKE_Fortran_MODOUT_FLAG")) {
|
|
|
|
this->AppendFlags(flags, modout_flag);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add a module output directory flag if necessary.
|
|
|
|
std::string mod_dir = target->GetFortranModuleDirectory();
|
|
|
|
if (!mod_dir.empty()) {
|
|
|
|
mod_dir =
|
|
|
|
this->Convert(mod_dir, this->WorkingDirectory, cmOutputConverter::SHELL);
|
|
|
|
} else {
|
|
|
|
mod_dir =
|
|
|
|
this->Makefile->GetSafeDefinition("CMAKE_Fortran_MODDIR_DEFAULT");
|
|
|
|
}
|
|
|
|
if (!mod_dir.empty()) {
|
|
|
|
const char* moddir_flag =
|
|
|
|
this->Makefile->GetRequiredDefinition("CMAKE_Fortran_MODDIR_FLAG");
|
|
|
|
std::string modflag = moddir_flag;
|
|
|
|
modflag += mod_dir;
|
|
|
|
this->AppendFlags(flags, modflag);
|
|
|
|
}
|
|
|
|
|
|
|
|
// If there is a separate module path flag then duplicate the
|
|
|
|
// include path with it. This compiler does not search the include
|
|
|
|
// path for modules.
|
|
|
|
if (const char* modpath_flag =
|
|
|
|
this->Makefile->GetDefinition("CMAKE_Fortran_MODPATH_FLAG")) {
|
|
|
|
std::vector<std::string> includes;
|
|
|
|
this->GetIncludeDirectories(includes, target, "C", config);
|
|
|
|
for (std::vector<std::string>::const_iterator idi = includes.begin();
|
|
|
|
idi != includes.end(); ++idi) {
|
|
|
|
std::string flg = modpath_flag;
|
|
|
|
flg +=
|
|
|
|
this->Convert(*idi, cmOutputConverter::NONE, cmOutputConverter::SHELL);
|
|
|
|
this->AppendFlags(flags, flg);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return flags;
|
|
|
|
}
|