diff options
author | Brad King <brad.king@kitware.com> | 2006-07-11 17:23:02 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2006-07-11 17:23:02 (GMT) |
commit | 87ef95c71549a7aada8be6ed5d7f45f0aefc85ce (patch) | |
tree | f66b08d39d0942d7813e92dd0f843a45870fc468 /Source | |
parent | 9bf5af6e32570195b06df594c1cb07f8c7a6a83e (diff) | |
download | CMake-87ef95c71549a7aada8be6ed5d7f45f0aefc85ce.zip CMake-87ef95c71549a7aada8be6ed5d7f45f0aefc85ce.tar.gz CMake-87ef95c71549a7aada8be6ed5d7f45f0aefc85ce.tar.bz2 |
ENH: Made cmLocalVisualStudioGenerator a superclass of cmLocalVisualStudio6Generator. Implemented object file unique naming when multiple sources share the same name.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmLocalVisualStudio6Generator.cxx | 29 | ||||
-rw-r--r-- | Source/cmLocalVisualStudio6Generator.h | 4 |
2 files changed, 29 insertions, 4 deletions
diff --git a/Source/cmLocalVisualStudio6Generator.cxx b/Source/cmLocalVisualStudio6Generator.cxx index a12d0e7..54bdafe 100644 --- a/Source/cmLocalVisualStudio6Generator.cxx +++ b/Source/cmLocalVisualStudio6Generator.cxx @@ -359,6 +359,9 @@ void cmLocalVisualStudio6Generator::WriteDSPFile(std::ostream& fout, } } } + + // Compute which sources need unique object computation. + this->ComputeObjectNameRequirements(sourceGroups); // Write the DSP file's header. this->WriteDSPHeader(fout, libName, target, sourceGroups); @@ -404,6 +407,13 @@ void cmLocalVisualStudio6Generator (*sf)->GetCustomCommand(); std::string compileFlags; std::vector<std::string> depends; + std::string objectNameDir; + if(this->NeedObjectName.find(*sf) != this->NeedObjectName.end()) + { + objectNameDir = + cmSystemTools::GetFilenamePath( + this->GetObjectFileNameWithoutTarget(*(*sf))); + } // Add per-source file flags. if(const char* cflags = (*sf)->GetProperty("COMPILE_FLAGS")) @@ -464,7 +474,7 @@ void cmLocalVisualStudio6Generator comment.c_str(), command->GetDepends(), command->GetOutputs(), flags); } - else if(compileFlags.size()) + else if(!compileFlags.empty() || !objectNameDir.empty()) { for(std::vector<std::string>::iterator i = this->Configurations.begin(); @@ -478,7 +488,22 @@ void cmLocalVisualStudio6Generator { fout << "!ELSEIF \"$(CFG)\" == " << i->c_str() << std::endl; } - fout << "\n# ADD CPP " << compileFlags << "\n\n"; + if(!compileFlags.empty()) + { + fout << "\n# ADD CPP " << compileFlags << "\n\n"; + } + if(!objectNameDir.empty()) + { + // Strip the subdirectory name out of the configuration name. + std::string config = *i; + std::string::size_type pos = config.find_last_of(" "); + config = config.substr(pos+1, std::string::npos); + config = config.substr(0, config.size()-1); + + // Setup an alternate object file directory. + fout << "\n# PROP Intermediate_Dir \"" + << config << "/" << objectNameDir << "\"\n\n"; + } } fout << "!ENDIF\n\n"; } diff --git a/Source/cmLocalVisualStudio6Generator.h b/Source/cmLocalVisualStudio6Generator.h index f2b4d13..cdc246f 100644 --- a/Source/cmLocalVisualStudio6Generator.h +++ b/Source/cmLocalVisualStudio6Generator.h @@ -17,7 +17,7 @@ #ifndef cmLocalVisualStudio6Generator_h #define cmLocalVisualStudio6Generator_h -#include "cmLocalGenerator.h" +#include "cmLocalVisualStudioGenerator.h" class cmMakeDepend; class cmTarget; @@ -31,7 +31,7 @@ class cmCustomCommand; * cmLocalVisualStudio6Generator produces a LocalUnix makefile from its * member this->Makefile. */ -class cmLocalVisualStudio6Generator : public cmLocalGenerator +class cmLocalVisualStudio6Generator : public cmLocalVisualStudioGenerator { public: ///! Set cache only and recurse to false by default. |