mirror of
https://github.com/reactos/CMake.git
synced 2025-01-19 01:42:18 +00:00
many enhancements including dll support
This commit is contained in:
parent
d13d283f14
commit
e5e2a57bfb
@ -17,6 +17,7 @@
|
||||
#include "cmStandardIncludes.h"
|
||||
#include "cmSystemTools.h"
|
||||
#include "cmRegularExpression.h"
|
||||
#include "cmCacheManager.h"
|
||||
|
||||
cmDSPMakefile::~cmDSPMakefile()
|
||||
{
|
||||
@ -81,13 +82,27 @@ void cmDSPMakefile::OutputDSPFile()
|
||||
// add any extra define flags
|
||||
m_ReleaseLibraryOptions = m_DebugLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_ReleaseLibraryOptions, "Debug", "Release");
|
||||
|
||||
|
||||
m_DebugDLLLibraryOptions = m_DebugLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_DebugDLLLibraryOptions, "Debug", "DebugDLL");
|
||||
m_ReleaseDLLLibraryOptions = m_DebugDLLLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_ReleaseDLLLibraryOptions, "Debug", "Release");
|
||||
m_ReleaseMinSizeLibraryOptions = m_ReleaseLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_ReleaseMinSizeLibraryOptions,
|
||||
"Release", "ReleaseMinSize");
|
||||
|
||||
// Create the DSP or set of DSP's for libraries and executables
|
||||
if(strlen(m_Makefile->GetLibraryName()) != 0)
|
||||
{
|
||||
this->SetBuildType(STATIC_LIBRARY);
|
||||
const char* cacheValue
|
||||
= cmCacheManager::GetInstance()->GetCacheValue("BUILD_SHARED_LIBS");
|
||||
if(cacheValue && strcmp(cacheValue,"0"))
|
||||
{
|
||||
this->SetBuildType(DLL);
|
||||
}
|
||||
else
|
||||
{
|
||||
this->SetBuildType(STATIC_LIBRARY);
|
||||
}
|
||||
this->CreateSingleDSP();
|
||||
}
|
||||
// if there are executables build them
|
||||
@ -305,8 +320,14 @@ void cmDSPMakefile::WriteDSPHeader(std::ostream& fout)
|
||||
std::string line = buffer;
|
||||
cmSystemTools::ReplaceString(line, "CM_RELEASE_LIBRARIES",
|
||||
m_ReleaseLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_RELEASEMINSIZE_LIBRARIES",
|
||||
m_ReleaseMinSizeLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_DEBUG_LIBRARIES",
|
||||
m_DebugLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_RELEASEDLL_LIBRARIES",
|
||||
m_ReleaseDLLLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_DEBUGDLL_LIBRARIES",
|
||||
m_DebugDLLLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "BUILD_INCLUDES",
|
||||
m_IncludeOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "OUTPUT_LIBNAME",
|
||||
@ -357,8 +378,7 @@ void cmDSPMakefile::WriteDSPBuildRules(std::ostream& fout, const char *ext)
|
||||
std::vector<cmClassFile>& Classes = m_Makefile->GetClasses();
|
||||
for(int i = 0; i < Classes.size(); ++i)
|
||||
{
|
||||
if(!Classes[i].m_IsExecutable && !Classes[i].m_AbstractClass &&
|
||||
!Classes[i].m_HeaderFileOnly)
|
||||
if(!Classes[i].m_IsExecutable && !Classes[i].m_HeaderFileOnly)
|
||||
{
|
||||
// is this class of the appropriate type ?
|
||||
if (std::find(exts.begin(),exts.end(),Classes[i].m_ClassExtension)
|
||||
|
@ -82,6 +82,9 @@ private:
|
||||
std::string m_IncludeOptions;
|
||||
std::string m_DebugLibraryOptions;
|
||||
std::string m_ReleaseLibraryOptions;
|
||||
std::string m_ReleaseMinSizeLibraryOptions;
|
||||
std::string m_DebugDLLLibraryOptions;
|
||||
std::string m_ReleaseDLLLibraryOptions;
|
||||
cmMakefile* m_Makefile;
|
||||
|
||||
std::vector<std::string> m_Configurations;
|
||||
|
@ -17,6 +17,7 @@
|
||||
#include "cmStandardIncludes.h"
|
||||
#include "cmSystemTools.h"
|
||||
#include "cmRegularExpression.h"
|
||||
#include "cmCacheManager.h"
|
||||
|
||||
cmDSPMakefile::~cmDSPMakefile()
|
||||
{
|
||||
@ -81,13 +82,27 @@ void cmDSPMakefile::OutputDSPFile()
|
||||
// add any extra define flags
|
||||
m_ReleaseLibraryOptions = m_DebugLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_ReleaseLibraryOptions, "Debug", "Release");
|
||||
|
||||
|
||||
m_DebugDLLLibraryOptions = m_DebugLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_DebugDLLLibraryOptions, "Debug", "DebugDLL");
|
||||
m_ReleaseDLLLibraryOptions = m_DebugDLLLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_ReleaseDLLLibraryOptions, "Debug", "Release");
|
||||
m_ReleaseMinSizeLibraryOptions = m_ReleaseLibraryOptions;
|
||||
cmSystemTools::ReplaceString(m_ReleaseMinSizeLibraryOptions,
|
||||
"Release", "ReleaseMinSize");
|
||||
|
||||
// Create the DSP or set of DSP's for libraries and executables
|
||||
if(strlen(m_Makefile->GetLibraryName()) != 0)
|
||||
{
|
||||
this->SetBuildType(STATIC_LIBRARY);
|
||||
const char* cacheValue
|
||||
= cmCacheManager::GetInstance()->GetCacheValue("BUILD_SHARED_LIBS");
|
||||
if(cacheValue && strcmp(cacheValue,"0"))
|
||||
{
|
||||
this->SetBuildType(DLL);
|
||||
}
|
||||
else
|
||||
{
|
||||
this->SetBuildType(STATIC_LIBRARY);
|
||||
}
|
||||
this->CreateSingleDSP();
|
||||
}
|
||||
// if there are executables build them
|
||||
@ -305,8 +320,14 @@ void cmDSPMakefile::WriteDSPHeader(std::ostream& fout)
|
||||
std::string line = buffer;
|
||||
cmSystemTools::ReplaceString(line, "CM_RELEASE_LIBRARIES",
|
||||
m_ReleaseLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_RELEASEMINSIZE_LIBRARIES",
|
||||
m_ReleaseMinSizeLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_DEBUG_LIBRARIES",
|
||||
m_DebugLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_RELEASEDLL_LIBRARIES",
|
||||
m_ReleaseDLLLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "CM_DEBUGDLL_LIBRARIES",
|
||||
m_DebugDLLLibraryOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "BUILD_INCLUDES",
|
||||
m_IncludeOptions.c_str());
|
||||
cmSystemTools::ReplaceString(line, "OUTPUT_LIBNAME",
|
||||
@ -357,8 +378,7 @@ void cmDSPMakefile::WriteDSPBuildRules(std::ostream& fout, const char *ext)
|
||||
std::vector<cmClassFile>& Classes = m_Makefile->GetClasses();
|
||||
for(int i = 0; i < Classes.size(); ++i)
|
||||
{
|
||||
if(!Classes[i].m_IsExecutable && !Classes[i].m_AbstractClass &&
|
||||
!Classes[i].m_HeaderFileOnly)
|
||||
if(!Classes[i].m_IsExecutable && !Classes[i].m_HeaderFileOnly)
|
||||
{
|
||||
// is this class of the appropriate type ?
|
||||
if (std::find(exts.begin(),exts.end(),Classes[i].m_ClassExtension)
|
||||
|
@ -82,6 +82,9 @@ private:
|
||||
std::string m_IncludeOptions;
|
||||
std::string m_DebugLibraryOptions;
|
||||
std::string m_ReleaseLibraryOptions;
|
||||
std::string m_ReleaseMinSizeLibraryOptions;
|
||||
std::string m_DebugDLLLibraryOptions;
|
||||
std::string m_ReleaseDLLLibraryOptions;
|
||||
cmMakefile* m_Makefile;
|
||||
|
||||
std::vector<std::string> m_Configurations;
|
||||
|
@ -121,20 +121,18 @@ void cmDSWMakefile::WriteProject(std::ostream& fout,
|
||||
fout << "Package=<5>\n{{{\n}}}\n\n";
|
||||
fout << "Package=<4>\n";
|
||||
fout << "{{{\n";
|
||||
if(project->GetMakefile()->HasExecutables())
|
||||
|
||||
// insert Begin Project Dependency Project_Dep_Name project stuff here
|
||||
std::vector<std::string>::iterator i, end;
|
||||
i = project->GetMakefile()->GetLinkLibraries().begin();
|
||||
end = project->GetMakefile()->GetLinkLibraries().end();
|
||||
for(;i!= end; ++i)
|
||||
{
|
||||
// insert Begin Project Dependency Project_Dep_Name project stuff here
|
||||
std::vector<std::string>::iterator i, end;
|
||||
i = project->GetMakefile()->GetLinkLibraries().begin();
|
||||
end = project->GetMakefile()->GetLinkLibraries().end();
|
||||
for(;i!= end; ++i)
|
||||
if (strcmp(i->c_str(),dspname))
|
||||
{
|
||||
if (strcmp(i->c_str(),dspname))
|
||||
{
|
||||
fout << "Begin Project Dependency\n";
|
||||
fout << "Project_Dep_Name " << *i << "\n";
|
||||
fout << "End Project Dependency\n";
|
||||
}
|
||||
fout << "Begin Project Dependency\n";
|
||||
fout << "Project_Dep_Name " << *i << "\n";
|
||||
fout << "End Project Dependency\n";
|
||||
}
|
||||
}
|
||||
fout << "}}}\n\n";
|
||||
|
@ -121,20 +121,18 @@ void cmDSWMakefile::WriteProject(std::ostream& fout,
|
||||
fout << "Package=<5>\n{{{\n}}}\n\n";
|
||||
fout << "Package=<4>\n";
|
||||
fout << "{{{\n";
|
||||
if(project->GetMakefile()->HasExecutables())
|
||||
|
||||
// insert Begin Project Dependency Project_Dep_Name project stuff here
|
||||
std::vector<std::string>::iterator i, end;
|
||||
i = project->GetMakefile()->GetLinkLibraries().begin();
|
||||
end = project->GetMakefile()->GetLinkLibraries().end();
|
||||
for(;i!= end; ++i)
|
||||
{
|
||||
// insert Begin Project Dependency Project_Dep_Name project stuff here
|
||||
std::vector<std::string>::iterator i, end;
|
||||
i = project->GetMakefile()->GetLinkLibraries().begin();
|
||||
end = project->GetMakefile()->GetLinkLibraries().end();
|
||||
for(;i!= end; ++i)
|
||||
if (strcmp(i->c_str(),dspname))
|
||||
{
|
||||
if (strcmp(i->c_str(),dspname))
|
||||
{
|
||||
fout << "Begin Project Dependency\n";
|
||||
fout << "Project_Dep_Name " << *i << "\n";
|
||||
fout << "End Project Dependency\n";
|
||||
}
|
||||
fout << "Begin Project Dependency\n";
|
||||
fout << "Project_Dep_Name " << *i << "\n";
|
||||
fout << "End Project Dependency\n";
|
||||
}
|
||||
}
|
||||
fout << "}}}\n\n";
|
||||
|
Loading…
x
Reference in New Issue
Block a user