Baubit.Tasks
2026.22.1
dotnet add package Baubit.Tasks --version 2026.22.1
NuGet\Install-Package Baubit.Tasks -Version 2026.22.1
<PackageReference Include="Baubit.Tasks" Version="2026.22.1" />
<PackageVersion Include="Baubit.Tasks" Version="2026.22.1" />
<PackageReference Include="Baubit.Tasks" />
paket add Baubit.Tasks --version 2026.22.1
#r "nuget: Baubit.Tasks, 2026.22.1"
#:package Baubit.Tasks@2026.22.1
#addin nuget:?package=Baubit.Tasks&version=2026.22.1
#tool nuget:?package=Baubit.Tasks&version=2026.22.1
Baubit.Tasks
Task utilities with FluentResults integration.
Install
dotnet add package Baubit.Tasks
Features
WaitingRoom<TValue>
Coordinates concurrent awaiters waiting for a single result value. All guests that call Join are held until TrySetResult, TrySetCanceled, or Dispose is called.
using var room = new WaitingRoom<string>();
// Multiple callers can join concurrently
var task1 = room.Join(cancellationToken);
var task2 = room.Join(cancellationToken);
Console.WriteLine(room.HasGuests); // true
// Completes all waiting tasks at once
room.TrySetResult("hello");
var result1 = await task1; // "hello"
var result2 = await task2; // "hello"
// Cancel all waiting tasks
room.TrySetCanceled();
// Disposing also cancels any remaining guests
room.Dispose();
| Member | Description |
|---|---|
HasGuests |
true when at least one caller is currently awaiting a result. |
Join(CancellationToken) |
Joins the waiting room and returns a task that completes when a result is set or cancellation is requested. |
TrySetResult(TValue) |
Supplies the result to all waiting guests. Returns true if the result was set successfully. |
TrySetCanceled(CancellationToken) |
Cancels all waiting guests. Returns true if cancellation was applied. |
Dispose() |
Cancels any remaining guests and releases resources. |
TimedCancellationTokenSource
Auto-cancelling CancellationTokenSource with configurable timeout.
// Timer starts when token is accessed (default)
using var cts = new TimedCancellationTokenSource(TimeSpan.FromSeconds(30));
var token = cts.Token; // Timer starts now
// Timer starts on explicit check
using var cts = new TimedCancellationTokenSource(1000, timerStartsAtTokenAccess: false);
if (cts.IsCancellationRequested) // Timer starts now
{
// Handle cancellation
}
Task Extensions
Wait / WaitAsync
Convert task exceptions to Result objects.
var result = task.Wait();
if (result.IsSuccess) { /* ... */ }
var result = await task.WaitAsync();
WaitAsync with CancellationToken
Asynchronously wait for a task with cancellation support. Provides .NET 6+ WaitAsync(CancellationToken) functionality for .NET Standard 2.0.
var cts = new CancellationTokenSource(TimeSpan.FromSeconds(5));
try
{
await longRunningTask.WaitAsync(cts.Token);
}
catch (TaskCanceledException)
{
// Timeout occurred
}
// With result
var result = await task.WaitAsync<int>(cts.Token);
RegisterCancellationToken
Link CancellationToken to TaskCompletionSource.
var tcs = new TaskCompletionSource<int>();
var cts = new CancellationTokenSource();
tcs.RegisterCancellationToken(cts.Token);
cts.Cancel(); // Automatically cancels tcs.Task
GetCancellationAwaiterAsync
Asynchronously wait until one or more CancellationTokens are cancelled. Always returns true when any observed token is cancelled. Short-circuit checks are performed before and after each registration to avoid unnecessary waits.
// Wait for a single token to be cancelled
await myCancellationToken.GetCancellationAwaiterAsync();
// Wait for any of several tokens to be cancelled
await myCancellationToken.GetCancellationAwaiterAsync(token2, token3);
// Wait with a timeout — completes when the token is cancelled or the timeout elapses
await myCancellationToken.GetCancellationAwaiterAsync(TimeSpan.FromSeconds(5));
// Wait with a timeout and additional tokens
await myCancellationToken.GetCancellationAwaiterAsync(TimeSpan.FromSeconds(5), token2, token3);
CreateTimedCancellationTokenSource
Extension method on TimeSpan for fluent creation of a TimedCancellationTokenSource.
// Timer starts when Token is first accessed (default)
using var cts = TimeSpan.FromSeconds(30).CreateTimedCancellationTokenSource();
// Timer starts when IsCancellationRequested is first read
using var cts = TimeSpan.FromSeconds(30).CreateTimedCancellationTokenSource(timerStartsAtTokenAccess: false);
License
MIT
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 was computed. 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. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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 was computed. |
| .NET Framework | net461 was computed. 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. |
-
.NETStandard 2.0
- Baubit.Traceability (>= 2025.48.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Baubit.Tasks:
| Package | Downloads |
|---|---|
|
Baubit.Caching
Thread-safe insertion-ordered cache with O(1) lookups, two-tier storage (bounded L1, unbounded L2), and async enumeration. Provides deletion-resilient iteration, automatic multi-consumer memory management, and zero-latency producer-consumer coordination using GuidV7 time-ordered identifiers. Ideal for event sourcing, audit logs, message queues, and time-series caching scenarios. |
GitHub repositories
This package is not used by any popular GitHub repositories.