mirror of
https://github.com/idris-lang/Idris2.git
synced 2024-12-24 12:14:26 +03:00
55 lines
1.4 KiB
Idris
55 lines
1.4 KiB
Idris
import Data.List
|
|
import Data.Nat
|
|
|
|
namespace MaybeList
|
|
public export
|
|
(>>=) : (Maybe . List) a -> (a -> (Maybe . List) b) -> (Maybe . List) b
|
|
(>>=) = (>>=) @{Compose}
|
|
|
|
public export
|
|
pure : a -> (Maybe . List) a
|
|
pure = Just . singleton
|
|
|
|
public export
|
|
guard : Bool -> (Maybe . List) ()
|
|
guard False = Nothing
|
|
guard True = pure ()
|
|
|
|
namespace ListMaybe
|
|
public export
|
|
(>>=) : (List . Maybe) a -> (a -> (List . Maybe) b) -> (List . Maybe) b
|
|
(>>=) = (>>=) @{Compose}
|
|
|
|
public export
|
|
(>>) : (List . Maybe) () -> Lazy ((List . Maybe) b) -> (List . Maybe) b
|
|
(>>) = (>>) @{Compose}
|
|
|
|
public export
|
|
pure : a -> (List . Maybe) a
|
|
pure = singleton . Just
|
|
|
|
public export
|
|
guard : Bool -> (List . Maybe) ()
|
|
guard False = []
|
|
guard True = ListMaybe.pure ()
|
|
|
|
-- Deliberately introduce ambiguity
|
|
namespace ListMaybe2
|
|
public export
|
|
(>>=) : (List . Maybe) a -> (a -> (List . Maybe) b) -> (List . Maybe) b
|
|
(>>=) = (>>=) @{Compose}
|
|
|
|
-- "Qualified do" should propagate the namespace to nested bangs.
|
|
-- "pure" and "guard" calls generated by comprehensions are
|
|
-- also subject to "qualified do".
|
|
partial
|
|
propagateNSToBangs : (List . Maybe) (Nat, Nat)
|
|
propagateNSToBangs = ListMaybe.do
|
|
let x = ![x | x <- map Just [1..10], modNat x 2 == 0]
|
|
let f = !(map Just $ Prelude.do [(+ x) | x <- [1..3]])
|
|
xs <- [MaybeList.do
|
|
Just [!(Just $ Prelude.do [(*x) | x <- [1..10], modNat x 2 == 1])
|
|
!(Just [4, 5, 6])]]
|
|
y <- map Just xs
|
|
[Just (f (10 * x), y)]
|