TaskExceptionCatcher 1.1.0
dotnet add package TaskExceptionCatcher --version 1.1.0
NuGet\Install-Package TaskExceptionCatcher -Version 1.1.0
<PackageReference Include="TaskExceptionCatcher" Version="1.1.0" />
paket add TaskExceptionCatcher --version 1.1.0
#r "nuget: TaskExceptionCatcher, 1.1.0"
// Install TaskExceptionCatcher as a Cake Addin #addin nuget:?package=TaskExceptionCatcher&version=1.1.0 // Install TaskExceptionCatcher as a Cake Tool #tool nuget:?package=TaskExceptionCatcher&version=1.1.0
TaskExceptionCatcher
Use Catcher.Run
for preventing a task to throw during a "one-fails-all" operation like Task.WhenAll
or AwaitMultiple.
How to use and why
This example explains the syntax, but may not be useful beyond that:
var result = await Catcher.Run(() => ThrowOrNotAsync());
if (result.Exception != null)
{
// this point will be reached in case of an exception.
}
else
{
var taskResultValue = result.Value.
}
When using AwaitMultiple or Task.WhenAll
, an exception is thrown in case one task fails and you cannot access the values of the not-failed tasks.
In some cases, that may not be desired: you may want to continue if "getting value b
" fails:
var (a, catchResultB, c) = await Tasks(
StartTaskAAsync(),
Catcher.Run(() => StartTaskBAsync()),
StartTaskCAsync());
if (catchResultB.Exception is { } exception)
{
// no problem!
}
else
{
var b = catchResultB.Value;
// use `b`.
}
// use `a` and `c`.
Just like with Task.Run
, you can also create a Task
from a synchronous function with Catcher.Run
:
string SayHelloTo(string name)
{
return $"Hello {name}";
}
var (a, catchResultB, catchResultC) = await Tasks(
Task.Run(() => SayHelloTo("A")),
Catcher.Run(() => SayHelloTo("B")),
Catcher.Run(() => SayHelloTo("C")));
Get it
Available via NuGet.
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. |
.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
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
v1.0.1: fix typo in package name ("Tast" => "Task").
v1.1.0: new overload that can create a Task from a Func.