summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2003-10-16 03:42:06 (GMT)
committerBill Hoffman <bill.hoffman@kitware.com>2003-10-16 03:42:06 (GMT)
commitdb3cd8259068f09c53dad3a2e81c1b78ba7683eb (patch)
tree388d23b26401cd9a4e9ff5e7740e72a4be9af02c
parentde27c1207b9d61c604b1e89803dd343498e84911 (diff)
downloadCMake-db3cd8259068f09c53dad3a2e81c1b78ba7683eb.zip
CMake-db3cd8259068f09c53dad3a2e81c1b78ba7683eb.tar.gz
CMake-db3cd8259068f09c53dad3a2e81c1b78ba7683eb.tar.bz2
BUG: fix for bug 78 should be on 1.8 branch
-rw-r--r--Modules/Platform/Windows-cl.cmake2
-rw-r--r--Source/cmLocalVisualStudio7Generator.cxx124
2 files changed, 89 insertions, 37 deletions
diff --git a/Modules/Platform/Windows-cl.cmake b/Modules/Platform/Windows-cl.cmake
index 7a892e4..7f46c60 100644
--- a/Modules/Platform/Windows-cl.cmake
+++ b/Modules/Platform/Windows-cl.cmake
@@ -62,6 +62,7 @@ IF(CMAKE_GENERATOR MATCHES "Visual Studio 6")
SET (CMAKE_NO_BUILD_TYPE 1)
ENDIF(CMAKE_GENERATOR MATCHES "Visual Studio 6")
IF(CMAKE_GENERATOR MATCHES "Visual Studio 7")
+ SET (CMAKE_NO_BUILD_TYPE 1)
SET (CMAKE_CONFIGURATION_TYPES "Debug;Release;MinSizeRel;RelWithDebInfo" CACHE STRING
"Semicolon separated list of supported configuration types, only supports Debug, Release, MinSizeRel, and RelWithDebInfo, anything else will be ignored.")
SET (CMAKE_CXX_WARNING_LEVEL "3" CACHE STRING
@@ -69,7 +70,6 @@ IF(CMAKE_GENERATOR MATCHES "Visual Studio 7")
SET (CMAKE_CXX_STACK_SIZE "10000000" CACHE STRING
"Size of stack for programs.")
MARK_AS_ADVANCED(CMAKE_CONFIGURATION_TYPES CMAKE_CXX_STACK_SIZE CMAKE_CXX_WARNING_LEVEL)
- SET (CMAKE_NOT_USING_CONFIG_FLAGS 1)
ENDIF(CMAKE_GENERATOR MATCHES "Visual Studio 7")
# does the compiler support pdbtype
diff --git a/Source/cmLocalVisualStudio7Generator.cxx b/Source/cmLocalVisualStudio7Generator.cxx
index 6fdbe17..18be630 100644
--- a/Source/cmLocalVisualStudio7Generator.cxx
+++ b/Source/cmLocalVisualStudio7Generator.cxx
@@ -253,32 +253,26 @@ void cmLocalVisualStudio7Generator::WriteConfiguration(std::ostream& fout,
<< "\t\t\t\tName=\"VCCLCompilerTool\"\n"
<< "\t\t\t\tAdditionalOptions=\"";
std::string flags;
+ std::string flagsRelease = " ";
+ std::string flagsMinSize = " ";
+ std::string flagsDebug = " ";
+ std::string flagsDebugRel = " ";
if(target.HasCxx())
{
flags = m_Makefile->GetDefinition("CMAKE_CXX_FLAGS");
+ flagsRelease += m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_RELEASE");
+ flagsMinSize += m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_MINSIZEREL");
+ flagsDebug += m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_DEBUG");
+ flagsDebugRel += m_Makefile->GetDefinition("CMAKE_CXX_FLAGS_RELWITHDEBINFO");
}
else
{
- if(m_Makefile->GetDefinition("CMAKE_C_FLAGS"))
- {
- flags = m_Makefile->GetDefinition("CMAKE_C_FLAGS");
- }
+ flags = m_Makefile->GetDefinition("CMAKE_C_FLAGS");
+ flagsRelease += m_Makefile->GetDefinition("CMAKE_C_FLAGS_RELEASE");
+ flagsMinSize += m_Makefile->GetDefinition("CMAKE_C_FLAGS_MINSIZEREL");
+ flagsDebug += m_Makefile->GetDefinition("CMAKE_C_FLAGS_DEBUG");
+ flagsDebugRel += m_Makefile->GetDefinition("CMAKE_C_FLAGS_RELWITHDEBINFO");
}
- cmSystemTools::ReplaceString(flags, "\"", "&quot;");
- fout << flags;
-
- fout << " -DCMAKE_INTDIR=\\&quot;" << configName << "\\&quot;"
- << "\"\n";
-
- fout << "\t\t\t\tAdditionalIncludeDirectories=\"";
- std::vector<std::string>& includes = m_Makefile->GetIncludeDirectories();
- std::vector<std::string>::iterator i = includes.begin();
- for(;i != includes.end(); ++i)
- {
- std::string ipath = this->ConvertToXMLOutputPath(i->c_str());
- fout << ipath << ";";
- }
- fout << "\"\n";
// Optimization = 0 None Debug /O0
// Optimization = 1 MinSize /O1
@@ -295,34 +289,92 @@ void cmLocalVisualStudio7Generator::WriteConfiguration(std::ostream& fout,
// InlineFunctionExpansion = 2 any time you can
+ int runtime = 0;
+ int optimized = 0;
+ int inlineFunctions = 0;
+ const char* pre = "WIN32,_DEBUG,_WINDOWS";
+ // set the flags and defaults for
+ // runtime, optimized, and inlineFunctions , and
+ // default pre processor flags
if(strcmp(configName, "Debug") == 0)
{
- fout << "\t\t\t\tOptimization=\"0\"\n"
- << "\t\t\t\tRuntimeLibrary=\"3\"\n"
- << "\t\t\t\tInlineFunctionExpansion=\"0\"\n"
- << "\t\t\t\tPreprocessorDefinitions=\"WIN32,_DEBUG,_WINDOWS";
+ inlineFunctions = 0;
+ flags += flagsDebug;
+ optimized = 0;
+ runtime = 3;
+ pre = "WIN32,_DEBUG,_WINDOWS";
}
- else if(strcmp(configName, "Release") == 0)
+ else if (strcmp(configName, "Release") == 0)
{
- fout << "\t\t\t\tOptimization=\"2\"\n"
- << "\t\t\t\tRuntimeLibrary=\"2\"\n"
- << "\t\t\t\tInlineFunctionExpansion=\"1\"\n"
- << "\t\t\t\tPreprocessorDefinitions=\"WIN32,NDEBUG,_WINDOWS";
+ inlineFunctions = 1;
+ optimized =2;
+ pre = "WIN32,NDEBUG,_WINDOWS";
+ flags += flagsRelease;
+ runtime = 2;
}
else if(strcmp(configName, "MinSizeRel") == 0)
{
- fout << "\t\t\t\tOptimization=\"1\"\n"
- << "\t\t\t\tRuntimeLibrary=\"2\"\n"
- << "\t\t\t\tInlineFunctionExpansion=\"1\"\n"
- << "\t\t\t\tPreprocessorDefinitions=\"WIN32,NDEBUG,_WINDOWS";
+ inlineFunctions = 1;
+ runtime = 2;
+ optimized = 1;
+ pre = "WIN32,NDEBUG,_WINDOWS";
+ flags += flagsMinSize;
}
else if(strcmp(configName, "RelWithDebInfo") == 0)
{
- fout << "\t\t\t\tOptimization=\"2\"\n"
- << "\t\t\t\tRuntimeLibrary=\"2\"\n"
- << "\t\t\t\tInlineFunctionExpansion=\"1\"\n"
- << "\t\t\t\tPreprocessorDefinitions=\"WIN32,NDEBUG,_WINDOWS";
+ inlineFunctions = 1;
+ optimized = 2;
+ runtime = 2;
+ pre = "WIN32,NDEBUG,_WINDOWS";
+ flags += flagsDebugRel;
+ }
+
+ cmSystemTools::ReplaceString(flags, "\"", "&quot;");
+ fout << flags;
+
+ fout << " -DCMAKE_INTDIR=\\&quot;" << configName << "\\&quot;"
+ << "\"\n";
+
+ fout << "\t\t\t\tAdditionalIncludeDirectories=\"";
+ std::vector<std::string>& includes = m_Makefile->GetIncludeDirectories();
+ std::vector<std::string>::iterator i = includes.begin();
+ for(;i != includes.end(); ++i)
+ {
+ std::string ipath = this->ConvertToXMLOutputPath(i->c_str());
+ fout << ipath << ";";
+ }
+ fout << "\"\n";
+ // check the flags for the run time library flag options
+ // if there is a match set the run time flag
+ if(flags.find("MTd") != flags.npos)
+ {
+ runtime = 1;
}
+ else if (flags.find("MDd") != flags.npos)
+ {
+ runtime = 3;
+ }
+ else if (flags.find("MLd") != flags.npos)
+ {
+ runtime = 5;
+ }
+ else if (flags.find("MT") != flags.npos)
+ {
+ runtime = 0;
+ }
+ else if (flags.find("MD") != flags.npos)
+ {
+ runtime = 2;
+ }
+ else if (flags.find("ML") != flags.npos)
+ {
+ runtime = 4;
+ }
+
+ fout << "\t\t\t\tOptimization=\"" << optimized << "\"\n"
+ << "\t\t\t\tRuntimeLibrary=\"" << runtime << "\"\n"
+ << "\t\t\t\tInlineFunctionExpansion=\"" << inlineFunctions << "\"\n"
+ << "\t\t\t\tPreprocessorDefinitions=\"" << pre;
if(target.GetType() == cmTarget::SHARED_LIBRARY
|| target.GetType() == cmTarget::MODULE_LIBRARY)
{