The provided ComposedAdapterService exports the IAdapterService interface, and "imports many" IAdapter implementations.
Initialize your composition container so that it contains both the exported adapters and the adapter service, and it
will be initialized automatically for use.
======= Example =======
// Initialize container with your assemblies/types/catalogs
CompositionContainer container = new CompositionContainer(catalog);
// Retrieve initialized adapter service
IAdapterService service = container.GetExportedValue<IAdapterService>();
// Initialize the adapter facade with the service
// Use adapter extension method As as needed, i.e.
// say we need to use it as an MSBuild project, if possible
IMSBuildProject msbuild = project.As<IMSBuildProject>();
if (msbuild != null)
// do MSBuild stuff with it.
======= Adapters =======
public class ProjectToMsBuildAdapter : IAdapter<IProject, IMSBuildProject>
// Implement actual conversion.
Simply by exporting the right contract, the adapter service will locate it.
Note that to create adapter implementations, you need to install the Adapter.Sdk package.
Install-Package Adapter.Composition -Version 1.1.1301.1418
dotnet add package Adapter.Composition --version 1.1.1301.1418
<PackageReference Include="Adapter.Composition" Version="1.1.1301.1418" />
paket add Adapter.Composition --version 1.1.1301.1418
* Additional support for source packages, like Adapter.Interfaces.Source,
which also use token replacement and adopt the containing project
* Initial version, with support for flexible matching of from and to types
* Support for MEF in separate Adapter.Composition package
* Proper split of: Adapter.Interfaces, Adapter.Sdk and Adapter (implementation).
This package has no dependencies.
This package is not used by any popular GitHub repositories.