Remora.Extensions.Options.Immutable
1.0.6
Prefix Reserved
See the version list below for details.
dotnet add package Remora.Extensions.Options.Immutable --version 1.0.6
NuGet\Install-Package Remora.Extensions.Options.Immutable -Version 1.0.6
<PackageReference Include="Remora.Extensions.Options.Immutable" Version="1.0.6" />
paket add Remora.Extensions.Options.Immutable --version 1.0.6
#r "nuget: Remora.Extensions.Options.Immutable, 1.0.6"
// Install Remora.Extensions.Options.Immutable as a Cake Addin #addin nuget:?package=Remora.Extensions.Options.Immutable&version=1.0.6 // Install Remora.Extensions.Options.Immutable as a Cake Tool #tool nuget:?package=Remora.Extensions.Options.Immutable&version=1.0.6
Remora.Extensions.Options.Immutable
This package provides an extension to Microsoft.Extensions.Options
, allowing
the use of immutable types (such as record
s) in the options ecosystem.
The extension takes a simple and direct approach to integration with the existing Microsoft-provided extension, adding only the minimal API necessary to achieve feature parity.
Usage
Usage is simple - immutable option types may be configured in a practically identical manner to mutable types, provided one of the following conditions are true:
- The type defines a parameterless constructor
- The type defines a constructor where all arguments are optional
- The type is explicitly initialized with a root state
That is, given the following types,
public record ExplicitOptions(string Value, bool Flag);
public record ParameterlessOptions()
{
public string? Value { get; init; }
}
public record AllOptionalOptions(string Value = "initial", bool Flag = true");
they may be utilized in the following manner:
var services = new ServiceCollection()
.Configure(() => new ExplicitOptions("initial", true))
.Configure<ExplicitOptions>(opt => opt with { Flag = false });
var services = new ServiceCollection()
.Configure<ParameterlessOptions>(opt => opt with { Value = "configured" });
var services = new ServiceCollection()
.Configure<AllOptionalOptions>(opt => opt with { Flag = false });
All the various normal configuration calls, such as Configure
,
PostConfigure
, ConfigureAll
, and PostConfigureAll
(along with their named)
variants are supported.
Installation
Get it on NuGet!
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 is compatible. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.6.1
- Microsoft.Extensions.Options (>= 7.0.0)
-
.NETStandard 2.0
- Microsoft.Extensions.Options (>= 7.0.0)
-
.NETStandard 2.1
- Microsoft.Extensions.Options (>= 7.0.0)
-
net6.0
- Microsoft.Extensions.Options (>= 7.0.0)
-
net7.0
- Microsoft.Extensions.Options (>= 7.0.0)
NuGet packages (6)
Showing the top 5 NuGet packages that depend on Remora.Extensions.Options.Immutable:
Package | Downloads |
---|---|
Remora.Discord.Gateway
Remora.Discord's implementation of a Discord gateway client |
|
Remora.Discord.Commands
Glue code for using Remora.Commands with Remora.Discord |
|
Remora.Discord.Hosting
Implementation of a hosted Discord gateway service for the .NET Generic Host |
|
Remora.Plugins
The default implementation of Remora.Plugins.Abstractions. |
|
Coca.Remora.Valour
The glue between Valour.Api and Remora.Commands |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Remora.Extensions.Options.Immutable:
Repository | Stars |
---|---|
Remora/Remora.Discord
A data-oriented C# Discord library, focused on high-performance concurrency and robust design.
|
Upgrade Remora.Sdk.
Add .NET 7 as a target.