From 776acc24ced4974629bd4ecf5ef62e741a4470a1 Mon Sep 17 00:00:00 2001 From: "Tom Meschter (from Dev Box)" Date: Mon, 12 Aug 2024 13:35:22 -0700 Subject: [PATCH 1/3] Update docs Updates docs to include more information on project system selectors. --- docs/opening-with-new-project-system.md | 47 ++++++++++++++++++++++--- 1 file changed, 43 insertions(+), 4 deletions(-) diff --git a/docs/opening-with-new-project-system.md b/docs/opening-with-new-project-system.md index 88a862b58ff..1e711382cbb 100644 --- a/docs/opening-with-new-project-system.md +++ b/docs/opening-with-new-project-system.md @@ -1,12 +1,51 @@ # Opening with the new project system +## Background + +The solution (.sln) file specifies which project system should be used to open each project. For example: + +``` +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Library3", "Library3.csproj", "{ADFEAAF5-225C-4E13-8B65-77057AAC44B8}" +EndProject +``` + +Here the "Library3.csproj" project should be opened with the project system designated by the "FAE04EC0-301F-11D3-BF4B-00C04F79EFBC" GUID. + +While the solution file entry associates a specific project with a specific project system, ultimately this information comes from the [ProviderProjectFactoryAttribute](https://learn.microsoft.com/en-us/dotnet/api/microsoft.visualstudio.shell.provideprojectfactoryattribute)--or the equivalent entries in a .pkgdef file--which associates a file extension (like .csproj) with a project system. + +## Problem + +There may be situations where more than one project system is capable of loading project files with a particular extension, or where the choice of project system needs to be dynamically determined. In this case the solution file itself does not contain enough information for the correct project system to be determined. + +## General Solution + +One option is to provide some sort of upgrade tool that can analyze the solution file and project, recommend the user switch that project to a different project system, and then make the required changes to the solution file on their behalf. However, this requires interactions with the user (which may become noisy if there are a lot of projects to upgrade) changes to the solution file (which the user may not understand) and reloading the project. This is also not a particularly dynamic approach as the change to the project system is persisted in the solution file. + +To better address the situation where you may need to dynamically choose the project system, VS provides the [IVsProjectSystemSelector](https://learn.microsoft.com/en-us/dotnet/api/microsoft.visualstudio.shell.interop.ivsprojectselector) interface. Implementations of this interface are associated with a particular project system, and are called before a project is loaded in order to redirect the load to a different project system. + +When an IVsProjectSystemSelector is in play, the following sequence of events occurs before a project is loaded: + +1. The solution loader reads the project system GUID specified in the .sln file. +2. If an implementation of IVsProjectSystemSelector has been associated with that project system GUID it is invoked with the following information: + 1. The original project system GUID + 2. The path to the project file +3. The selector can respond in one of two ways: + 1. Decline the request, in which case the project will be loaded with the project system in the .sln file. + 2. Return the GUID of a different project system, in which case it will be used to load the project. + +## C#/VB/F# Specifics + +### Our IVsProjectSystemSelector implementation + +The implementation of our IVsProjectSystemSelector lives in the VS repo as it is associated with the older CSProj project system. However, the registry keys that actually associated the selector with the CSProj project system can be found in [ProjectSelectors.pkgdef](https://github.com/dotnet/project-system/blob/1aa6689827ba43e8cd7b9d29a6d15b3eabf6842c/setup/ProjectSystemSetup/ProjectSelectors.pkgdef); we only want the selector to be active when this project system is installed. + ***NOTE:** The behaviors listed below are subject to change as we add support for more project types in the new project system.* -## When does a project open with the new project system versus the legacy project system? +### When does a project open with the new project system versus the legacy project system? Because both the new project system and legacy project systems use the same file extensions (csproj, vbproj and fsproj), two factors determine whether a project will open in one or the other. -### TargetFramework/TargetFrameworks properties +#### TargetFramework/TargetFrameworks properties *Applies to C# and Visual Basic only* @@ -45,7 +84,7 @@ Whereas, the following csproj or vbproj will open in the legacy project system: ``` -### SDKs +#### SDKs *Applies to F# in 16.3 and earlier, and to F#, C#, and Visual Basic in 16.4 and later* @@ -91,7 +130,7 @@ Whereas the following will open in the legacy project system: ``` -### Project Type GUIDs +#### Project Type GUIDs Inside the solution, there are GUIDs associated with a project called a "project type". By default, all csproj, vbproj and fsproj point to the following three GUIDs (the first GUID in the line): From d4519e43b177604afe7a3b83c90b61711d98ea41 Mon Sep 17 00:00:00 2001 From: "Tom Meschter (from Dev Box)" Date: Mon, 12 Aug 2024 13:39:27 -0700 Subject: [PATCH 2/3] Correct name Replace IVsProjectSystemSelector (incorrect) with IVsProjectSelector (correct). --- docs/opening-with-new-project-system.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/opening-with-new-project-system.md b/docs/opening-with-new-project-system.md index 1e711382cbb..f3c8eece5f4 100644 --- a/docs/opening-with-new-project-system.md +++ b/docs/opening-with-new-project-system.md @@ -21,12 +21,12 @@ There may be situations where more than one project system is capable of loading One option is to provide some sort of upgrade tool that can analyze the solution file and project, recommend the user switch that project to a different project system, and then make the required changes to the solution file on their behalf. However, this requires interactions with the user (which may become noisy if there are a lot of projects to upgrade) changes to the solution file (which the user may not understand) and reloading the project. This is also not a particularly dynamic approach as the change to the project system is persisted in the solution file. -To better address the situation where you may need to dynamically choose the project system, VS provides the [IVsProjectSystemSelector](https://learn.microsoft.com/en-us/dotnet/api/microsoft.visualstudio.shell.interop.ivsprojectselector) interface. Implementations of this interface are associated with a particular project system, and are called before a project is loaded in order to redirect the load to a different project system. +To better address the situation where you may need to dynamically choose the project system, VS provides the [IVSProjectSelector](https://learn.microsoft.com/en-us/dotnet/api/microsoft.visualstudio.shell.interop.ivsprojectselector) interface. Implementations of this interface are associated with a particular project system, and are called before a project is loaded in order to redirect the load to a different project system. -When an IVsProjectSystemSelector is in play, the following sequence of events occurs before a project is loaded: +When an IVSProjectSelector is in play, the following sequence of events occurs before a project is loaded: 1. The solution loader reads the project system GUID specified in the .sln file. -2. If an implementation of IVsProjectSystemSelector has been associated with that project system GUID it is invoked with the following information: +2. If an implementation of IVSProjectSelector has been associated with that project system GUID it is invoked with the following information: 1. The original project system GUID 2. The path to the project file 3. The selector can respond in one of two ways: @@ -35,9 +35,9 @@ When an IVsProjectSystemSelector is in play, the following sequence of events oc ## C#/VB/F# Specifics -### Our IVsProjectSystemSelector implementation +### Our IVSProjectSelector implementation -The implementation of our IVsProjectSystemSelector lives in the VS repo as it is associated with the older CSProj project system. However, the registry keys that actually associated the selector with the CSProj project system can be found in [ProjectSelectors.pkgdef](https://github.com/dotnet/project-system/blob/1aa6689827ba43e8cd7b9d29a6d15b3eabf6842c/setup/ProjectSystemSetup/ProjectSelectors.pkgdef); we only want the selector to be active when this project system is installed. +The implementation of our IVSProjectSelector lives in the VS repo as it is associated with the older CSProj project system. However, the registry keys that actually associated the selector with the CSProj project system can be found in [ProjectSelectors.pkgdef](https://github.com/dotnet/project-system/blob/1aa6689827ba43e8cd7b9d29a6d15b3eabf6842c/setup/ProjectSystemSetup/ProjectSelectors.pkgdef); we only want the selector to be active when this project system is installed. ***NOTE:** The behaviors listed below are subject to change as we add support for more project types in the new project system.* From a399e6f2342a538127462d4661e968b281b86a6e Mon Sep 17 00:00:00 2001 From: Tom Meschter Date: Wed, 14 Aug 2024 12:36:58 -0700 Subject: [PATCH 3/3] Apply suggestions from code review Co-authored-by: Drew Noakes --- docs/opening-with-new-project-system.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/opening-with-new-project-system.md b/docs/opening-with-new-project-system.md index f3c8eece5f4..accf4e9e3f3 100644 --- a/docs/opening-with-new-project-system.md +++ b/docs/opening-with-new-project-system.md @@ -11,7 +11,7 @@ EndProject Here the "Library3.csproj" project should be opened with the project system designated by the "FAE04EC0-301F-11D3-BF4B-00C04F79EFBC" GUID. -While the solution file entry associates a specific project with a specific project system, ultimately this information comes from the [ProviderProjectFactoryAttribute](https://learn.microsoft.com/en-us/dotnet/api/microsoft.visualstudio.shell.provideprojectfactoryattribute)--or the equivalent entries in a .pkgdef file--which associates a file extension (like .csproj) with a project system. +While the solution file entry associates a specific project with a specific project system, ultimately this information comes from the [ProviderProjectFactoryAttribute](https://learn.microsoft.com/dotnet/api/microsoft.visualstudio.shell.provideprojectfactoryattribute)--or the equivalent entries in a .pkgdef file--which associates a file extension (like .csproj) with a project system. ## Problem @@ -21,7 +21,7 @@ There may be situations where more than one project system is capable of loading One option is to provide some sort of upgrade tool that can analyze the solution file and project, recommend the user switch that project to a different project system, and then make the required changes to the solution file on their behalf. However, this requires interactions with the user (which may become noisy if there are a lot of projects to upgrade) changes to the solution file (which the user may not understand) and reloading the project. This is also not a particularly dynamic approach as the change to the project system is persisted in the solution file. -To better address the situation where you may need to dynamically choose the project system, VS provides the [IVSProjectSelector](https://learn.microsoft.com/en-us/dotnet/api/microsoft.visualstudio.shell.interop.ivsprojectselector) interface. Implementations of this interface are associated with a particular project system, and are called before a project is loaded in order to redirect the load to a different project system. +To better address the situation where you may need to dynamically choose the project system, VS provides the [IVSProjectSelector](https://learn.microsoft.com/dotnet/api/microsoft.visualstudio.shell.interop.ivsprojectselector) interface. Implementations of this interface are associated with a particular project system, and are called before a project is loaded in order to redirect the load to a different project system. When an IVSProjectSelector is in play, the following sequence of events occurs before a project is loaded: