diff options
Diffstat (limited to 'Source/cmLocalGenerator.cxx')
-rw-r--r-- | Source/cmLocalGenerator.cxx | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/Source/cmLocalGenerator.cxx b/Source/cmLocalGenerator.cxx index d22a2ef..f91ed10 100644 --- a/Source/cmLocalGenerator.cxx +++ b/Source/cmLocalGenerator.cxx @@ -2700,7 +2700,8 @@ cmLocalGenerator std::string cmLocalGenerator ::GetObjectFileNameWithoutTarget(const cmSourceFile& source, - std::string::size_type dir_len) + std::string::size_type dir_len, + bool* hasSourceExtension) { // Construct the object file name using the full path to the source // file which is its only unique identification. @@ -2751,11 +2752,25 @@ cmLocalGenerator // Replace the original source file extension with the object file // extension. + bool keptSourceExtension = true; if(!source.GetPropertyAsBool("KEEP_EXTENSION")) { - // Remove the original extension for CMake 2.4 compatibility. - if(this->NeedBackwardsCompatibility(2, 4)) + // Decide whether this language wants to replace the source + // extension with the object extension. For CMake 2.4 + // compatibility do this by default. + bool replaceExt = this->NeedBackwardsCompatibility(2, 4); + if(!replaceExt) + { + std::string repVar = "CMAKE_"; + repVar += source.GetLanguage(); + repVar += "_OUTPUT_EXTENSION_REPLACE"; + replaceExt = this->Makefile->IsOn(repVar.c_str()); + } + + // Remove the source extension if it is to be replaced. + if(replaceExt) { + keptSourceExtension = false; std::string::size_type dot_pos = objectName.rfind("."); if(dot_pos != std::string::npos) { @@ -2767,6 +2782,10 @@ cmLocalGenerator objectName += this->GlobalGenerator->GetLanguageOutputExtension(source); } + if(hasSourceExtension) + { + *hasSourceExtension = keptSourceExtension; + } // Convert to a safe name. return this->CreateSafeUniqueObjectFileName(objectName.c_str(), dir_len); |