diff options
author | Ken Martin <ken.martin@kitware.com> | 2002-09-12 15:49:10 (GMT) |
---|---|---|
committer | Ken Martin <ken.martin@kitware.com> | 2002-09-12 15:49:10 (GMT) |
commit | c8c89b653fb49befaa8f0771523b5254ea1a7d7e (patch) | |
tree | 74850ae8fb020aa610dfa7fee0b5e10bd96d9d15 /Source/cmBorlandMakefileGenerator.cxx | |
parent | 271e6ec3741e58d319e1c08142802f19bcebb73c (diff) | |
download | CMake-c8c89b653fb49befaa8f0771523b5254ea1a7d7e.zip CMake-c8c89b653fb49befaa8f0771523b5254ea1a7d7e.tar.gz CMake-c8c89b653fb49befaa8f0771523b5254ea1a7d7e.tar.bz2 |
new arch
Diffstat (limited to 'Source/cmBorlandMakefileGenerator.cxx')
-rw-r--r-- | Source/cmBorlandMakefileGenerator.cxx | 462 |
1 files changed, 0 insertions, 462 deletions
diff --git a/Source/cmBorlandMakefileGenerator.cxx b/Source/cmBorlandMakefileGenerator.cxx deleted file mode 100644 index e467cdd..0000000 --- a/Source/cmBorlandMakefileGenerator.cxx +++ /dev/null @@ -1,462 +0,0 @@ -/*========================================================================= - - Program: Insight Segmentation & Registration Toolkit - Module: $RCSfile$ - Language: C++ - Date: $Date$ - Version: $Revision$ - - Copyright (c) 2002 Insight Consortium. All rights reserved. - See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details. - - This software is distributed WITHOUT ANY WARRANTY; without even - the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR - PURPOSE. See the above copyright notices for more information. - -=========================================================================*/ -#include "cmBorlandMakefileGenerator.h" -#include "cmMakefile.h" -#include "cmStandardIncludes.h" -#include "cmSystemTools.h" -#include "cmSourceFile.h" -#include "cmMakeDepend.h" -#include "cmCacheManager.h" -#include "cmGeneratedFileStream.h" -#include "windows.h" -#include <stdio.h> - -cmBorlandMakefileGenerator::cmBorlandMakefileGenerator() -{ - this->SetLibraryPathOption("-L"); - this->SetLibraryLinkOption(""); -} - -cmBorlandMakefileGenerator::~cmBorlandMakefileGenerator() -{ -} - - -void cmBorlandMakefileGenerator::EnableLanguage(const char*) -{ - // now load the settings - if(!m_Makefile->GetDefinition("CMAKE_ROOT")) - { - cmSystemTools::Error( - "CMAKE_ROOT has not been defined, bad GUI or driver program"); - return; - } - std::string outdir = m_Makefile->GetCurrentOutputDirectory(); - if(outdir.find('-') != std::string::npos) - { - std::string message = "The Borland command line tools do not support path names that have - in them. Please re-name your output directory and use _ instead of -."; - message += "\nYour path currently is: "; - message += outdir; - cmSystemTools::Error(message.c_str()); - } - if(!this->GetLanguageEnabled("CXX")) - { - std::string fpath = - m_Makefile->GetDefinition("CMAKE_ROOT"); - fpath += "/Templates/CMakeBorlandWindowsSystemConfig.cmake"; - m_Makefile->ReadListFile(NULL,fpath.c_str()); - this->SetLanguageEnabled("CXX"); - } - -} - - - -void cmBorlandMakefileGenerator::OutputMakeVariables(std::ostream& fout) -{ - fout << "# NMake Makefile generated by cmake\n"; - const char* variables = - "# general varibles used in the makefile\n" - "\n" - "CMAKE_STANDARD_WINDOWS_LIBRARIES = @CMAKE_STANDARD_WINDOWS_LIBRARIES@\n" - "CMAKE_C_FLAGS = @CMAKE_C_FLAGS@ @BUILD_FLAGS@\n" - "CMAKE_OBJECT_FILE_SUFFIX = @CMAKE_OBJECT_FILE_SUFFIX@\n" - "CMAKE_EXECUTABLE_SUFFIX = @CMAKE_EXECUTABLE_SUFFIX@\n" - "CMAKE_STATICLIB_SUFFIX = @CMAKE_STATICLIB_SUFFIX@\n" - "CMAKE_SHLIB_SUFFIX = @CMAKE_SHLIB_SUFFIX@\n" - "CMAKE_SHLIB_CFLAGS = -tWR\n" - "CMAKE_LINKER_FLAGS = @CMAKE_LINKER_FLAGS@ @LINKER_BUILD_FLAGS@\n" - "CMAKE_CXX_FLAGS = -P @CMAKE_CXX_FLAGS@ @BUILD_FLAGS@\n" - "!IF \"$(OS)\" == \"Windows_NT\"\n" - "NULL=\n" - "!ELSE \n" - "NULL=nul\n" - "!ENDIF \n"; - std::string buildType = "CMAKE_CXX_FLAGS_"; - buildType += m_Makefile->GetDefinition("CMAKE_BUILD_TYPE"); - buildType = cmSystemTools::UpperCase(buildType); - m_Makefile->AddDefinition("BUILD_FLAGS", - m_Makefile->GetDefinition( - buildType.c_str())); - - buildType = "CMAKE_LINKER_FLAGS_"; - buildType += m_Makefile->GetDefinition("CMAKE_BUILD_TYPE"); - buildType = cmSystemTools::UpperCase(buildType); - m_Makefile->AddDefinition("LINKER_BUILD_FLAGS", - m_Makefile->GetDefinition( - buildType.c_str())); - - std::string replaceVars = variables; - m_Makefile->ExpandVariablesInString(replaceVars); - std::string ccompiler = m_Makefile->GetDefinition("CMAKE_C_COMPILER"); - fout << "CMAKE_C_COMPILER = " - << this->ConvertToOutputPath(ccompiler.c_str()) - << "\n"; - std::string cxxcompiler = m_Makefile->GetDefinition("CMAKE_CXX_COMPILER"); - fout << "CMAKE_CXX_COMPILER = " - << this->ConvertToOutputPath(cxxcompiler.c_str()) - << "\n"; - - if(m_Makefile->GetDefinition("CMAKE_EDIT_COMMAND")) - { - fout << "CMAKE_EDIT_COMMAND = " - << this->ShortPath(m_Makefile->GetDefinition("CMAKE_EDIT_COMMAND")) - << "\n"; - } - - std::string cmakecommand = m_Makefile->GetDefinition("CMAKE_COMMAND"); - fout << "CMAKE_COMMAND = " - << this->ShortPath(cmakecommand.c_str()) << "\n"; - fout << "RM = " << this->ShortPath(cmakecommand.c_str()) << " -E remove -f\n"; - - fout << replaceVars.c_str(); - fout << "CMAKE_CURRENT_SOURCE = " - << ShortPath(m_Makefile->GetStartDirectory() ) - << "\n"; - fout << "CMAKE_CURRENT_BINARY = " - << ShortPath(m_Makefile->GetStartOutputDirectory()) - << "\n"; - fout << "CMAKE_SOURCE_DIR = " - << ShortPath(m_Makefile->GetHomeDirectory()) << "\n"; - fout << "CMAKE_BINARY_DIR = " - << ShortPath(m_Makefile->GetHomeOutputDirectory() ) - << "\n"; - // Output Include paths - fout << "INCLUDE_FLAGS = "; - std::vector<std::string>& includes = m_Makefile->GetIncludeDirectories(); - std::vector<std::string>::iterator i; - fout << "-I" << - this->ShortPath(m_Makefile->GetStartDirectory()) << " "; - for(i = includes.begin(); i != includes.end(); ++i) - { - std::string include = *i; - // Don't output a -I for the standard include path "/usr/include". - // This can cause problems with certain standard library - // implementations because the wrong headers may be found first. - fout << "-I" << this->ConvertToOutputPath(i->c_str()).c_str() << " "; - } - fout << m_Makefile->GetDefineFlags(); - fout << "\n\n"; -} - - - -void -cmBorlandMakefileGenerator:: -OutputBuildObjectFromSource(std::ostream& fout, - const char* shortName, - const cmSourceFile& source, - const char* extraCompileFlags, - bool shared) -{ - // force shared flag if building shared libraries - if(cmSystemTools::IsOn(m_Makefile->GetDefinition("BUILD_SHARED_LIBS"))) - { - shared = true; - } - // Header files shouldn't have build rules. - if(source.GetPropertyAsBool("HEADER_FILE_ONLY")) - { - return; - } - - - - std::string comment = "Build "; - std::string objectFile = std::string(shortName) + - this->GetOutputExtension(source.GetSourceExtension().c_str()); - objectFile = this->ConvertToOutputPath(objectFile.c_str()); - comment += objectFile + " From "; - comment += source.GetFullPath(); - std::string compileCommand; - std::string ext = source.GetSourceExtension(); - if(ext == "c" ) - { - compileCommand = "$(CMAKE_C_COMPILER) $(CMAKE_C_FLAGS) "; - compileCommand += extraCompileFlags; - if(shared) - { - compileCommand += "$(CMAKE_SHLIB_CFLAGS) "; - } - compileCommand += " -o"; - compileCommand += objectFile; - compileCommand += " $(INCLUDE_FLAGS) -c "; - compileCommand += - this->ConvertToOutputPath(source.GetFullPath().c_str()); - } - else if (ext == "rc") - { - compileCommand = "$(RC) $(INCLUDE_FLAGS) -o\""; - compileCommand += objectFile; - compileCommand += "\" "; - compileCommand += - this->ConvertToOutputPath(source.GetFullPath().c_str()); - } - else if (ext == "def") - { - // no rule to output for this one - return; - } - // assume c++ if not c rc or def - else - { - compileCommand = "$(CMAKE_CXX_COMPILER) $(CMAKE_CXX_FLAGS) "; - compileCommand += extraCompileFlags; - if(shared) - { - compileCommand += "$(CMAKE_SHLIB_CFLAGS) "; - } - compileCommand += " -o"; - compileCommand += objectFile; - compileCommand += " $(INCLUDE_FLAGS) -c "; - compileCommand += - this->ConvertToOutputPath(source.GetFullPath().c_str()); - } - this->OutputMakeRule(fout, - comment.c_str(), - objectFile.c_str(), - this->ConvertToOutputPath( - source.GetFullPath().c_str()).c_str(), - compileCommand.c_str()); -} - -void cmBorlandMakefileGenerator::OutputSharedLibraryRule(std::ostream& fout, - const char* name, - const cmTarget &t) -{ - std::string target = m_LibraryOutputPath + name; - std::string libpath = target + ".lib"; - target += ".dll"; - target = this->ConvertToOutputPath(target.c_str()); - libpath = this->ConvertToOutputPath(libpath.c_str()); - std::string depend = "$("; - depend += this->CreateMakeVariable(name, "_SRC_OBJS"); - depend += ") $(" + this->CreateMakeVariable(name, "_DEPEND_LIBS") + ")"; - std::string command = "$(CMAKE_CXX_COMPILER) -tWD $(CMAKE_SHLIB_CFLAGS) $(CMAKE_LINKER_FLAGS) @&&|\n"; - // must be executable name - command += "-e"; - command += target; - command += " "; - cmStringStream linklibs; - this->OutputLinkLibraries(linklibs, name, t); - // then the linker options -L and libraries (any other order will fail!) - command += linklibs.str(); - // then list of object files - command += " $(" + this->CreateMakeVariable(name, "_SRC_OBJS") + ") "; - std::string command2 = "implib -w "; - command2 += libpath + " " + target; - const std::vector<cmSourceFile*>& sources = t.GetSourceFiles(); - for(std::vector<cmSourceFile*>::const_iterator i = sources.begin(); - i != sources.end(); ++i) - { - if((*i)->GetSourceExtension() == "def") - { - command += ""; - command += (*i)->GetFullPath(); - } - } - command += "\n|\n"; - - std::string customCommands = this->CreateTargetRules(t, name); - const char* cc = 0; - if(customCommands.size() > 0) - { - cc = customCommands.c_str(); - } - this->OutputMakeRule(fout, "rules for a shared library", - target.c_str(), - depend.c_str(), - command.c_str(), - command2.c_str(), - cc); -} - -void cmBorlandMakefileGenerator::OutputModuleLibraryRule(std::ostream& fout, - const char* name, - const cmTarget &target) -{ - this->OutputSharedLibraryRule(fout, name, target); -} - -void cmBorlandMakefileGenerator::OutputStaticLibraryRule(std::ostream& fout, - const char* name, - const cmTarget &t) -{ - std::string target = m_LibraryOutputPath + std::string(name) + ".lib"; - target = this->ConvertToOutputPath(target.c_str()); - std::string depend = "$("; - depend += this->CreateMakeVariable(name, "_SRC_OBJS") + ") "; - std::string command = "tlib @&&|\n\t /p512 /a "; - command += target; - command += " "; - std::string deleteCommand = "if exist "; - deleteCommand += target; - deleteCommand += " del "; - deleteCommand += target; - - command += " $("; - command += this->CreateMakeVariable(name, "_SRC_OBJS_QUOTED") + ")"; - command += "\n|\n"; - std::string comment = "rule to build static library: "; - comment += name; - std::string customCommands = this->CreateTargetRules(t, name); - const char* cc = 0; - if(customCommands.size() > 0) - { - cc = customCommands.c_str(); - } - this->OutputMakeRule(fout, - comment.c_str(), - target.c_str(), - depend.c_str(), - deleteCommand.c_str(), - command.c_str(), cc); -} - -void cmBorlandMakefileGenerator::OutputExecutableRule(std::ostream& fout, - const char* name, - const cmTarget &t) -{ - std::string target = m_ExecutableOutputPath + name + m_ExecutableExtension; - target = this->ConvertToOutputPath(target.c_str()); - std::string depend = "$("; - depend += this->CreateMakeVariable(name, "_SRC_OBJS") + ") $(" + - this->CreateMakeVariable(name, "_DEPEND_LIBS") + ")"; - std::string command = - "$(CMAKE_CXX_COMPILER) "; - command += " $(CMAKE_LINKER_FLAGS) -e" + target; - if(cmSystemTools::IsOn(m_Makefile->GetDefinition("BUILD_SHARED_LIBS"))) - { - command += " $(CMAKE_SHLIB_CFLAGS) "; - } - if(t.GetType() == cmTarget::WIN32_EXECUTABLE) - { - command += " -tWM "; - } - else - { - command += " -tWC "; - } - cmStringStream linklibs; - this->OutputLinkLibraries(linklibs, 0, t); - command += linklibs.str(); - command += " $(" + this->CreateMakeVariable(name, "_SRC_OBJS") + ")"; - - std::string comment = "rule to build executable: "; - comment += name; - std::string customCommands = this->CreateTargetRules(t, name); - const char* cc = 0; - if(customCommands.size() > 0) - { - cc = customCommands.c_str(); - } - this->OutputMakeRule(fout, - comment.c_str(), - target.c_str(), - depend.c_str(), - command.c_str(), cc); -} - - - - -std::string cmBorlandMakefileGenerator::GetOutputExtension(const char* s) -{ - std::string sourceExtension = s; - if(sourceExtension == "def") - { - return ""; - } - if(sourceExtension == "ico" || sourceExtension == "rc2") - { - return ""; - } - if(sourceExtension == "rc") - { - return ".res"; - } - return ".obj"; -} - - - -bool cmBorlandMakefileGenerator::SamePath(const char* path1, const char* path2) -{ - // first check to see if they are the same anyway - if (strcmp(path1, path2) == 0) - { - return true; - } - // next short path and lower case both of them for the compare - return - cmSystemTools::LowerCase(ShortPath(path1)) == - cmSystemTools::LowerCase(ShortPath(path2)); -} - - -// borland make does not support variables that are longer than 32 -// so use this function to rename any long ones -std::string cmBorlandMakefileGenerator::CreateMakeVariable(const char* s, const char* s2) -{ - std::string unmodified = s; - unmodified += s2; - // see if th - std::map<cmStdString, cmStdString>::iterator i = m_MakeVariableMap.find(unmodified); - if(i != m_MakeVariableMap.end()) - { - return i->second; - } - std::string ret = unmodified; - // if the string is greater the 32 chars it is an invalid vairable name - // for borland make - if(ret.size() > 32) - { - std::string str1 = s; - std::string str2 = s2; - // we must shorten the combined string by 4 charactors - // keep no more than 24 charactors from the second string - if(str2.size() > 24) - { - str2 = str2.substr(0, 24); - } - if(str1.size() + str2.size() > 27) - { - str1 = str1.substr(0, 27 - str2.size()); - } - char buffer[5]; - int i = 0; - sprintf(buffer, "%04d", i); - ret = str1 + str2 + buffer; - while(m_ShortMakeVariableMap.count(ret) && i < 1000) - { - ++i; - sprintf(buffer, "%04d", i); - ret = str1 + str2 + buffer; - } - if(i == 1000) - { - cmSystemTools::Error("Borland makefile varible length too long"); - return unmodified; - } - // once an unused variable is found - m_ShortMakeVariableMap[ret] = "1"; - } - // always make an entry into the unmodified to varible map - m_MakeVariableMap[unmodified] = ret; - return ret; -} - |