summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKen Martin <ken.martin@kitware.com>2005-10-19 14:03:20 (GMT)
committerKen Martin <ken.martin@kitware.com>2005-10-19 14:03:20 (GMT)
commit6b444ee345e7dcabbac33a18ba8e4c16fd7a7b54 (patch)
treeeb5916428f4d7180749e06f0626b3726a339ab50
parent66e50573c15d7338868142d7f1055c3491048291 (diff)
downloadCMake-6b444ee345e7dcabbac33a18ba8e4c16fd7a7b54.zip
CMake-6b444ee345e7dcabbac33a18ba8e4c16fd7a7b54.tar.gz
CMake-6b444ee345e7dcabbac33a18ba8e4c16fd7a7b54.tar.bz2
BUG: cd into local directory to reduce link line length
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.cxx149
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.h7
2 files changed, 52 insertions, 104 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx
index 4316b3c..f948e30 100644
--- a/Source/cmLocalUnixMakefileGenerator3.cxx
+++ b/Source/cmLocalUnixMakefileGenerator3.cxx
@@ -1304,9 +1304,9 @@ cmLocalUnixMakefileGenerator3
// Convert to the output path to use in constructing commands.
std::string targetOutPath =
- this->Convert(targetFullPath.c_str(),HOME_OUTPUT,MAKEFILE);
+ this->Convert(targetFullPath.c_str(),START_OUTPUT,MAKEFILE);
std::string targetOutPathReal =
- this->Convert(targetFullPathReal.c_str(),HOME_OUTPUT,MAKEFILE);
+ this->Convert(targetFullPathReal.c_str(),START_OUTPUT,MAKEFILE);
// Get the language to use for linking this executable.
const char* linkLanguage =
@@ -1330,35 +1330,7 @@ cmLocalUnixMakefileGenerator3
// Build a list of compiler flags and linker flags.
std::string flags;
std::string linkFlags;
-#if 0
- // Loop over all libraries and see if all are shared
- const cmTarget::LinkLibraries& tlibs = target.GetLinkLibraries();
- int AllShared = 2; // 0 = false, 1 = true, 2 = unknown
- for(cmTarget::LinkLibraries::const_iterator lib = tlibs.begin();
- lib != tlibs.end(); ++lib)
- {
- // look up the target if there is one
- cmTarget *libtgt = m_GlobalGenerator->FindTarget(0,lib->first.c_str());
- if (libtgt)
- {
- if (libtgt->GetType() != cmTarget::SHARED_LIBRARY)
- {
- AllShared = 0;
- }
- else if (AllShared == 2)
- {
- AllShared = 1;
- }
- }
- }
- // if all libs were shared then add the special borland flag for linking an
- // executable to only shared libs
- if(AllShared == 1)
- {
- this->AppendFlags
- (linkFlags,m_Makefile->GetDefinition("CMAKE_SHARED_BUILD_CXX_FLAGS"));
- }
-#endif
+
// Add flags to deal with shared libraries. Any library being
// linked in might be shared, so always use shared flags for an
// executable.
@@ -1368,7 +1340,6 @@ cmLocalUnixMakefileGenerator3
this->AddConfigVariableFlags(linkFlags, "CMAKE_EXE_LINKER_FLAGS");
-
if(target.GetPropertyAsBool("WIN32_EXECUTABLE"))
{
this->AppendFlags(linkFlags,
@@ -1415,8 +1386,12 @@ cmLocalUnixMakefileGenerator3
std::string linkRuleVar = "CMAKE_";
linkRuleVar += linkLanguage;
linkRuleVar += "_LINK_EXECUTABLE";
- std::string linkRule = m_Makefile->GetRequiredDefinition(linkRuleVar.c_str());
- cmSystemTools::ExpandListArgument(linkRule, commands);
+ std::string linkRule =
+ m_Makefile->GetRequiredDefinition(linkRuleVar.c_str());
+ std::vector<std::string> commands1;
+ cmSystemTools::ExpandListArgument(linkRule, commands1);
+ this->CreateCDCommand(commands1);
+ commands.insert(commands.end(), commands1.begin(), commands1.end());
// Add a rule to create necessary symlinks for the library.
if(targetOutPath != targetOutPathReal)
@@ -1670,13 +1645,13 @@ cmLocalUnixMakefileGenerator3
// Construct the output path version of the names for use in command
// arguments.
std::string targetOutPath =
- this->Convert(targetFullPath.c_str(),HOME_OUTPUT,MAKEFILE);
+ this->Convert(targetFullPath.c_str(),START_OUTPUT,MAKEFILE);
std::string targetOutPathSO =
- this->Convert(targetFullPathSO.c_str(),HOME_OUTPUT,MAKEFILE);
+ this->Convert(targetFullPathSO.c_str(),START_OUTPUT,MAKEFILE);
std::string targetOutPathReal =
- this->Convert(targetFullPathReal.c_str(),HOME_OUTPUT,MAKEFILE);
+ this->Convert(targetFullPathReal.c_str(),START_OUTPUT,MAKEFILE);
std::string targetOutPathBase =
- this->Convert(targetFullPathBase.c_str(),HOME_OUTPUT,MAKEFILE);
+ this->Convert(targetFullPathBase.c_str(),START_OUTPUT,MAKEFILE);
// Add the link message.
std::string buildEcho = "Linking ";
@@ -1743,7 +1718,10 @@ cmLocalUnixMakefileGenerator3
// Construct the main link rule.
std::string linkRule = m_Makefile->GetRequiredDefinition(linkRuleVar);
- cmSystemTools::ExpandListArgument(linkRule, commands);
+ std::vector<std::string> commands1;
+ cmSystemTools::ExpandListArgument(linkRule, commands1);
+ this->CreateCDCommand(commands1);
+ commands.insert(commands.end(), commands1.begin(), commands1.end());
// Add a rule to create necessary symlinks for the library.
if(targetOutPath != targetOutPathReal)
@@ -1832,12 +1810,11 @@ cmLocalUnixMakefileGenerator3
ruleFileStream
<< "# Object files for target " << target.GetName() << "\n"
<< variableName.c_str() << " =";
- std::string relPath = this->GetHomeRelativeOutputPath();
std::string object;
for(std::vector<std::string>::const_iterator i = objects.begin();
i != objects.end(); ++i)
{
- object = relPath;
+ object.clear();
object += *i;
ruleFileStream
<< " \\\n"
@@ -1857,7 +1834,7 @@ cmLocalUnixMakefileGenerator3
for(std::vector<std::string>::const_iterator i = external_objects.begin();
i != external_objects.end(); ++i)
{
- object = this->Convert(i->c_str(),HOME_OUTPUT);
+ object = this->Convert(i->c_str(),START_OUTPUT);
ruleFileStream
<< " \\\n"
<< this->ConvertToQuotedOutputPath(object.c_str());
@@ -2340,8 +2317,6 @@ cmLocalUnixMakefileGenerator3
::AppendCustomCommand(std::vector<std::string>& commands,
const cmCustomCommand& cc)
{
- // TODO: Convert outputs/dependencies (arguments?) to relative paths.
-
std::vector<std::string> commands1;
// Add each command line to the set of commands.
@@ -2371,44 +2346,10 @@ cmLocalUnixMakefileGenerator3
commands1.push_back(cmd);
}
}
-
- // stick this group of commands into a cd of the proper path
- // Build the jump-and-build command list.
- if(m_WindowsShell)
- {
- // On Windows we must perform each step separately and then jump
- // back because the shell keeps the working directory between
- // commands.
- std::string cmd = "cd ";
- cmd += this->ConvertToOutputForExisting(m_Makefile->GetStartOutputDirectory());
- commands.push_back(cmd);
- // push back the custom commands
- commands.insert(commands.end(), commands1.begin(), commands1.end());
-
- // Jump back to the home directory.
- cmd = "cd ";
- cmd += this->ConvertToOutputForExisting(m_Makefile->GetHomeOutputDirectory());
- commands.push_back(cmd);
- }
- else
- {
- // On UNIX we must construct a single shell command to jump and
- // build because make resets the directory between each command.
- std::string cmd = "cd ";
- cmd += this->ConvertToOutputForExisting(m_Makefile->GetStartOutputDirectory());
-
- // add the commands
- unsigned int i;
- for (i = 0; i < commands1.size(); ++i)
- {
- cmd += " && ";
- cmd += commands1[i];
- }
-
- // Add the command as a single line.
- commands.push_back(cmd);
- }
+ // push back the custom commands
+ this->CreateCDCommand(commands1);
+ commands.insert(commands.end(), commands1.begin(), commands1.end());
}
//----------------------------------------------------------------------------
@@ -2990,9 +2931,7 @@ void cmLocalUnixMakefileGenerator3
}
void cmLocalUnixMakefileGenerator3
-::CreateJumpCommand(std::vector<std::string>& commands,
- const char *MakefileName,
- std::string& localName)
+::CreateCDCommand(std::vector<std::string>& commands)
{
if(m_WindowsShell)
{
@@ -3001,18 +2940,12 @@ void cmLocalUnixMakefileGenerator3
// commands.
std::string cmd = "cd ";
cmd += this->ConvertToOutputForExisting
- (m_Makefile->GetHomeOutputDirectory());
- commands.push_back(cmd);
-
- // Build the target for this pass.
- commands.push_back(this->GetRecursiveMakeCall
- (MakefileName,localName.c_str()));
+ (m_Makefile->GetStartOutputDirectory());
+ commands.insert(commands.begin(),cmd);
// Change back to the starting directory. Any trailing slash must be
// removed to avoid problems with Borland Make.
- std::string back =
- cmSystemTools::RelativePath(m_Makefile->GetHomeOutputDirectory(),
- m_Makefile->GetStartOutputDirectory());
+ std::string back = m_Makefile->GetHomeOutputDirectory();
if(back.size() && back[back.size()-1] == '/')
{
back = back.substr(0, back.size()-1);
@@ -3026,18 +2959,30 @@ void cmLocalUnixMakefileGenerator3
// On UNIX we must construct a single shell command to change
// directory and build because make resets the directory between
// each command.
- std::string cmd = "cd ";
- cmd += this->ConvertToOutputForExisting(m_Makefile->GetHomeOutputDirectory());
-
- // Build the target for this pass.
- cmd += " && ";
- cmd += this->GetRecursiveMakeCall(MakefileName,localName.c_str());
-
- // Add the command as a single line.
- commands.push_back(cmd);
+ std::vector<std::string>::iterator i = commands.begin();
+ for (; i != commands.end(); ++i)
+ {
+ std::string cmd = "cd ";
+ cmd += this->ConvertToOutputForExisting(m_Makefile->GetStartOutputDirectory());
+ cmd += " && ";
+ cmd += *i;
+ *i = cmd;
+ }
}
}
+void cmLocalUnixMakefileGenerator3
+::CreateJumpCommand(std::vector<std::string>& commands,
+ const char *MakefileName,
+ std::string& localName)
+{
+ // Build the target for this pass.
+ commands.push_back(this->GetRecursiveMakeCall
+ (MakefileName,localName.c_str()));
+
+ this->CreateCDCommand(commands);
+}
+
//----------------------------------------------------------------------------
void cmLocalUnixMakefileGenerator3::CheckDependencies(cmMakefile* mf,
bool verbose,
diff --git a/Source/cmLocalUnixMakefileGenerator3.h b/Source/cmLocalUnixMakefileGenerator3.h
index ea70e6a..466cf50 100644
--- a/Source/cmLocalUnixMakefileGenerator3.h
+++ b/Source/cmLocalUnixMakefileGenerator3.h
@@ -170,8 +170,11 @@ protected:
const char *MakefileName,
std::string & localName);
- // these two methods just compute reasonable values for m_LibraryOutputPath and
- // m_ExecutableOutputPath
+ // create a command that cds to the start dir then runs the commands
+ void CreateCDCommand(std::vector<std::string>& commands);
+
+ // these two methods just compute reasonable values for m_LibraryOutputPath
+ // and m_ExecutableOutputPath
void ConfigureOutputPaths();
void FormatOutputPath(std::string& path, const char* name);