rslcs 2.0.0

dotnet add package rslcs --version 2.0.0
                    
NuGet\Install-Package rslcs -Version 2.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="rslcs" Version="2.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="rslcs" Version="2.0.0" />
                    
Directory.Packages.props
<PackageReference Include="rslcs" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add rslcs --version 2.0.0
                    
#r "nuget: rslcs, 2.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.
#addin nuget:?package=rslcs&version=2.0.0
                    
Install as a Cake Addin
#tool nuget:?package=rslcs&version=2.0.0
                    
Install as a Cake Tool

rslcs

A lightweight C# library that brings Go-like error handling to .NET applications

Installation

dotnet add package rslcs

Features

  • Explicit Error Handling: No more hidden exceptions or try/catch blocks for expected errors
  • Type Safety: Compiler-enforced error checking prevents forgetting to handle error cases
  • Deconstruction Support: C# tuple deconstruction for clean, concise code
  • Operation Chaining: API for composing operations that might fail
  • Zero Dependencies: Pure C# implementation with no external dependencies

Basic Usage

using rslcs;

Result<double> Divide(double a, double b)
{
    if (b == 0)
    {
        return new(new DivideByZeroException("Cannot divide by zero"));
    }
    return new(a / b);
}

var result = Divide(10, 2);

if (result.Error != null)
{
    Console.WriteLine($"Error: {result.Error.Message}");
    return;
}
Console.WriteLine($"Result: {result.Value}");

Tuple Deconstruction

var (value, error) = Divide(10, 0);

if (error != null)
{
    Console.WriteLine($"Error: {error.Message}");
    return;
}
Console.WriteLine($"Result: {value}");

Operation Chaining

var result = Divide(10, 2)
    .Then(r => Divide(r, 5))
    .Then(r => Divide(r, 2));

// Equivalent to:
var result = Divide(10, 2);
if (result.Error == null) return new(result.Error);
result = Divide(result.Value, 5);
if (result.Error == null) return new(result.Error);
return Divide(result.Value, 2);

Async Support

async Task<Result<string>> FetchDataAsync(string url)
{
    try
    {
        using HttpClient client = new HttpClient();
        HttpResponseMessage response = await client.GetAsync(url);

        if (!response.IsSuccessStatusCode)
        {
            return new(new HttpRequestException(
                $"HTTP error! Status: {response.StatusCode}"));
        }

        string data = await response.Content.ReadAsStringAsync();
        return new(data);
    }
    catch (Exception ex)
    {
        return new(ex);
    }
}

// Usage
async Task ProcessDataAsync()
{
    var (value, error) = await FetchDataAsync("https://api.example.com/data");

    if (error != null)
    {
        Console.WriteLine($"Error: {error.Message}");
        return;
    }

    Console.WriteLine($"Data: {value}");
}

License

MIT License

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

Version Downloads Last Updated
2.0.0 163 4/1/2025
1.0.0 160 3/31/2025