Browse Source

VS: Place source-specific AdditionalOptions after target-wide flags

Flags specified in the `COMPILE_FLAGS` source-file property should
be placed after those in target-wide properties so that those on
individual source files can override those on the whole target.
This is already done by most generators but was not implemented
correctly for VS 2010 and above.

Closes: #16400
Brad King 9 years ago
parent
commit
4cb5d3353f
2 changed files with 12 additions and 2 deletions
  1. 9 0
      Help/release/dev/vs-flag-order.rst
  2. 3 2
      Source/cmVisualStudioGeneratorOptions.cxx

+ 9 - 0
Help/release/dev/vs-flag-order.rst

@@ -0,0 +1,9 @@
+vs-flag-order
+-------------
+
+* The :ref:`Visual Studio Generators` for VS 2010 and above now place
+  per-source file flags after target-wide flags when they are classified
+  as raw flags with no project file setting (``AdditionalOptions``).
+  This behavior is more consistent with the ordering of flags produced
+  by other generators, and allows flags on more-specific properties
+  (per-source) to override those on more general ones (per-target).

+ 3 - 2
Source/cmVisualStudioGeneratorOptions.cxx

@@ -334,8 +334,9 @@ void cmVisualStudioGeneratorOptions::OutputAdditionalOptions(
       } else {
       } else {
         fout << "<AdditionalOptions>";
         fout << "<AdditionalOptions>";
       }
       }
-      fout << cmVisualStudio10GeneratorOptionsEscapeForXML(this->FlagString)
-           << " %(AdditionalOptions)</AdditionalOptions>\n";
+      fout << "%(AdditionalOptions) "
+           << cmVisualStudio10GeneratorOptionsEscapeForXML(this->FlagString)
+           << "</AdditionalOptions>\n";
     } else {
     } else {
       fout << prefix << "AdditionalOptions=\"";
       fout << prefix << "AdditionalOptions=\"";
       fout << cmVisualStudioGeneratorOptionsEscapeForXML(this->FlagString);
       fout << cmVisualStudioGeneratorOptionsEscapeForXML(this->FlagString);