CodeOfChaos.Extensions
0.29.0
Prefix Reserved
See the version list below for details.
dotnet add package CodeOfChaos.Extensions --version 0.29.0
NuGet\Install-Package CodeOfChaos.Extensions -Version 0.29.0
<PackageReference Include="CodeOfChaos.Extensions" Version="0.29.0" />
paket add CodeOfChaos.Extensions --version 0.29.0
#r "nuget: CodeOfChaos.Extensions, 0.29.0"
// Install CodeOfChaos.Extensions as a Cake Addin #addin nuget:?package=CodeOfChaos.Extensions&version=0.29.0 // Install CodeOfChaos.Extensions as a Cake Tool #tool nuget:?package=CodeOfChaos.Extensions&version=0.29.0
CodeOfChaos.Extensions
CodeOfChaos.Extensions
is a collection of utility extension methods designed to enhance and simplify everyday
programming tasks in .NET projects. This library offers extensions for tasks, strings, enums, LINQ queries, collections,
and dictionaries, enabling more readable, efficient, and intuitive code.
Features
Task Extensions
Enhance task handling with support for timeouts and cancellation tokens:
.WithCancellation(CancellationToken)
– Cancel a task when the token is triggered..WithTimeout(TimeSpan)
– Enforce a timeout on task execution.- Available for both
Task
andTask<T>
.
String Extensions
Simplify string management with useful utilities:
IsNullOrEmpty()
/IsNotNullOrEmpty()
– Check for null or empty strings.IsNullOrWhiteSpace()
/IsNotNullOrWhiteSpace()
– Check for null, empty, or whitespace strings.Truncate(int maxLength)
– Shorten a string to a maximum length.ToGuid()
– Parse a string into aGuid
.
Enum Extensions
Work with enums more efficiently:
.GetFlags()
– Retrieve all flagged values from an enum..GetFlagsAsArray()
/.GetFlagsAsList()
– Retrieve flagged values as arrays or lists.- Caches enums for better performance.
LINQ Extensions
Add conditional logic to LINQ operations:
- Apply operations conditionally:
ConditionalWhere
ConditionalTake
ConditionalOrderBy
ConditionalDistinct
and more.
- Chain LINQ operations dynamically based on runtime conditions.
Collection Extensions
Extensions to handle collections and arrays more effectively:
IsEmpty()
– Check if astring[]
orIEnumerable<string>
is empty.
Dictionary Extensions
Enhance dictionary management:
AddOrUpdate()
– Add a key-value pair or update the existing value.TryAddToOrCreateCollection()
– Add values to a collection within a dictionary or create a new collection.
Installation
This library targets .NET 9.0
and requires C# 13.0. Ensure your project meets these requirements before using.
Add the dependency to your project via NuGet:
dotnet add package CodeOfChaos.Extensions
Usage
Here’s how you can leverage the CodeOfChaos.Extensions
library:
Task Example
using System;
using System.Threading;
using System.Threading.Tasks;
var tokenSource = new CancellationTokenSource();
var task = Task.Delay(5000); // Example task
await task.WithCancellation(tokenSource.Token);
String Example
using System;
string? input = "Hello, World!";
if (input.IsNotNullOrWhiteSpace()) {
Console.WriteLine(input.Truncate(5)); // Output: Hello
}
Enum Example
[Flags]
enum AccessLevel { None = 0, Read = 1, Write = 2, Execute = 4 }
var access = AccessLevel.Read | AccessLevel.Execute;
var flags = access.GetFlagsAsList(); // Output: [Read, Execute]
LINQ Example
var items = new List<int> { 1, 2, 3, 4, 5 }.AsQueryable();
var filtered = items.ConditionalWhere(true, x => x > 2); // Applies condition
Contributing
Feel free to fork and contribute to the project by submitting pull requests. When contributing, ensure your changes align with the project’s coding standards.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. |
-
net9.0
- CodeOfChaos.Extensions.Analyzers (>= 0.29.0)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on CodeOfChaos.Extensions:
Package | Downloads |
---|---|
CodeOfChaos.AspNetCore
A Library of Nuget Packages frequently used in other code-of-chaos projects or project written by Andreas |
|
CodeOfChaos.Types
A library of common types and classes within the CodeOfChaos project |
|
CodeOfChaos.Parsers.Csv
A Library to parse csv files in a similar api to regular xml parsing |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.29.2 | 24 | 1/4/2025 |
0.29.0 | 50 | 1/3/2025 |
0.28.2 | 76 | 1/1/2025 |
0.27.1 | 75 | 12/31/2024 |
0.27.0 | 94 | 12/29/2024 |
0.26.0 | 88 | 12/28/2024 |
0.25.0 | 94 | 12/28/2024 |
0.24.3 | 85 | 12/27/2024 |
0.24.2 | 81 | 12/27/2024 |
0.24.1 | 81 | 12/27/2024 |
0.24.0 | 85 | 12/27/2024 |
0.23.1 | 76 | 12/27/2024 |
0.23.0 | 90 | 12/27/2024 |
0.22.2 | 81 | 12/27/2024 |
0.22.0 | 115 | 12/23/2024 |
0.21.0 | 90 | 12/22/2024 |
0.20.0-preview.1 | 55 | 12/21/2024 |
0.15.0 | 85 | 12/11/2024 |
0.13.0 | 127 | 11/1/2024 |
0.12.1 | 95 | 10/31/2024 |
0.12.0 | 91 | 10/30/2024 |
0.11.0 | 103 | 10/30/2024 |
0.10.0 | 88 | 10/26/2024 |
0.9.0 | 92 | 10/25/2024 |
0.8.1 | 137 | 9/18/2024 |
0.7.0 | 135 | 9/4/2024 |
0.6.0 | 194 | 7/6/2024 |
0.5.0 | 95 | 7/6/2024 |
0.4.3 | 112 | 7/1/2024 |
0.4.1 | 110 | 7/1/2024 |
0.4.0 | 220 | 6/13/2024 |
0.3.0 | 101 | 6/11/2024 |
0.2.0 | 149 | 6/8/2024 |
0.1.0 | 105 | 6/7/2024 |