ConstTypeArgs.Bools 1.0.0

dotnet add package ConstTypeArgs.Bools --version 1.0.0                
NuGet\Install-Package ConstTypeArgs.Bools -Version 1.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ConstTypeArgs.Bools" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ConstTypeArgs.Bools --version 1.0.0                
#r "nuget: ConstTypeArgs.Bools, 1.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ConstTypeArgs.Bools as a Cake Addin
#addin nuget:?package=ConstTypeArgs.Bools&version=1.0.0

// Install ConstTypeArgs.Bools as a Cake Tool
#tool nuget:?package=ConstTypeArgs.Bools&version=1.0.0                

Bool Const Type Arguments

Const type arguments (also called const type args) are types used to pass constant & static values to generics through type parameters. These values are available at compile-time and can be used in static contexts, such as static constructors, static fields, and static methods. This can provide enhanced type safety, compile-time polymorphism, performance improvements, and more.

 

You can use types in the ConstTypeArgs.Bools namespace for passing boolean values as const type arguments.

Usage scenarios include:

  • Static configuration,
  • Eliminating unnecessary instance constructors,
  • "Passing" values to type initializers,
  • and more.

 

The following is a simple Hello World example to demonstrate how this works:

using ConstTypeArgs.Bools;

public class Foo<TToConsole>
   where TToConsole: K_Bool
{
   static Foo()
   {        
       if (TToConsole.Value)
           Console.WriteLine("Hello, world!");
   }
}

// Elsewhere
var foo = new Foo<True>();  // Console outputs: Hello, world!
foo     = new Foo<False>(); // No output.
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.0 110 7/11/2024

Initial release.