Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/moonad-dotnet/moonad
A simple F#'s monads port for C#.
https://github.com/moonad-dotnet/moonad
csharp csharp-library functional-programming monad monads result result-type
Last synced: 3 months ago
JSON representation
A simple F#'s monads port for C#.
- Host: GitHub
- URL: https://github.com/moonad-dotnet/moonad
- Owner: moonad-dotnet
- License: mit
- Created: 2023-12-24T03:05:56.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-30T20:43:12.000Z (9 months ago)
- Last Synced: 2024-03-31T20:44:47.285Z (9 months ago)
- Topics: csharp, csharp-library, functional-programming, monad, monads, result, result-type
- Language: C#
- Homepage:
- Size: 204 KB
- Stars: 9
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Moonad
![Version](https://img.shields.io/nuget/v/moonad?label=version&color=029632) ![Tests](https://img.shields.io/github/actions/workflow/status/moonad-dotnet/moonad/dotnet.yml?logo=github&label=tests&color=029632) ![Nuget](https://img.shields.io/nuget/dt/moonad?logo=nuget&label=downloads&color=029632)
A simple F#'s monads port for C#.
This library contains the main F#'s monads found on FSharp.Core lib written in, and adapted for, C#. Check the docs at [Moonad.NET](https://moonad.net).
## Installing
The project's package can be found on [Nuget](https://nuget.org/packages/moonad) and installed by your IDE or shell as following:```shell
dotnet add package Moonad
```or
```shell
PM> Install-Package Moonad
```### A Note on Null Reference Types
Since our main goal is to protect the user from `NullReferenceException` we strongly recommend the use of [Nullable Reference Types](https://learn.microsoft.com/en-us/dotnet/csharp/language-reference/builtin-types/nullable-reference-types) on any project which uses this lib.
## The Monads
F# offers in it's core library four monads to help you to have more flexibility when working with primitives and also potential null occurrences. So this library do the same.
### Choice
Also known as `Either` in some languages this monad offers you the possibility to choose one of two types to be hold by its instance.Example:
```c#
public Choice Choose(bool returnInt)
{
if(returnInt)
return 1;return "This is a Choice!";
}
```### Result
A type to express the final state of a given processing revealing its success of failure and optionally carrying a value or an error.
Example 1 - Success indicator:
```c#
public Result Send(Message message)
{
try
{
...
return Result.Ok();
}
catch(Exception exc)
{
...
return Result.Error();
}
}
```Example 2 - Value and error returning:
```c#
public Result Create(...)
{
//When a guard clause is actioned
return new EmptyUserNameError();//When all is valid
return new User(...);
}
```### Option
This monad, also known as `Maybe`, has as its goal preventing the `NullReferenceException` by notifying the existence or absense of a value. Once a potentially null, or simply absent, value is converted to Option it's evaluated to a `Some` instance, which carry the value, or a `None` instance, which replaces the `null` and let the client works as `null` doesn't exists.
Example 1 - Preventing null from a 3rd party lib:
```c#
//lib.Method returns a stringvar option = lib.Method().ToOption();
//The ToOption method will turn a null value into a None instance.if(option.IsSome)
Console.WriteLine($"Returned value: {option}");
if(option.IsNone)
Console.WriteLine($"No returned value.");
```Example 2 - Creating an Option explicitly:
```c#
public Option ReturnWhenGreaterThanZero(int input) =>
input > 0 ? input : Option.None;
```### ValueOption
It has the very same concept as Option but is intended to use with value types to be faster in performance critical scenarios.Example 1 - Preventing null from a 3rd party lib:
```c#
//lib.Method returns a nullable intvar option = lib.Method().ToValueOption();
//The ToOption method will turn a null value into a None instance.if(option.IsSome)
Console.WriteLine($"Returned value: {option}");
if(option.IsNone)
Console.WriteLine($"No returned value.");
```Example 2 - Creating an Option explicitly:
```c#
public ValueOption ReturnWhenGreaterThanZero(int input) =>
input > 0 ? input : ValueOption.None;
```