Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for ValueTask #523

Merged
Merged
Show file tree
Hide file tree
Changes from 15 commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
d27d7d2
First try for value task
rodriguestiago0 Nov 23, 2022
6993db9
Some code clean up
rodriguestiago0 Nov 23, 2022
7ddfc04
added one unit test and code clean up
rodriguestiago0 Nov 23, 2022
f943840
Added more unit tests
rodriguestiago0 Nov 23, 2022
98bd22c
fixed unit tests
rodriguestiago0 Nov 23, 2022
0e93581
code clean up
rodriguestiago0 Nov 23, 2022
48dd1a2
Added ValueTask Overloads
rodriguestiago0 Nov 24, 2022
56f5240
convert from task CE to backgroundTask CE
rodriguestiago0 Nov 24, 2022
b9a0712
Update to dotnet 7.0.100 sdk
rodriguestiago0 Nov 24, 2022
1df6f0a
fixed build
rodriguestiago0 Nov 24, 2022
1d59084
fixed build
rodriguestiago0 Nov 24, 2022
86de024
Revert to task CE and dotnet 6 sdk
rodriguestiago0 Nov 24, 2022
b5a8e1b
Fixed tests
rodriguestiago0 Nov 24, 2022
8974e22
Changed to backgroundTask
rodriguestiago0 Nov 24, 2022
0491d56
Update to dotnet SDK7 to use the backgroundTask CE
rodriguestiago0 Nov 24, 2022
93fbced
Updated documentarion
rodriguestiago0 Nov 24, 2022
0ee5773
Use slash instead of back slash
rodriguestiago0 Nov 24, 2022
06eaca7
Update workflow dotnet version
rodriguestiago0 Nov 24, 2022
27d7afc
Update to dotnet 7
rodriguestiago0 Nov 24, 2022
b50fb4b
Update to dotnet 7.0
rodriguestiago0 Nov 24, 2022
215b03a
Update to dotnet 7.0
rodriguestiago0 Nov 24, 2022
fed8b30
Remove DivRem for build porpuse
rodriguestiago0 Nov 25, 2022
ea57139
Trying to fix the build
rodriguestiago0 Nov 25, 2022
851d161
Update docTool to dotnet 7
rodriguestiago0 Nov 25, 2022
3e1bd63
Merge branch 'master' into rodrigues/first_try_to_add_valuetask
wallymathieu Nov 27, 2022
fa911b4
Merge changes
wallymathieu Nov 27, 2022
4f743b4
net7 only for dotnet subset of fable
wallymathieu Nov 27, 2022
7aedeac
rm subfolder global json
wallymathieu Nov 27, 2022
9c1912c
+ reference in Comonad docs
gusty Nov 28, 2022
60bc944
Syntax
gusty Nov 28, 2022
03ec920
Fix merge error and minimize diff
gusty Nov 28, 2022
5fa3f0e
Merge branch 'master' into rodrigues/first_try_to_add_valuetask
gusty Nov 28, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion global.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"sdk": {
"version": "6.0.200",
"version": "7.0.100",
"rollForward": "latestFeature"
},

