From f3e288a88ab9c63abad2c151b01960d67ba81512 Mon Sep 17 00:00:00 2001 From: "Andy (Steve) De George" <67293991+adegeo@users.noreply.github.com> Date: Wed, 24 Jan 2024 09:52:31 -0800 Subject: [PATCH] Add some clarifications around C++/CLI projects (#39228) * Update article * Apply suggestions from code review Co-authored-by: Genevieve Warren <24882762+gewarren@users.noreply.github.com> * minor --------- Co-authored-by: Genevieve Warren <24882762+gewarren@users.noreply.github.com> --- docs/core/porting/cpp-cli.md | 87 +++++++++++++++++++----------------- 1 file changed, 46 insertions(+), 41 deletions(-) diff --git a/docs/core/porting/cpp-cli.md b/docs/core/porting/cpp-cli.md index 80a1bde41fa31..0418a21b2e0c1 100644 --- a/docs/core/porting/cpp-cli.md +++ b/docs/core/porting/cpp-cli.md @@ -1,52 +1,57 @@ --- -title: Migrate C++/CLI projects to .NET Core and .NET 5+ -description: Learn about porting C++/CLI projects to .NET Core and .NET 5 and later versions. +title: Migrate C++/CLI projects to .NET +description: Learn about porting C++/CLI projects to .NET. author: mjrousos -ms.date: 10/27/2023 +ms.date: 01/23/2024 --- -# How to port a C++/CLI project to .NET Core or .NET 5+ +# How to port a C++/CLI project to .NET -Beginning with .NET Core 3.1 and Visual Studio 2019, [C++/CLI projects](/cpp/dotnet/dotnet-programming-with-cpp-cli-visual-cpp) can target .NET Core. This support makes it possible to port Windows desktop applications with C++/CLI interop layers to .NET Core/.NET 5+. This article describes how to port C++/CLI projects from .NET Framework to .NET Core 3.1. +Beginning with Visual Studio 2019, [C++/CLI projects](/cpp/dotnet/dotnet-programming-with-cpp-cli-visual-cpp) can target .NET. This support makes it possible to port Windows desktop applications with C++/CLI interop layers from .NET Framework to .NET. This article describes how to port C++/CLI projects from .NET Framework to .NET. ## C++/CLI .NET Core limitations -There are some important limitations to porting C++/CLI projects to .NET Core compared to other languages: +There are some important limitations with C++/CLI projects and .NET compared to .NET Framework: -- C++/CLI support for .NET Core is Windows only. -- C++/CLI projects can't target .NET Standard, only .NET Core or .NET Framework. -- C++/CLI projects don't support the new SDK-style project file format. Instead, even when targeting .NET Core, C++/CLI projects use the existing *.vcxproj* file format. -- C++/CLI projects can't multitarget multiple .NET platforms. If you need to build a C++/CLI project for both .NET Framework and .NET Core, use separate project files. -- .NET Core doesn't support `-clr:pure` or `-clr:safe` compilation, only the new `-clr:netcore` option (which is equivalent to `-clr` for .NET Framework). +- Compiling a C++/CLI project to an executable isn't supported. You must compile to a DLL. +- C++/CLI support for .NET is Windows only. +- C++/CLI projects can't target .NET Standard. +- C++/CLI projects don't support the newer SDK-style project file format. Instead, C++/CLI projects use the same _.vcxproj_ file format that other Visual Studio C++ projects use. +- C++/CLI projects can't target multiple .NET platforms. If you need to build a C++/CLI project for both .NET and .NET Framework, use separate project files. +- .NET doesn't support `-clr:pure` or `-clr:safe` compilation, only the newer `-clr:netcore` option (which is equivalent to `-clr` for .NET Framework). ## Port a C++/CLI project -To port a C++/CLI project to .NET Core, make the following changes to the *.vcxproj* file. These migration steps differ from the steps needed for other project types because C++/CLI projects don't use SDK-style project files. +To port a C++/CLI project to .NET, make the following changes to the _.vcxproj_ file. These migration steps differ from the steps needed for other project types because C++/CLI projects don't use SDK-style project files. -1. Replace `true` properties with `NetCore`. This property is often in configuration-specific property groups, so you might need to replace it in multiple places. -2. Replace `` properties with `netcoreapp3.1`. Be sure to change the tag as well as the value. -3. Remove any .NET Framework references to `System`, `System.Data`, `System.Windows.Forms`, and `System.Xml`, like ``. .NET Core SDK assemblies are automatically referenced when using `NetCore`. -4. Update API usage in *.cpp* files, as necessary, to remove APIs unavailable to .NET Core. Because C++/CLI projects tend to be fairly thin interop layers, there are often not many changes needed. You can use the [.NET Portability Analyzer](../../standard/analyzers/portability-analyzer.md) to identify unsupported .NET APIs used by C++/CLI binaries just as with purely managed binaries. +01. Replace `true` properties with `NetCore`. This property is often in configuration-specific property groups, so you might need to replace it in multiple places. +01. Replace `` properties with `net8.0`. Be sure to change the tag and value. +01. Remove any .NET Framework references to `System`, `System.Data`, `System.Windows.Forms`, and `System.Xml`, like ``. .NET SDK assemblies are automatically referenced when using `NetCore`. +01. Update API usage in _.cpp_ files, as necessary, to remove APIs unavailable to .NET. Because C++/CLI projects tend to be fairly thin interop layers, there are often not many changes needed. You can use the [.NET Portability Analyzer](../../standard/analyzers/portability-analyzer.md) to identify unsupported .NET APIs used by C++/CLI binaries. +01. If your project was an executable, perform the following steps: + 01. Change the project type to a library. + 01. Create a new .NET executable project. + 01. In the .NET executable project, add reference the C++/CLI .NET library. ### WPF and Windows Forms usage -.NET Core C++/CLI projects can use Windows Forms and WPF APIs. To use these Windows desktop APIs, you need to add explicit framework references to the UI libraries. SDK-style projects that use Windows desktop APIs reference the necessary framework libraries automatically by using the `Microsoft.NET.Sdk.WindowsDesktop` SDK. Because C++/CLI projects don't use the SDK-style project format, they need to add explicit framework references when targeting .NET Core. +.NET C++/CLI projects can use Windows Forms and WPF APIs. To use these Windows desktop APIs, you need to add explicit framework references to the UI libraries. SDK-style projects that use Windows desktop APIs reference the necessary framework libraries automatically by using the `Microsoft.NET.Sdk.WindowsDesktop` SDK. Because C++/CLI projects don't use the SDK-style project format, they need to add explicit framework references when targeting .NET Core. -To use Windows Forms APIs, add this reference to the *.vcxproj* file: +To use Windows Forms APIs, add this reference to the _.vcxproj_ file: ```xml ``` -To use WPF APIs, add this reference to the *.vcxproj* file: +To use WPF APIs, add this reference to the _.vcxproj_ file: ```xml ``` -To use both Windows Forms and WPF APIs, add this reference to the *.vcxproj* file: +To use both Windows Forms and WPF APIs, add this reference to the _.vcxproj_ file: ```xml