summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2019-07-08 15:33:02 (GMT)
committerBrad King <brad.king@kitware.com>2019-07-08 15:33:02 (GMT)
commit1555837ccbdee95cedb9a5ba0e617a62fe74b9a3 (patch)
tree45ef4f3d62349d86d4103f5bac0b8f8059d57355
parent12e46dc413193c42589918bc588b5a41774329a8 (diff)
parentb0bcd4d7d2cb9defb790514375b78efbf60cc2e8 (diff)
downloadCMake-1555837ccbdee95cedb9a5ba0e617a62fe74b9a3.zip
CMake-1555837ccbdee95cedb9a5ba0e617a62fe74b9a3.tar.gz
CMake-1555837ccbdee95cedb9a5ba0e617a62fe74b9a3.tar.bz2
Merge branch 'fortran-submodule-cray' into release-3.15
Merge-request: !3504
-rw-r--r--Modules/Compiler/Cray-Fortran.cmake2
-rw-r--r--Source/cmFortranParserImpl.cxx8
2 files changed, 9 insertions, 1 deletions
diff --git a/Modules/Compiler/Cray-Fortran.cmake b/Modules/Compiler/Cray-Fortran.cmake
index dbf28e3..ccb7c2e 100644
--- a/Modules/Compiler/Cray-Fortran.cmake
+++ b/Modules/Compiler/Cray-Fortran.cmake
@@ -4,6 +4,8 @@
include(Compiler/Cray)
__compiler_cray(Fortran)
+set(CMAKE_Fortran_SUBMODULE_SEP "")
+set(CMAKE_Fortran_SUBMODULE_EXT ".mod")
set(CMAKE_Fortran_MODOUT_FLAG -em)
set(CMAKE_Fortran_MODDIR_FLAG -J)
set(CMAKE_Fortran_MODDIR_DEFAULT .)
diff --git a/Source/cmFortranParserImpl.cxx b/Source/cmFortranParserImpl.cxx
index 18e3c10..e8b1da8 100644
--- a/Source/cmFortranParserImpl.cxx
+++ b/Source/cmFortranParserImpl.cxx
@@ -79,7 +79,13 @@ std::string cmFortranParser_s::ModName(std::string const& mod_name) const
std::string cmFortranParser_s::SModName(std::string const& mod_name,
std::string const& sub_name) const
{
- return mod_name + this->Compiler.SModSep + sub_name + this->Compiler.SModExt;
+ std::string const& SModExt =
+ this->Compiler.SModExt.empty() ? ".mod" : this->Compiler.SModExt;
+ // An empty separator means that the compiler does not use a prefix.
+ if (this->Compiler.SModSep.empty()) {
+ return sub_name + SModExt;
+ }
+ return mod_name + this->Compiler.SModSep + sub_name + SModExt;
}
bool cmFortranParser_FilePush(cmFortranParser* parser, const char* fname)