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" />
<PackageReference Include="rslcs" />
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
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#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
#tool nuget:?package=rslcs&version=2.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
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 | Versions 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.