summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2007-05-23 16:05:05 (GMT)
committerBrad King <brad.king@kitware.com>2007-05-23 16:05:05 (GMT)
commit702d785c9ae49015a770530a9c5f27e7bfaff716 (patch)
tree226ae4caef7654d169f0007405e892734471c1b4
parent2d051a67098333625a2c3f8a25b65936aa889239 (diff)
downloadCMake-702d785c9ae49015a770530a9c5f27e7bfaff716.zip
CMake-702d785c9ae49015a770530a9c5f27e7bfaff716.tar.gz
CMake-702d785c9ae49015a770530a9c5f27e7bfaff716.tar.bz2
BUG: Add ./ to custom command executables in the top of the build tree even when the path is generated by target name replacement.
-rw-r--r--Source/cmLocalUnixMakefileGenerator3.cxx9
1 files changed, 6 insertions, 3 deletions
diff --git a/Source/cmLocalUnixMakefileGenerator3.cxx b/Source/cmLocalUnixMakefileGenerator3.cxx
index 08289ba..bd8949d 100644
--- a/Source/cmLocalUnixMakefileGenerator3.cxx
+++ b/Source/cmLocalUnixMakefileGenerator3.cxx
@@ -915,14 +915,17 @@ cmLocalUnixMakefileGenerator3
cmSystemTools::ReplaceString(cmd, "/./", "/");
// Convert the command to a relative path only if the current
// working directory will be the start-output directory.
+ bool had_slash = cmd.find("/") != cmd.npos;
if(!workingDir)
{
cmd = this->Convert(cmd.c_str(),START_OUTPUT);
}
- if(cmd.find("/") == cmd.npos &&
- commandLine[0].find("/") != cmd.npos)
+ bool has_slash = cmd.find("/") != cmd.npos;
+ if(had_slash && !has_slash)
{
- // Add a leading "./" for executables in the current directory.
+ // This command was specified as a path to a file in the
+ // current directory. Add a leading "./" so it can run
+ // without the current directory being in the search path.
cmd = "./" + cmd;
}
cmd = this->Convert(cmd.c_str(),NONE,SHELL);