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                
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="LightResults.Extensions.ExceptionHandling" Version="8.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add LightResults.Extensions.ExceptionHandling --version 8.0.2                
#r "nuget: LightResults.Extensions.ExceptionHandling, 8.0.2"                
#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 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                

Banner

LightResults Extensions

Extensions for LightResults, an extremely light and modern Operation Result Pattern library for .NET.

main

ExceptionHandling

Provides extension methods for exception handling using LightResults.

nuget downloads

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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
8.0.2 3,372 4/2/2024
8.0.1 147 3/1/2024
8.0.0 127 2/29/2024