Skip to content

Commit

Permalink
Merge pull request MicrosoftDocs#6780 from MicrosoftDocs/master637595…
Browse files Browse the repository at this point in the history
…506323042891

For protected CLA branch, push strategy should use PR and merge to target branch method to work around git push error
  • Loading branch information
ghogen authored Jun 17, 2021
2 parents 1ecc972 + b72ce13 commit a4de961
Show file tree
Hide file tree
Showing 101 changed files with 2,588 additions and 875 deletions.
6 changes: 6 additions & 0 deletions docs/containers/edit-and-refresh.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,12 @@ To debug apps in a local Docker container, the following tools must be installed

::: moniker-end

::: moniker range="vs-2022"

* [Visual Studio 2022 Preview]() with the Web Development workload installed

::: moniker-end

To run Docker containers locally, you must have a local Docker client. You can use [Docker for Windows](https://www.docker.com/get-docker), which uses Hyper-V and requires Windows 10.

Docker containers are available for .NET Framework and .NET Core projects. Let's look at two examples. First, we look at a .NET Core web app. Then, we look at a .NET Framework console app.
Expand Down
16 changes: 13 additions & 3 deletions docs/containers/tutorial-multicontainer.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,17 +15,27 @@ In this tutorial, you'll learn how to manage more than one container and communi
## Prerequisites

::: moniker range="vs-2017"

* [Docker Desktop](https://hub.docker.com/editions/community/docker-ce-desktop-windows)
* [Visual Studio 2017](https://visualstudio.microsoft.com/vs/older-downloads/?utm_medium=microsoft&utm_source=docs.microsoft.com&utm_campaign=vs+2017+download) with the **Web Development**, **Azure Tools** workload, or **.NET Core cross-platform development** workload installed
::: moniker-end

::: moniker range=">= vs-2019"
::: moniker range="vs-2019"

* [Docker Desktop](https://hub.docker.com/editions/community/docker-ce-desktop-windows)
* [Visual Studio 2019](https://visualstudio.microsoft.com/downloads) with the **Web Development**, **Azure Tools** workload, and/or **.NET Core cross-platform development** workload installed
* [.NET Core 2.2 Development Tools](https://dotnet.microsoft.com/download/dotnet-core/2.2) for development with .NET Core 2.2
* [.NET Core 3 Development Tools](https://dotnet.microsoft.com/download/dotnet-core/3.1) for development with .NET Core 3.1.
::: moniker-end

::: moniker range=">=vs-2022"

* [Docker Desktop](https://hub.docker.com/editions/community/docker-ce-desktop-windows)
* [Visual Studio 2022 Preview](https://visualstudio.microsoft.com/vs/preview/vs2022) with the **Web Development**, **Azure Tools** workload, and/or **.NET Core cross-platform development** workload installed
* [.NET Core 3 Development Tools](https://dotnet.microsoft.com/download/dotnet-core/3.1) for development with .NET Core 3.1.
* [.NET 5 Development Toos](https://dotnet.microsoft.com/download/dotnet-core/5.0) for development with .NET 5.
::: moniker-end

## Create a Web Application project

In Visual Studio, create an **ASP.NET Core Web App** project, named `WebFrontEnd`, to create a web application with Razor pages.
Expand All @@ -38,7 +48,7 @@ Do not select **Enable Docker Support**. You'll add Docker support later.

::: moniker-end

::: moniker range="vs-2019"
::: moniker range=">=vs-2019"

![Create ASP.NET Core Web App project](./media/tutorial-multicontainer/vs-2019/create-web-project1.png)

Expand All @@ -55,7 +65,7 @@ Add a project to the same solution and call it *MyWebAPI*. Select **API** as the
::: moniker range="vs-2017"
![Screenshot of creating the Web API project](./media/tutorial-multicontainer/docker-tutorial-mywebapi.png)
::: moniker-end
::: moniker range="vs-2019"
::: moniker range=">=vs-2019"
![Screenshot of creating the Web API project](./media/tutorial-multicontainer/vs-2019/create-webapi-project.png)
::: moniker-end

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ Here is the list of software that you need:

::: moniker-end

::: moniker range="vs-2019"
::: moniker range=">=vs-2019"

- [Windows 10](https://support.microsoft.com/help/17777/downloads-for-windows). Visual Studio 2019 supports UWP development only on Windows 10. For more details, see Visual Studio [Platform targeting](/visualstudio/releases/2019/compatibility/) and [System requirements](/visualstudio/releases/2019/system-requirements/).

Expand Down
4 changes: 2 additions & 2 deletions docs/data-tools/add-new-data-sources.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,9 @@ ms.workload:
---
# Add new data sources

:::moniker range="vs-2019"
:::moniker range=">=vs-2019"
> [!NOTE]
> The features described in this article apply to .NET Framework Windows Forms and WPF development. In Visual Studio 2019 (and previous versions), the features are not supported for .NET Core development, for both WPF and Windows Forms.
> The features described in this article apply to .NET Framework Windows Forms and WPF development. The features are not supported for .NET Core development, for both WPF and Windows Forms.
:::moniker-end

In the context of .NET data tools in Visual Studio, the term *data source* refers to .NET objects that connect to a data store and make the data available to a .NET application. The Visual Studio designers can consume the output of the data source to generate the boilerplate code that binds the data to forms when you drag and drop database objects from the **Data Sources** window. This kind of data source can be:
Expand Down
6 changes: 6 additions & 0 deletions docs/debugger/getting-started-with-the-debugger-cpp.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,12 @@ If you haven't already installed Visual Studio, go to the [Visual Studio downloa

::: moniker-end

::: moniker range="vs-2022"

If you haven't already installed Visual Studio 2022 Preview, go to the [Visual Studio 2022 Preview downloads](https://visualstudio.microsoft.com/vs/preview/vs2022) page to install it for free.

::: moniker-end

If you need to install the workload but already have Visual Studio, go to **Tools** > **Get Tools and Features...**, which opens the Visual Studio Installer. The Visual Studio Installer launches. Choose the **Desktop development with C++** workload, then choose **Modify**.

## Create a project
Expand Down
7 changes: 7 additions & 0 deletions docs/extensibility/includes/preview-note.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
ms.topic: include
ms.author: ghogen
author: ghogen
---
> [!IMPORTANT]
> Visual Studio 2022 is currently in preview and is not [licensed](https://visualstudio.microsoft.com/license-terms/vs2022-prerelease/) for use in production environments.
134 changes: 134 additions & 0 deletions docs/extensibility/migration/breaking-api-list.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
---
title: Breaking API changes in Visual Studio 2022 Preview
description: Learn about API changes that cause existing VS extensions to fail to compile when migrating extensions to Visual Studio 2022 Preview.
ms.date: 06/08/2021
ms.topic: reference
author: leslierichardson95
ms.author: lerich
manager: jmartens
monikerRange: "vs-2022"
ms.workload:
- vssdk
---
# Breaking API changes in Visual Studio 2022

[!INCLUDE [preview-note](../includes/preview-note.md)]

If you're migrating an extension to Visual Studio 2022, the breaking changes listed here might affect you.

## Reference assemblies no longer installed

Many of the assemblies you may have been referencing that MSBuild resolved from a Visual Studio installation directory are no longer installed. You should use NuGet to acquire the Visual Studio SDK ref assemblies you need. See [Modernize projects](update-visual-studio-extension.md#modernize-your-vsix-project) for detailed steps on doing this.

## Removed APIs

In Visual Studio 2022 a number of APIs have been removed as part of moving Visual Studio going forward. A list of the removed APIs can be found on the [Removed API List](removed-api-list.md) page.

## Interop breaking changes

Many of our APIs have changed in Visual Studio 2022, usually with simple changes that are straightforward for your code to accommodate.

To manage the breaking changes, we are planning to provide a new mechanism for the distribution of interop assemblies. Specifically, for
Visual Studio 2022 and beyond we provide a single interop assembly with definitions for many common public Visual Studio interface. That
assembly contains managed definitions for many Visual Studio interfaces moving away from multiple interop assemblies. The new interop
assembly is be distributed via the `Microsoft.VisualStudio.Interop` NuGet package.

However, Visual Studio components that are primarily used in native contexts and have a low number of breaking changes will continue to have
their own interop assemblies (for example, the debugger assembly will still be VisualStudio.Debugger.Interop.dll as it does today). In any case the assemblies can be then referenced from your application, just as they are today.

This is a significant change and means that extensions that use APIs in and assembly built in this new approach are not compatible with older
versions of Visual Studio using the previous interop assembly.

This has a few very important advantages that will make updating your extension to Visual Studio 2022 easier:

- Any broken APIs will become build time errors making them easier to find and fix.
- You only need to update code that uses an API that was broken in Visual Studio 2022.
- You will not be able to accidentally use the old, now broken API.

Overall, these changes will result in a more stable version of Visual Studio for all users. The major drawback of this approach is that your
managed assemblies will not be able to run in both Visual Studio 2019 and Visual Studio 2022 without compiling your code once for each target Visual Studio version.

As you work through compile errors due to the API differences between Visual Studio 2019 and Visual Studio 2022, you may find the API or pattern you're facing listed below with guidance on how to fix it.

### `int` or `uint` where `IntPtr` is expected

We expect this will be a very common error. To make Visual Studio 2022 a 64-bit process, some of our interop APIs had to be fixed
where they assumed a pointer could fit in a 32-bit integer to actually use a pointer-sized value.

Sample error:

> Argument 3: cannot convert from 'out uint' to 'out System.IntPtr'
Simply update your code to expect or provide `IntPtr` or `UIntPtr` where `int` or `uint` used to be to resolve the break.

Sample fix:

```diff
-shell.LoadLibrary(myGuid, myFlags, out uint ptrLib);
+shell.LoadLibrary(myGuid, myFlags, out IntPtr ptrLib);
```

### An interop type defined in two assemblies

When C# compiler reports an error that a type you're using is defined in two assemblies, you probably are referencing an assembly from the Visual Studio 2019 version of the SDK that you should no longer reference.

Sample error:

> error CS0433: The type 'IVsDpiAware' exists in both 'Microsoft.VisualStudio.Interop, Version=17.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' and 'Microsoft.VisualStudio.Shell.Interop.16.0.DesignTime, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a'
Refer to our [reference assembly remapping table](migrated-assemblies.md) to see which assembly name is the preferred name in Visual Studio 2022.
Considering the two assemblies named in the sample error above and looking at this table, notice that `Microsoft.VisualStudio.Interop` is the new assembly name. The fix then would be to remove the reference to `Microsoft.VisualStudio.Shell.Interop.16.0.DesignTime` from the project.

In some cases we offer a Visual Studio 2022-versioned package for the deprecated assembly that contains type forwarders. When this is available, you have the option to *upgrade* your package reference to the Visual Studio 2022 version instead of removing it. The type forwarders will resolve the error from the compiler.

Keep in mind that sometimes these references can come by transitive package reference, and thus can be harder to remove than a direct reference made in your project file. In such cases, make sure all your direct package references all are using Visual Studio 2022 SDK packages themselves. You may refer to *project.assets.json* to identify the chain of packages responsible for bringing in the deprecated assembly. Updating a transitive package reference to a Visual Studio 2022 version is as easy as installing it as a direct reference.

If you cannot change the dependency tree (for example, because it involves a third-party dependency), you can add a direct package reference to the pre-Visual Studio 2022 package and add `ExcludeAssets="compile"` metadata to that `PackageReference` item to solve the compiler error. But keep in mind that with this technique, your extension may retain a dependency on a pre-Visual Studio 2022 assembly and your extension may malfunction at runtime.

### Missing reference to an interop assembly

When you reference an assembly that compiled against the pre-Visual Studio 2022 SDK, you may get an error about missing an assembly reference.

Sample error:

> Error CS0012 The type 'IVsTextViewFilter' is defined in an assembly that is not referenced. You must add a reference to assembly 'Microsoft.VisualStudio.TextManager.Interop, Version=7.1.40304.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a'
Using the [reference assembly remapping table](migrated-assemblies.md), you can confirm that the requested assembly is in fact not one you should have to reference.

The best fix is to update your dependency to a version that compiled against the Visual Studio 2022 SDK so the removed interop assembly is no longer requested by the compiler.

In some cases we offer a Visual Studio 2022-versioned package for the deprecated assembly that contains type forwarders. When this is available, you have the option to add a package reference to the Visual Studio 2022 version of the obsolete package so the type forwarders will resolve the error from the compiler.

### `IAsyncServiceProvider` is missing

There are two definitions of this interface, in two namespaces. Only one of these was intended for managed consumption.

Visual Studio 2019 Namespace | Visual Studio 2022 Namespace | Intended use
--|--|--
Microsoft.VisualStudio.Shell.IAsyncServiceProvider | Microsoft.VisualStudio.Shell.IAsyncServiceProvider | Managed code consumption
Microsoft.VisualStudio.Shell.Interop.IAsyncServiceProvider | Microsoft.VisualStudio.Shell.COMAsyncServiceProvider.IAsyncServiceProvider | low-level interop only

If you see an error about `IAsyncServiceProvider`, it *may* be that you were using the one intended for native code (the second row).
If so, you can update to the new namespace, or switch to the more managed-friendly interface.

### `DTE` and `_DTE` type cast failures

`DTE` and `_DTE` are both interfaces. One derives from the other. However in Visual Studio 2022, the base and derived types are swapped.
This makes certain type assignments or casts fail.

This also means where you used to use `new DTE()`, you must now use `new _DTE()`.

### Missing argument on a method invocation

A few methods no longer declare default arguments for what were optional parameters in the interop API.
If you get an error about a missing argument for a COM interop call, and the parameter calls for an `object` type, the previous default value that the Visual Studio 2019 interop API defined may have been `""`, so consider adding `""` as your argument
to resolve the compile error.

When in doubt about what the default argument used to be, try switching your language service context from Visual Studio 2022 to Visual Studio 2019 so you get Intellisense with the older interop assemblies to see what the default argument was, and then add it explicitly to your code. It will continue to work fine when compiled for Visual Studio 2019, but will now compile for Visual Studio 2022.

Sample fix:

```diff
-process4.Attach2();
+process4.Attach2("");
```
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading

0 comments on commit a4de961

Please sign in to comment.