Skip to content

Provide System.Composition.Hosting package readme #106783

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 2 commits into from
Sep 4, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
80 changes: 80 additions & 0 deletions src/libraries/System.Composition.Hosting/src/PACKAGE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
## About

<!-- A description of the package and where one can find more documentation -->

`System.Composition.Hosting` is part of the Managed Extensibility Framework (MEF) 2.0, a composition library for .NET that enables dependency injection through attributes or conventions.

This package provides core services for creating composition containers.
It offers tools to configure and manage the composition of parts within your application, facilitating dependency injection and enabling modular architectures.

## Key Features

<!-- The key features of this package -->

* Create and manage composition containers for dynamic dependency injection.

## How to Use

<!-- A compelling example on how to use this package with code, as well as any specific guidelines for when to use the package -->

Create a composition host and compose parts.

```csharp
using System.Composition;
using System.Composition.Hosting;

// Create a container configuration
var configuration = new ContainerConfiguration()
.WithPart<Service>();

// Create the composition host (container)
using CompositionHost container = configuration.CreateContainer();

// Get an instance of the service
var service = container.GetExport<IService>();
service.Run();
// Service is running!

public interface IService
{
void Run();
}

[Export(typeof(IService))]
public class Service : IService
{
public void Run() => Console.WriteLine("Service is running!");
}
```

## Main Types

<!-- The main types provided in this library -->

The main type provided by this library is:

* `System.Composition.CompositionHost`

## Additional Documentation

<!-- Links to further documentation. Remove conceptual documentation if not available for the library. -->

* [API documentation](https://learn.microsoft.com/dotnet/api/system.composition.hosting)
* [Managed Extensibility Framework (MEF)](https://learn.microsoft.com/dotnet/framework/mef/)

## Related Packages

<!-- The related packages associated with this package -->

* [System.Composition](https://www.nuget.org/packages/System.Composition)
* [System.Composition.AttributedModel](https://www.nuget.org/packages/System.Composition.AttributedModel)
* [System.Composition.Convention](https://www.nuget.org/packages/System.Composition.Convention)
* [System.Composition.Runtime](https://www.nuget.org/packages/System.Composition.Runtime)
* [System.Composition.TypedParts](https://www.nuget.org/packages/System.Composition.TypedParts)

## Feedback & Contributing

<!-- How to provide feedback on this package and contribute to it -->

System.Composition.Hosting is released as open source under the [MIT license](https://licenses.nuget.org/MIT).
Bug reports and contributions are welcome at [the GitHub repository](https://github.com/dotnet/runtime).
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,10 @@
<StrongNameKeyId>Microsoft</StrongNameKeyId>
<UseCompilerGeneratedDocXmlFile>false</UseCompilerGeneratedDocXmlFile>
<IsPackable>true</IsPackable>
<PackageDescription>Provides Managed Extensibility Framework types that are useful to developers of extensible applications, or hosts.

Commonly Used Types:
System.Composition.Hosting.CompositionHost</PackageDescription>
<PackageDescription>Provides Managed Extensibility Framework (MEF) types that are useful to developers of extensible applications, or hosts.</PackageDescription>
<!-- TODO https://github.com/dotnet/runtime/issues/90400: Annotate for nullable reference types -->
<Nullable>disable</Nullable>
<NoWarn>$(NoWarn);nullable</NoWarn>
<!-- TODO: Add package README file: https://github.com/dotnet/runtime/issues/99358 -->
<EnableDefaultPackageReadmeFile>false</EnableDefaultPackageReadmeFile>
</PropertyGroup>

<ItemGroup>
Expand Down
Loading