diff options
author | Brad King <brad.king@kitware.com> | 2009-10-28 16:19:15 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-10-28 16:19:15 (GMT) |
commit | b38c2929b0aec6f7ac994ab1e9cbf13052ab1ad6 (patch) | |
tree | ce5d9ae3c3a39853b38ce29e7eb41a4a06206b5c | |
parent | 90b8164e444699d97982b199b423a529f66eb13e (diff) | |
download | CMake-b38c2929b0aec6f7ac994ab1e9cbf13052ab1ad6.zip CMake-b38c2929b0aec6f7ac994ab1e9cbf13052ab1ad6.tar.gz CMake-b38c2929b0aec6f7ac994ab1e9cbf13052ab1ad6.tar.bz2 |
Create a static library's output dir for VS 6
VS 6 forgets to create the output directory for a static library if it
differs from the intermediate files directory. We work around this VS
bug by creating a pre-link event on the library target to make the
directory.
-rw-r--r-- | Source/cmLocalVisualStudio6Generator.cxx | 33 | ||||
-rw-r--r-- | Source/cmLocalVisualStudio6Generator.h | 2 |
2 files changed, 35 insertions, 0 deletions
diff --git a/Source/cmLocalVisualStudio6Generator.cxx b/Source/cmLocalVisualStudio6Generator.cxx index 54f7bf4..2cf840d 100644 --- a/Source/cmLocalVisualStudio6Generator.cxx +++ b/Source/cmLocalVisualStudio6Generator.cxx @@ -825,6 +825,34 @@ void cmLocalVisualStudio6Generator::SetBuildType(BuildType b, } } +//---------------------------------------------------------------------------- +cmsys::auto_ptr<cmCustomCommand> +cmLocalVisualStudio6Generator::MaybeCreateOutputDir(cmTarget& target, + const char* config) +{ + cmsys::auto_ptr<cmCustomCommand> pcc; + + // VS6 forgets to create the output directory for archives if it + // differs from the intermediate directory. + if(target.GetType() != cmTarget::STATIC_LIBRARY) { return pcc; } + std::string outDir = target.GetDirectory(config, false); + + // Add a pre-link event to create the directory. + cmCustomCommandLine command; + command.push_back(this->Makefile->GetRequiredDefinition("CMAKE_COMMAND")); + command.push_back("-E"); + command.push_back("make_directory"); + command.push_back(outDir); + std::vector<std::string> no_output; + std::vector<std::string> no_depends; + cmCustomCommandLines commands; + commands.push_back(command); + pcc.reset(new cmCustomCommand(no_output, no_depends, commands, 0, 0)); + pcc->SetEscapeOldStyle(false); + pcc->SetEscapeAllowMakeVars(true); + return pcc; +} + // look for custom rules on a target and collect them together std::string cmLocalVisualStudio6Generator::CreateTargetRules(cmTarget &target, @@ -849,6 +877,11 @@ cmLocalVisualStudio6Generator::CreateTargetRules(cmTarget &target, { event.Write(*pcc); } + pcc = this->MaybeCreateOutputDir(target, configName); + if(pcc.get()) + { + event.Write(*pcc); + } event.Finish(); // Write the post-build rules. diff --git a/Source/cmLocalVisualStudio6Generator.h b/Source/cmLocalVisualStudio6Generator.h index 7279869..195d654 100644 --- a/Source/cmLocalVisualStudio6Generator.h +++ b/Source/cmLocalVisualStudio6Generator.h @@ -81,6 +81,8 @@ private: std::ostream &fout, const char *libName); class EventWriter; friend class EventWriter; + cmsys::auto_ptr<cmCustomCommand> + MaybeCreateOutputDir(cmTarget& target, const char* config); std::string CreateTargetRules(cmTarget &target, const char* configName, const char *libName); |