cmLocalCommonGenerator.cxx 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. file Copyright.txt or https://cmake.org/licensing for details. */
  3. #include "cmLocalCommonGenerator.h"
  4. #include <vector>
  5. #include "cmGeneratorTarget.h"
  6. #include "cmMakefile.h"
  7. #include "cmOutputConverter.h"
  8. class cmGlobalGenerator;
  9. cmLocalCommonGenerator::cmLocalCommonGenerator(cmGlobalGenerator* gg,
  10. cmMakefile* mf,
  11. std::string const& wd)
  12. : cmLocalGenerator(gg, mf)
  13. , WorkingDirectory(wd)
  14. {
  15. }
  16. cmLocalCommonGenerator::~cmLocalCommonGenerator()
  17. {
  18. }
  19. void cmLocalCommonGenerator::SetConfigName()
  20. {
  21. // Store the configuration name that will be generated.
  22. if (const char* config = this->Makefile->GetDefinition("CMAKE_BUILD_TYPE")) {
  23. // Use the build type given by the user.
  24. this->ConfigName = config;
  25. } else {
  26. // No configuration type given.
  27. this->ConfigName = "";
  28. }
  29. }
  30. std::string cmLocalCommonGenerator::GetTargetFortranFlags(
  31. cmGeneratorTarget const* target, std::string const& config)
  32. {
  33. std::string flags;
  34. // Enable module output if necessary.
  35. if (const char* modout_flag =
  36. this->Makefile->GetDefinition("CMAKE_Fortran_MODOUT_FLAG")) {
  37. this->AppendFlags(flags, modout_flag);
  38. }
  39. // Add a module output directory flag if necessary.
  40. std::string mod_dir =
  41. target->GetFortranModuleDirectory(this->WorkingDirectory);
  42. if (!mod_dir.empty()) {
  43. mod_dir = this->ConvertToOutputFormat(
  44. this->ConvertToRelativePath(this->WorkingDirectory, mod_dir),
  45. cmOutputConverter::SHELL);
  46. } else {
  47. mod_dir =
  48. this->Makefile->GetSafeDefinition("CMAKE_Fortran_MODDIR_DEFAULT");
  49. }
  50. if (!mod_dir.empty()) {
  51. const char* moddir_flag =
  52. this->Makefile->GetRequiredDefinition("CMAKE_Fortran_MODDIR_FLAG");
  53. std::string modflag = moddir_flag;
  54. modflag += mod_dir;
  55. this->AppendFlags(flags, modflag);
  56. }
  57. // If there is a separate module path flag then duplicate the
  58. // include path with it. This compiler does not search the include
  59. // path for modules.
  60. if (const char* modpath_flag =
  61. this->Makefile->GetDefinition("CMAKE_Fortran_MODPATH_FLAG")) {
  62. std::vector<std::string> includes;
  63. this->GetIncludeDirectories(includes, target, "C", config);
  64. for (std::vector<std::string>::const_iterator idi = includes.begin();
  65. idi != includes.end(); ++idi) {
  66. std::string flg = modpath_flag;
  67. flg += this->ConvertToOutputFormat(*idi, cmOutputConverter::SHELL);
  68. this->AppendFlags(flags, flg);
  69. }
  70. }
  71. return flags;
  72. }