Orsak.AspNetCore
0.4.3-beta0022
dotnet add package Orsak.AspNetCore --version 0.4.3-beta0022
NuGet\Install-Package Orsak.AspNetCore -Version 0.4.3-beta0022
<PackageReference Include="Orsak.AspNetCore" Version="0.4.3-beta0022" />
paket add Orsak.AspNetCore --version 0.4.3-beta0022
#r "nuget: Orsak.AspNetCore, 0.4.3-beta0022"
// Install Orsak.AspNetCore as a Cake Addin #addin nuget:?package=Orsak.AspNetCore&version=0.4.3-beta0022&prerelease // Install Orsak.AspNetCore as a Cake Tool #tool nuget:?package=Orsak.AspNetCore&version=0.4.3-beta0022&prerelease
Orsak
eff {
let! line = Effects.Console.readLine()
do! Effect.Console.writeLine $"Hello {line}"
}
Orsak is a library for function effects in F#, allowing pragmatic and composable modelling of side-effects through interfaces. It is inspired by Zio, with F# encoding similar to the approach described by Bartosz Sypytkowski here. The library intends to be as complete as is practical, including a computation expression, supporting functions and operators, and should be compatible with FSharpPlus.
However, Orsak is not intended to be a framework. Rather, it is encouraged and recommended to make use of the existing .NET ecosystem, and Orsak is intended to make that as easy and friction-free as possible. It can be used piecemeal, and introduced to existing codebases in isolated chunks.
This implementation makes use of resumable code to implement the computation expression builder for the lowest possible overhead.
The builder also has various overloads for Bind
, allowing for friction free interop with TaskLike<'a>
, Async<'a>
, Result<'T,'E>
and more.
It supports for
, while
, use
, try-with
and try-finally
, and also applicative bind when the error-type supports +
.
While the computation expression is the intended way of working with effects, the corresponding module should contain all the expected functions.
Show me the code
Imagine having the following interfaces, which each describes some none-pure operation, that is, they both have side-effects.
type IButtonPusher =
abstract member PushButton: unit -> Task<unit>
type IBeanCounter =
abstract member CountBeans: unit -> Task<int>
By creating the following helper-interfaces
type IButtonPusherProvider =
abstract member ButtonPusher: IButtonPusher
type IBeanCounterProvider =
abstract member BeanCounter: IBeanCounter
and the following helpers
let pushButton () =
Effect.Create(fun (provider: #IButtonPusherProvider) -> provider.ButtonPusher.PushButton())
let countBeans () =
Effect.Create(fun (provider: #IBeanCounterProvider) -> provider.BeanCounter.CountBeans())
then it is possible to partially apply, or 'inject' these interfaces into your code by simply making functions calls:
let pushAndCount<'a, 'b when 'a :> IButtonPusherProvider and 'a :> IBeanCounterProvider> ()
: Effect<'a, int, 'b> =
eff {
do! pushButton ()
let! beans = countBeans ()
return beans * 2
}
In essence, this is a partially applied function, waiting for an instance of 'a
which implements both IButtonPusherProvider
and IBeanCounterProvider
.
Now, in practise you do not need to specify any of this, the type inference will keep track of the requirements of your provider.
let pushAndCount () =
eff {
do! pushButton()
let! beans = countBeans()
return beans * 2
}
And adding further calls to functions with side-effects will apply the correct constraints seamlessly.
Main documentation is available at https://johsand.github.io/Orsak/
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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 was computed. 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. |
-
net6.0
- FastExpressionCompiler.LightExpression (>= 4.1.0)
- FSharp.Core (>= 8.0.300)
- Orsak (>= 0.4.3-beta0022)
-
net8.0
- FastExpressionCompiler.LightExpression (>= 4.1.0)
- FSharp.Core (>= 8.0.300)
- Orsak (>= 0.4.3-beta0022)
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 |
---|---|---|
0.4.3-beta0022 | 48 | 6/5/2024 |
0.4.3-beta0016 | 61 | 3/8/2024 |
0.4.3-beta0015 | 102 | 1/11/2024 |
0.4.3-beta0014 | 63 | 1/11/2024 |