TaskExceptionCatcher 1.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package TaskExceptionCatcher --version 1.0.0
NuGet\Install-Package TaskExceptionCatcher -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="TaskExceptionCatcher" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add TaskExceptionCatcher --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: TaskExceptionCatcher, 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 TaskExceptionCatcher as a Cake Addin #addin nuget:?package=TaskExceptionCatcher&version=1.0.0 // Install TaskExceptionCatcher as a Cake Tool #tool nuget:?package=TaskExceptionCatcher&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
TastExceptionCatcher
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`.
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. |
.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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.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.