Expand Down
9 changes: 9 additions & 0 deletions src/FSharpPlus/Control/Applicative.fs
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,9 @@ type Apply =
#if !FABLE_COMPILER
static member ``<*>`` (f: Task<_> , x: Task<'T> , [<Optional>]_output: Task<'U> , [<Optional>]_mthd: Apply) = Task.apply f x : Task<'U>
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member ``<*>`` (f: ValueTask<_> , x: ValueTask<'T> , [<Optional>]_output: ValueTask<'U> , [<Optional>]_mthd: Apply) = ValueTask.apply f x : ValueTask<'U>
#endif
static member ``<*>`` (f: Async<_> , x: Async<'T> , [<Optional>]_output: Async<'U> , [<Optional>]_mthd: Apply) = Async.apply f x : Async<'U>
static member ``<*>`` (f: option<_> , x: option<'T> , [<Optional>]_output: option<'U> , [<Optional>]_mthd: Apply) = Option.apply f x : option<'U>
static member ``<*>`` (f: Result<_,'E> , x: Result<'T,'E> , [<Optional>]_output: Result<'b,'E> , [<Optional>]_mthd: Apply) = Result.apply f x : Result<'U,'E>
Expand Down Expand Up @@ -81,6 +84,9 @@ type Lift2 =
#if !FABLE_COMPILER
static member Lift2 (f, (x: Task<'T> , y: Task<'U> ), _mthd: Lift2) = Task.map2 f x y
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Lift2 (f, (x: ValueTask<'T> , y: ValueTask<'U> ), _mthd: Lift2) = ValueTask.map2 f x y
#endif
static member Lift2 (f, (x , y ), _mthd: Lift2) = Async.map2 f x y
static member Lift2 (f, (x , y ), _mthd: Lift2) = Option.map2 f x y
static member Lift2 (f, (x: Result<'T,'Error> , y: Result<'U,'Error> ), _mthd: Lift2) = Result.map2 f x y
Expand Down Expand Up @@ -119,6 +125,9 @@ type Lift3 =
#if !FABLE_COMPILER
static member Lift3 (f, (x: Task<'T> , y: Task<'U> , z: Task<'V> ), _mthd: Lift3) = Task.map3 f x y z
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Lift3 (f, (x: ValueTask<'T> , y: ValueTask<'U> , z: ValueTask<'V> ), _mthd: Lift3) = ValueTask.map3 f x y z
#endif
static member Lift3 (f, (x , y , z ), _mthd: Lift3) = Async.map3 f x y z
static member Lift3 (f, (x , y , z ), _mthd: Lift3) = Option.map3 f x y z
static member Lift3 (f, (x: Result<'T,'Error> , y: Result<'U,'Error> , z: Result<'V, 'Error> ), _mthd: Lift3) = Result.map3 f x y z
Expand Down
11 changes: 11 additions & 0 deletions src/FSharpPlus/Control/Comonad.fs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,9 @@ type Extract =
#if !FABLE_COMPILER
static member Extract (f: Task<'T> ) = f.Result
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Extract (f: ValueTask<'T> ) = f.Result
#endif
static member inline Invoke (x: '``Comonad<'T>``) : 'T =
let inline call_2 (_mthd: ^M, x: ^I) = ((^M or ^I) : (static member Extract : _ -> _) x)
call_2 (Unchecked.defaultof<Extract>, x)
Expand Down Expand Up @@ -57,6 +60,14 @@ type Extend =
elif k.Status = TaskStatus.Canceled then tcs.SetCanceled ()
elif k.Status = TaskStatus.Faulted then tcs.SetException k.Exception.InnerExceptions) |> ignore
tcs.Task


#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member (=>>) (g: ValueTask<'T> , f: ValueTask<'T> -> 'U ) : ValueTask<'U> =
backgroundTask {
return! f g
} |> ValueTask<'U>
#endif

// Restricted Comonads
Expand Down
9 changes: 9 additions & 0 deletions src/FSharpPlus/Control/Functor.fs
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,9 @@ type Map =
#if !FABLE_COMPILER
static member Map ((x: Task<'T> , f: 'T->'U), _mthd: Map) = Task.map f x : Task<'U>
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Map ((x: ValueTask<'T> , f: 'T->'U), _mthd: Map) = ValueTask.map f x : ValueTask<'U>
#endif
static member Map ((x: option<_> , f: 'T->'U), _mthd: Map) = Option.map f x
static member Map ((x: list<_> , f: 'T->'U), _mthd: Map) = List.map f x : list<'U>
static member Map ((g: 'R->'T , f: 'T->'U), _mthd: Map) = (>>) g f
Expand Down Expand Up @@ -144,6 +147,9 @@ type Unzip =
#if !FABLE_COMPILER
static member Unzip ((source: Task<'T * 'U> , _output: Task<'T> * Task<'U> ) , _mthd: Unzip ) = Map.Invoke fst source, Map.Invoke snd source
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Unzip ((source: ValueTask<'T * 'U> , _output: ValueTask<'T> * ValueTask<'U> ) , _mthd: Unzip ) = Map.Invoke fst source, Map.Invoke snd source
#endif
static member Unzip ((source: option<'T * 'U> , _output: option<'T> * option<'U> ) , _mthd: Unzip ) = Option.unzip source

static member Unzip ((source: list<'T * 'U> , _output: list<'T> * list<'U> ) , _mthd: Unzip ) = List.unzip source
Expand Down Expand Up @@ -208,6 +214,9 @@ type Zip =
#if !FABLE_COMPILER
static member Zip ((x: Task<'T> , y: Task<'U> , _output: Task<'T*'U> ), _mthd: Zip) = Task.zip x y
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Zip ((x: ValueTask<'T> , y: ValueTask<'U> , _output: ValueTask<'T*'U> ), _mthd: Zip) = ValueTask.zip x y
#endif

static member inline Invoke (source1: '``ZipFunctor<'T1>``) (source2: '``ZipFunctor<'T2>``) =
let inline call_4 (a: ^a, b: ^b, c: ^c, d: ^d) = ((^a or ^b or ^c or ^d) : (static member Zip : (_*_*_)*_ -> _) (b, c, d), a)
Expand Down
63 changes: 38 additions & 25 deletions src/FSharpPlus/Control/Monad.fs
Original file line number Diff line number Diff line change
Expand Up @@ -16,16 +16,19 @@ open FSharpPlus.Internals.Prelude
// Monad class ------------------------------------------------------------

type Bind =
static member (>>=) (source: Lazy<'T> , f: 'T -> Lazy<'U> ) = lazy (f source.Value).Value : Lazy<'U>
static member (>>=) (source: seq<'T> , f: 'T -> seq<'U> ) = Seq.bind f source : seq<'U>
static member (>>=) (source: Lazy<'T> , f: 'T -> Lazy<'U> ) = lazy (f source.Value).Value : Lazy<'U>
static member (>>=) (source: seq<'T> , f: 'T -> seq<'U> ) = Seq.bind f source : seq<'U>
#if !FABLE_COMPILER
static member (>>=) (source: Task<'T> , f: 'T -> Task<'U> ) = Task.bind f source : Task<'U>
static member (>>=) (source , f: 'T -> _ ) = Nullable.bind f source : Nullable<'U>
static member (>>=) (source: Task<'T> , f: 'T -> Task<'U> ) = Task.bind f source : Task<'U>
static member (>>=) (source , f: 'T -> _ ) = Nullable.bind f source : Nullable<'U>
#endif
static member (>>=) (source , f: 'T -> _ ) = Option.bind f source : option<'U>
static member (>>=) (source , f: 'T -> _ ) = List.collect f source : list<'U>
static member (>>=) (source , f: 'T -> _ ) = Array.collect f source : 'U []
static member (>>=) (source , k: 'T -> _ ) = (fun r -> k (source r) r) : 'R->'U
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member (>>=) (source: ValueTask<'T> , f: 'T -> ValueTask<'U> ) = ValueTask.bind f source : ValueTask<'U>
#endif
static member (>>=) (source , f: 'T -> _ ) = Option.bind f source : option<'U>
static member (>>=) (source , f: 'T -> _ ) = List.collect f source : list<'U>
static member (>>=) (source , f: 'T -> _ ) = Array.collect f source : 'U []
static member (>>=) (source , k: 'T -> _ ) = (fun r -> k (source r) r) : 'R->'U
#if !FABLE_COMPILER
static member inline (>>=) ((w: 'Monoid, a: 'T), k: 'T -> 'Monoid * 'U) = let m, b = k a in (Plus.Invoke w m, b) : 'Monoid*'U
#else
Expand Down Expand Up @@ -66,24 +69,27 @@ type Bind =

type Join =
inherit Default1
static member inline Join (x: '``Monad<'Monad<'T>>``, [<Optional>]_output: '``Monad<'T>`` , [<Optional>]_mthd: Default2) = Bind.InvokeOnInstance x id : '``Monad<'T>``
static member inline Join (x: '``Monad<'Monad<'T>>``, [<Optional>]_output: '``Monad<'T>`` , [<Optional>]_mthd: Default1) = ((^``Monad<'Monad<'T>>`` or ^``Monad<'T>``) : (static member Join : _ -> _) x) : '``Monad<'T>``
static member Join (x: Lazy<Lazy<_>> , [<Optional>]_output: Lazy<'T> , [<Optional>]_mthd: Join ) = lazy x.Value.Value : Lazy<'T>
static member Join (x: seq<seq<_>> , [<Optional>]_output: seq<'T> , [<Optional>]_mthd: Join ) = Seq.concat x : seq<'T>
static member Join (x: Id<_> , [<Optional>]_output: Id<'T> , [<Optional>]_mthd: Join ) = x.getValue : Id<'T>
#if !FABLE_COMPILER
static member Join (x: Task<Task<_>> , [<Optional>]_output: Task<'T> , [<Optional>]_mthd: Join ) = Task.join x : Task<'T>
static member inline Join (x: '``Monad<'Monad<'T>>`` , [<Optional>]_output: '``Monad<'T>`` , [<Optional>]_mthd: Default2) = Bind.InvokeOnInstance x id : '``Monad<'T>``
static member inline Join (x: '``Monad<'Monad<'T>>`` , [<Optional>]_output: '``Monad<'T>`` , [<Optional>]_mthd: Default1) = ((^``Monad<'Monad<'T>>`` or ^``Monad<'T>``) : (static member Join : _ -> _) x) : '``Monad<'T>``
static member Join (x: Lazy<Lazy<_>> , [<Optional>]_output: Lazy<'T> , [<Optional>]_mthd: Join ) = lazy x.Value.Value : Lazy<'T>
static member Join (x: seq<seq<_>> , [<Optional>]_output: seq<'T> , [<Optional>]_mthd: Join ) = Seq.concat x : seq<'T>
static member Join (x: Id<_> , [<Optional>]_output: Id<'T> , [<Optional>]_mthd: Join ) = x.getValue : Id<'T>
#if !FABLE_COMPILER
static member Join (x: Task<Task<_>> , [<Optional>]_output: Task<'T> , [<Optional>]_mthd: Join ) = Task.join x : Task<'T>
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Join (x: ValueTask<ValueTask<_>> , [<Optional>]_output: ValueTask<'T> , [<Optional>]_mthd: Join ) = ValueTask.join x : ValueTask<'T>
#endif
static member Join (x , [<Optional>]_output: option<'T> , [<Optional>]_mthd: Join ) = Option.flatten x : option<'T>
static member Join (x: list<list<_>> , [<Optional>]_output: list<'T> , [<Optional>]_mthd: Join ) = List.concat x : list<'T>
static member Join (x: _ [][] , [<Optional>]_output: 'T [] , [<Optional>]_mthd: Join ) = Array.concat x : 'T []
static member Join (g , [<Optional>]_output: 'R->'T , [<Optional>]_mthd: Join ) = (fun r -> (g r) r) : 'R->'T
static member inline Join (m1, (m2, x) , [<Optional>]_output: 'Monoid * 'T , [<Optional>]_mthd: Join ) = Plus.Invoke m1 m2, x : 'Monoid*'T
static member Join (x , [<Optional>]_output: Async<'T> , [<Optional>]_mthd: Join ) = async.Bind (x, id) : Async<'T>
static member Join (x , [<Optional>]_output: Result<'T,'E> , [<Optional>]_mthd: Join ) = Result.flatten x : Result<'T,'E>
static member Join (x , [<Optional>]_output: Choice<'T,'E> , [<Optional>]_mthd: Join ) = Choice.flatten x : Choice<'T,'E>

static member Join (x: Map<_,_> , [<Optional>]_output: Map<'Key,'Value>, [<Optional>]_mthd: Join ) : Map<'Key,'Value> =
static member Join (x , [<Optional>]_output: option<'T> , [<Optional>]_mthd: Join ) = Option.flatten x : option<'T>
static member Join (x: list<list<_>> , [<Optional>]_output: list<'T> , [<Optional>]_mthd: Join ) = List.concat x : list<'T>
static member Join (x: _ [][] , [<Optional>]_output: 'T [] , [<Optional>]_mthd: Join ) = Array.concat x : 'T []
static member Join (g , [<Optional>]_output: 'R->'T , [<Optional>]_mthd: Join ) = (fun r -> (g r) r) : 'R->'T
static member inline Join (m1, (m2, x) , [<Optional>]_output: 'Monoid * 'T , [<Optional>]_mthd: Join ) = Plus.Invoke m1 m2, x : 'Monoid*'T
static member Join (x , [<Optional>]_output: Async<'T> , [<Optional>]_mthd: Join ) = async.Bind (x, id) : Async<'T>
static member Join (x , [<Optional>]_output: Result<'T,'E> , [<Optional>]_mthd: Join ) = Result.flatten x : Result<'T,'E>
static member Join (x , [<Optional>]_output: Choice<'T,'E> , [<Optional>]_mthd: Join ) = Choice.flatten x : Choice<'T,'E>

static member Join (x: Map<_,_> , [<Optional>]_output: Map<'Key,'Value>, [<Optional>]_mthd: Join ) : Map<'Key,'Value> =
Map (seq {
for KeyValue(k, v) in x do
match Map.tryFind k v with
Expand Down Expand Up @@ -128,6 +134,9 @@ type Return =
#if !FABLE_COMPILER
static member Return (_: 'T Task , _: Return ) = fun x -> Task.FromResult x : 'T Task
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Return (_: 'T ValueTask , _: Return ) = fun x -> ValueTask.FromResult x : 'T ValueTask
#endif
static member Return (_: option<'a> , _: Return ) = fun x -> Some x : option<'a>
static member Return (_: list<'a> , _: Return ) = fun x -> [ x ] : list<'a>
static member Return (_: 'a [] , _: Return ) = fun x -> [|x|] : 'a []
Expand Down Expand Up @@ -173,6 +182,10 @@ type Delay =
static member inline Invoke (source : unit -> '``Monad<'T>``) : '``Monad<'T>`` = Bind.Invoke (Return.Invoke ()) source

#endif

#if NETSTANDARD2_1 && !FABLE_COMPILER
static member Delay (_mthd: Delay , x: unit-> ValueTask<_> , _ ) = x () : ValueTask<'T>
#endif


[<System.ComponentModel.EditorBrowsable(System.ComponentModel.EditorBrowsableState.Never)>]
Expand Down
9 changes: 9 additions & 0 deletions src/FSharpPlus/Control/Monoid.fs
Original file line number Diff line number Diff line change
Expand Up @@ -99,8 +99,17 @@ type Plus with
type Plus with

static member inline ``+`` (x: 'a Task, y: 'a Task, [<Optional>]_mthd: Plus) = Task.map2 Plus.Invoke x y

#endif

#if NETSTANDARD2_1 && !FABLE_COMPILER
type Plus with

static member inline ``+`` (x: 'a ValueTask, y: 'a ValueTask, [<Optional>]_mthd: Plus) = ValueTask.map2 Plus.Invoke x y

#endif


static member inline ``+`` (x: Map<'a,'b> , y , [<Optional>]_mthd: Plus) = Map.unionWith Plus.Invoke x y

static member inline ``+`` (x: Dictionary<'Key,'Value>, y: Dictionary<'Key,'Value>, [<Optional>]_mthd: Plus) =
Expand Down
6 changes: 5 additions & 1 deletion src/FSharpPlus/Control/Numeric.fs
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,6 @@ open System.Collections.Generic
open Microsoft.FSharp.Quotations
open FSharpPlus.Internals.Prelude


type Zero =
inherit Default1

Expand Down Expand Up @@ -183,6 +182,11 @@ type Zero with
s.SetResult v
s.Task
#endif
#if NETSTANDARD2_1 && !FABLE_COMPILER
static member inline Zero (_: ValueTask<'a>, _: Zero) : ValueTask<'a> =
let (v: 'a) = Zero.Invoke ()
ValueTask<'a>(v)
#endif
static member inline Zero (_: 'T->'Monoid , _: Zero) = (fun _ -> Zero.Invoke ()) : 'T->'Monoid
static member inline Zero (_: Async<'a> , _: Zero) = let (v: 'a) = Zero.Invoke () in async.Return v
#if !FABLE_COMPILER
Expand Down
6 changes: 3 additions & 3 deletions src/FSharpPlus/Extensions/Task.fs
Original file line number Diff line number Diff line change
Expand Up @@ -232,13 +232,13 @@ module Task =
else
let tcs = TaskCompletionSource<unit> ()
if task.Status = TaskStatus.Faulted then
tcs.SetException task.Exception.InnerExceptions |> ignore
tcs.SetException task.Exception.InnerExceptions
elif task.Status = TaskStatus.Canceled then
tcs.SetCanceled ()
else
let k (t: Task) : unit =
if t.IsCanceled then tcs.SetCanceled () |> ignore
elif t.IsFaulted then tcs.SetException t.Exception |> ignore
if t.IsCanceled then tcs.SetCanceled ()
elif t.IsFaulted then tcs.SetException t.Exception
else tcs.SetResult ()
task.ContinueWith k |> ignore
tcs.Task
Expand Down
Loading