From 453ffd1b342ad4237fa9b8f7c03589383bc8ab0b Mon Sep 17 00:00:00 2001 From: Etienne Baudoux Date: Sun, 10 Nov 2024 22:28:39 -0800 Subject: [PATCH] Revert "Added support of per-extension assembly isolation (#1431)" (#1449) This reverts commit 0fddec07ee651aef31462c83b655e269002ee283. --- .../dev/DevToys.Core/Mef/AssemblyIsolation.cs | 26 ------------------- .../Mef/RecursiveDirectoryCatalog.cs | 9 +------ 2 files changed, 1 insertion(+), 34 deletions(-) delete mode 100644 src/app/dev/DevToys.Core/Mef/AssemblyIsolation.cs diff --git a/src/app/dev/DevToys.Core/Mef/AssemblyIsolation.cs b/src/app/dev/DevToys.Core/Mef/AssemblyIsolation.cs deleted file mode 100644 index d60460223e..0000000000 --- a/src/app/dev/DevToys.Core/Mef/AssemblyIsolation.cs +++ /dev/null @@ -1,26 +0,0 @@ -using System.Reflection; -using System.Runtime.Loader; - -namespace DevToys.Core.Mef; - -// See https://learn.microsoft.com/en-us/dotnet/core/dependency-loading/understanding-assemblyloadcontext -internal sealed class AssemblyIsolation : AssemblyLoadContext -{ - private readonly AssemblyDependencyResolver _resolver; - - internal AssemblyIsolation(string entryPointAssemblyPath) - { - _resolver = new AssemblyDependencyResolver(entryPointAssemblyPath); - } - - protected override Assembly? Load(AssemblyName assemblyName) - { - string? assemblyPath = _resolver.ResolveAssemblyToPath(assemblyName); - if (assemblyPath != null) - { - return LoadFromAssemblyPath(assemblyPath); - } - - return null; - } -} diff --git a/src/app/dev/DevToys.Core/Mef/RecursiveDirectoryCatalog.cs b/src/app/dev/DevToys.Core/Mef/RecursiveDirectoryCatalog.cs index 222698670a..2fe1eb7c38 100644 --- a/src/app/dev/DevToys.Core/Mef/RecursiveDirectoryCatalog.cs +++ b/src/app/dev/DevToys.Core/Mef/RecursiveDirectoryCatalog.cs @@ -14,7 +14,6 @@ internal sealed partial class RecursiveDirectoryCatalog : ComposablePartCatalog, { private readonly ILogger _logger; private readonly string _path; - private AssemblyIsolation? _assemblyIsolation; private AggregateCatalog? _aggregateCatalog; /// @@ -123,13 +122,7 @@ private bool AddLibraryToMefCatalog(string filePath) try { AssemblyCount++; - - // Create an isolation context for the plugin. - // This allows to load dependencies version that the plugin asks, even if DevToys uses a different version of that same dependency. - _assemblyIsolation ??= new AssemblyIsolation(filePath); - - Assembly assembly = _assemblyIsolation.LoadFromAssemblyPath(filePath); - var asmCat = new AssemblyCatalog(assembly); + var asmCat = new AssemblyCatalog(filePath); // Force MEF to load the plugin and figure out if there are any exports // good assemblies will not throw the RTLE exception and can be added to the catalog