diff options
author | Brad King <brad.king@kitware.com> | 2007-02-01 21:56:36 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2007-02-01 21:56:36 (GMT) |
commit | 23d8525d460f0b4a4e2a2cc55f82bad87438c05c (patch) | |
tree | 5c0ad8426fe8107902377f1b81c1f3641411aecb | |
parent | 4bc0fd0941a97a86b2925562b717597f5ed0a2f4 (diff) | |
download | CMake-23d8525d460f0b4a4e2a2cc55f82bad87438c05c.zip CMake-23d8525d460f0b4a4e2a2cc55f82bad87438c05c.tar.gz CMake-23d8525d460f0b4a4e2a2cc55f82bad87438c05c.tar.bz2 |
BUG: Use the exe/lib output path for .pdb file location. This addresses bug#3277 and bug#4287.
-rw-r--r-- | Source/cmMakefileTargetGenerator.cxx | 28 |
1 files changed, 21 insertions, 7 deletions
diff --git a/Source/cmMakefileTargetGenerator.cxx b/Source/cmMakefileTargetGenerator.cxx index 3f4ae14..3245d2f 100644 --- a/Source/cmMakefileTargetGenerator.cxx +++ b/Source/cmMakefileTargetGenerator.cxx @@ -466,15 +466,29 @@ cmMakefileTargetGenerator this->Makefile->GetRequiredDefinition(compileRuleVar.c_str()); cmSystemTools::ExpandListArgument(compileRule, commands); - std::string outpath = this->Makefile->GetStartOutputDirectory(); - outpath += "/"; - outpath += this->Target->GetName(); - outpath += ".pdb"; - outpath = this->Convert(outpath.c_str(), cmLocalGenerator::FULL, - cmLocalGenerator::MAKEFILE); + std::string targetOutPathPDB; + { + std::string targetFullPathPDB; + const char* configName = this->LocalGenerator->ConfigurationName.c_str(); + if(this->Target->GetType() == cmTarget::EXECUTABLE) + { + targetFullPathPDB = this->LocalGenerator->ExecutableOutputPath; + targetFullPathPDB += this->Target->GetPDBName(configName); + } + else if(this->Target->GetType() == cmTarget::STATIC_LIBRARY || + this->Target->GetType() == cmTarget::SHARED_LIBRARY || + this->Target->GetType() == cmTarget::MODULE_LIBRARY) + { + targetFullPathPDB = this->LocalGenerator->LibraryOutputPath; + targetFullPathPDB += this->Target->GetPDBName(configName); + } + targetOutPathPDB = + this->Convert(targetFullPathPDB.c_str(),cmLocalGenerator::FULL, + cmLocalGenerator::MAKEFILE); + } cmLocalGenerator::RuleVariables vars; vars.Language = lang; - vars.TargetPDB = outpath.c_str(); + vars.TargetPDB = targetOutPathPDB.c_str(); vars.Source = sourceFile.c_str(); vars.Object = relativeObj.c_str(); std::string objdir = this->LocalGenerator->GetHomeRelativeOutputPath(); |