diff options
author | Peter Ivanyi <pivanyi71@gmail.com> | 2017-05-02 23:07:26 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2017-05-03 16:48:53 (GMT) |
commit | ea6bb8293f50ecc93f42b6ea6525baa0252712a5 (patch) | |
tree | c97fead69c1fc5ac9aac7d872ec2e304312bb9b9 | |
parent | da9076e422667322ceb04afa1ff43f69bba4c879 (diff) | |
download | CMake-ea6bb8293f50ecc93f42b6ea6525baa0252712a5.zip CMake-ea6bb8293f50ecc93f42b6ea6525baa0252712a5.tar.gz CMake-ea6bb8293f50ecc93f42b6ea6525baa0252712a5.tar.bz2 |
VS: Use tool-specific flag table for COMPILE_FLAGS parsing
Fixes: #14710
-rw-r--r-- | Source/cmVisualStudio10TargetGenerator.cxx | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/Source/cmVisualStudio10TargetGenerator.cxx b/Source/cmVisualStudio10TargetGenerator.cxx index 5a09718..c81ba7a 100644 --- a/Source/cmVisualStudio10TargetGenerator.cxx +++ b/Source/cmVisualStudio10TargetGenerator.cxx @@ -1943,9 +1943,24 @@ bool cmVisualStudio10TargetGenerator::OutputSourceSpecificFlags( hasFlags = true; cmGlobalVisualStudio10Generator* gg = static_cast<cmGlobalVisualStudio10Generator*>(this->GlobalGenerator); + cmIDEFlagTable const* flagtable = CM_NULLPTR; + const std::string& srclang = source->GetLanguage(); + if (srclang == "C" || srclang == "CXX") { + flagtable = gg->GetClFlagTable(); + } else if (srclang == "ASM_MASM" && + this->GlobalGenerator->IsMasmEnabled()) { + flagtable = gg->GetMasmFlagTable(); + } else if (lang == "ASM_NASM" && + this->GlobalGenerator->IsNasmEnabled()) { + flagtable = gg->GetNasmFlagTable(); + } else if (srclang == "RC") { + flagtable = gg->GetRcFlagTable(); + } else if (srclang == "CSharp") { + flagtable = gg->GetCSharpFlagTable(); + } cmVisualStudioGeneratorOptions clOptions( this->LocalGenerator, cmVisualStudioGeneratorOptions::Compiler, - gg->GetClFlagTable(), 0, this); + flagtable, 0, this); if (compileAs) { clOptions.AddFlag("CompileAs", compileAs); } |