diff options
author | Michael Stürmer <michael.stuermer@schaeffler.com> | 2018-03-19 20:21:57 (GMT) |
---|---|---|
committer | Michael Stürmer <michael.stuermer@schaeffler.com> | 2018-04-23 05:31:22 (GMT) |
commit | f3c6828876f2f0dd8408868d90db1c4b323cba02 (patch) | |
tree | f2c146d9b938d0f403756a69e50c48f58ff2ad13 | |
parent | f9042d807db3264772dc08452195809b1f7a3a0c (diff) | |
download | CMake-f3c6828876f2f0dd8408868d90db1c4b323cba02.zip CMake-f3c6828876f2f0dd8408868d90db1c4b323cba02.tar.gz CMake-f3c6828876f2f0dd8408868d90db1c4b323cba02.tar.bz2 |
cmVisualStudio10TargetGenerator: /clr compatible flags for managed tgt
-rw-r--r-- | Source/cmVisualStudio10TargetGenerator.cxx | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/Source/cmVisualStudio10TargetGenerator.cxx b/Source/cmVisualStudio10TargetGenerator.cxx index f52e79a..4dabb4c 100644 --- a/Source/cmVisualStudio10TargetGenerator.cxx +++ b/Source/cmVisualStudio10TargetGenerator.cxx @@ -2550,10 +2550,15 @@ bool cmVisualStudio10TargetGenerator::ComputeClOptions( if (this->ProjectType != csproj && clOptions.IsManaged()) { this->Managed = true; std::string managedType = clOptions.GetFlag("CompileAsManaged"); - if (managedType == "Safe") { + if (managedType == "Safe" || managedType == "Pure") { // force empty calling convention if safe clr is used clOptions.AddFlag("CallingConvention", ""); } + // The default values of these flags are incompatible to + // managed assemblies. We have to force valid values if + // the target is a managed C++ target. + clOptions.AddFlag("ExceptionHandling", "Async"); + clOptions.AddFlag("BasicRuntimeChecks", "Default"); } if (this->ProjectType == csproj) { // /nowin32manifest overrides /win32manifest: parameter |