LightResults.Extensions.ExceptionHandling
8.0.2
Prefix Reserved
dotnet add package LightResults.Extensions.ExceptionHandling --version 8.0.2
NuGet\Install-Package LightResults.Extensions.ExceptionHandling -Version 8.0.2
<PackageReference Include="LightResults.Extensions.ExceptionHandling" Version="8.0.2" />
paket add LightResults.Extensions.ExceptionHandling --version 8.0.2
#r "nuget: LightResults.Extensions.ExceptionHandling, 8.0.2"
// Install LightResults.Extensions.ExceptionHandling as a Cake Addin #addin nuget:?package=LightResults.Extensions.ExceptionHandling&version=8.0.2 // Install LightResults.Extensions.ExceptionHandling as a Cake Tool #tool nuget:?package=LightResults.Extensions.ExceptionHandling&version=8.0.2
LightResults Extensions
Extensions for LightResults, an extremely light and modern Operation Result Pattern library for .NET.
ExceptionHandling
Provides extension methods for exception handling using LightResults.
Documentation
Make sure to read the docs for the full API.
Try method
The Try
method will wrap the execution of an Action
or Func
in a try { } catch { }
block. If an
exception occurs, a failed result will be returned and the Exception
will be added to the result as metadata.
With an Action
var result = action.Try();
if (result.IsSuccess)
{
// Do something
}
With an Action
with arguments
var result = action.Try(42);
if (result.IsSuccess)
{
// Do something
}
With a Func
var result = func.Try();
if (result.IsSuccess)
{
var value = result.Value;
// Do something
}
With a Func
with arguments
var result = func.Try(42);
if (result.IsSuccess)
{
var value = result.Value;
// Do something
}
Using the Try method with methods
Although extension methods for Action
or Func
cannot be attached to ordinary methods, the compiler will
automatically cast ordinary methods to Action
or Func
if only the method name is manually passed as the
argument to the extension method.
There are two ways this can be achieved, both of which are explained below.
Using the static class name
using LightResults.Extensions.ExceptionHandling;
public class OrdinaryClass
{
public void OrdinaryMethod() { }
public void TryOrdinaryMethod()
{
var result = ExceptionHandler.Try(OrdinaryMethod);
if (result.IsSuccess)
{
// Do something
}
}
public void OrdinaryMethodWithArguments(int arg1, int arg2) { }
public void TryOrdinaryMethodWithArguments()
{
var result = ExceptionHandler.Try(OrdinaryMethodWithArguments, 1, 2);
if (result.IsSuccess)
{
// Do something
}
}
public int OrdinaryMethodWithReturn() { return 0; }
public void TryOrdinaryMethodWithReturn()
{
var result = ExceptionHandler.Try(OrdinaryMethodWithReturn);
if (result.IsSuccess)
{
var value = result.Value;
// Do something
}
}
public int OrdinaryMethodWithReturnAndArguments(int arg1, int arg2) { return arg1 + arg2; }
public void TryOrdinaryMethodWithReturnAndArguments()
{
var result = ExceptionHandler.Try(OrdinaryMethodWithReturnAndArguments, 1, 2);
if (result.IsSuccess)
{
var value = result.Value;
// Do something
}
}
}
Declaring a using static
statement
using static LightResults.Extensions.ExceptionHandling.ExceptionHandler;
public class OrdinaryClass
{
public void OrdinaryMethod() { }
public void TryOrdinaryMethod()
{
var result = Try(OrdinaryMethod);
if (result.IsSuccess)
{
// Do something
}
}
public void OrdinaryMethodWithArguments(int arg1, int arg2) { }
public void TryOrdinaryMethodWithArguments()
{
var result = Try(OrdinaryMethodWithArguments, 1, 2);
if (result.IsSuccess)
{
// Do something
}
}
public int OrdinaryMethodWithReturn() { return 0; }
public void TryOrdinaryMethodWithReturn()
{
var result = Try(OrdinaryMethodWithReturn);
if (result.IsSuccess)
{
var value = result.Value;
// Do something
}
}
public int OrdinaryMethodWithReturnAndArguments(int arg1, int arg2) { return arg1 + arg2; }
public void TryOrdinaryMethodWithReturnAndArguments()
{
var result = Try(OrdinaryMethodWithReturnAndArguments, 1, 2);
if (result.IsSuccess)
{
var value = result.Value;
// Do something
}
}
}
Getting the Exception
var result = action.Try();
if (result.IsFailed)
{
var ex = (Exception)result.Error.Metadata["Exception"];
// Do something with the base exception type or...
if (ex is ArgumentNullException argumentNullException)
{
// Do something with a specific exception type
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. 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 is compatible. 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 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. |
.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
- LightResults (>= 8.0.9)
- System.Threading.Tasks.Extensions (>= 4.5.0)
-
net6.0
- LightResults (>= 8.0.9)
-
net7.0
- LightResults (>= 8.0.9)
-
net8.0
- LightResults (>= 8.0.9)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.