summaryrefslogtreecommitdiffstats
path: root/Source/cmGlobalGenerator.cxx
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2005-01-20 17:28:57 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2005-01-20 17:28:57 (GMT)
commitbeb584e7a1d73901d1b0494e5c60d25df6d6ef68 (patch)
treeb34ffc37c20bb48b3a63a7b3d3c1e8e8fc9273a8 /Source/cmGlobalGenerator.cxx
parent4d31557dcb9c2e515232b61073fb55a7827d4c2e (diff)
downloadCMake-beb584e7a1d73901d1b0494e5c60d25df6d6ef68.zip
CMake-beb584e7a1d73901d1b0494e5c60d25df6d6ef68.tar.gz
CMake-beb584e7a1d73901d1b0494e5c60d25df6d6ef68.tar.bz2
ENH: add some comments on how this could be moved to global generator
Diffstat (limited to 'Source/cmGlobalGenerator.cxx')
-rw-r--r--Source/cmGlobalGenerator.cxx41
1 files changed, 40 insertions, 1 deletions
diff --git a/Source/cmGlobalGenerator.cxx b/Source/cmGlobalGenerator.cxx
index 6b02c96..753221d 100644
--- a/Source/cmGlobalGenerator.cxx
+++ b/Source/cmGlobalGenerator.cxx
@@ -137,6 +137,15 @@ void cmGlobalGenerator::EnableLanguage(std::vector<std::string>const& languages,
dst2 += "/CMake";
dst2 += lang;
dst2 += "Compiler.cmake";
+ cmSystemTools::CopyFileIfDifferent(src2.c_str(), dst2.c_str());
+ src2 = m_ConfiguredFilesPath;
+ src2 += "/CMake";
+ src2 += lang;
+ src2 += "Platform.cmake";
+ dst2 = rootBin;
+ dst2 += "/CMake";
+ dst2 += lang;
+ dst2 += "Platform.cmake";
cmSystemTools::CopyFileIfDifferent(src2.c_str(), dst2.c_str());
}
rootBin = m_ConfiguredFilesPath;
@@ -145,6 +154,16 @@ void cmGlobalGenerator::EnableLanguage(std::vector<std::string>const& languages,
// **** Step 1, find and make sure CMAKE_MAKE_PROGRAM is defined
this->FindMakeProgram(mf);
+ // try and load the CMakeSystem.cmake if it is there
+ std::string fpath = rootBin;
+ if(!mf->GetDefinition("CMAKE_SYSTEM_LOADED"))
+ {
+ fpath += "/CMakeSystem.cmake";
+ if(cmSystemTools::FileExists(fpath.c_str()))
+ {
+ mf->ReadListFile(0,fpath.c_str());
+ }
+ }
// **** Step 2, Load the CMakeDetermineSystem.cmake file and find out
// what platform we are running on
if (!isLocal && !mf->GetDefinition("CMAKE_SYSTEM_NAME"))
@@ -166,7 +185,7 @@ void cmGlobalGenerator::EnableLanguage(std::vector<std::string>const& languages,
}
// **** Step 3, load the CMakeSystem.cmake from the binary directory
// this file is configured by the CMakeDetermineSystem.cmake file
- std::string fpath = rootBin;
+ fpath = rootBin;
if(!mf->GetDefinition("CMAKE_SYSTEM_LOADED"))
{
fpath += "/CMakeSystem.cmake";
@@ -188,6 +207,26 @@ void cmGlobalGenerator::EnableLanguage(std::vector<std::string>const& languages,
"broken CMakeLists.txt file or a problematic release of "
"CMake");
}
+ // try and load the configured file first
+ std::string loadedLang = "CMAKE_";
+ loadedLang += lang;
+ loadedLang += "_COMPILER_LOADED";
+ if(!mf->GetDefinition(loadedLang.c_str()))
+ {
+ fpath = rootBin;
+ fpath += "/CMake";
+ fpath += lang;
+ fpath += "Compiler.cmake";
+ if(cmSystemTools::FileExists(fpath.c_str()))
+ {
+ if(!mf->ReadListFile(0,fpath.c_str()))
+ {
+ cmSystemTools::Error("Could not find cmake module file:", fpath.c_str());
+ }
+ this->SetLanguageEnabled(lang, mf);
+ }
+ }
+
needTestLanguage = true; // must test a language after finding it
// read determine LANG compiler
std::string determineCompiler = "CMakeDetermine";