enso.nim: Next time don't get confused
This commit is contained in:
21
src/enso.nim
21
src/enso.nim
@ -10,7 +10,7 @@ func flatmap*[T, U](io: IO[T], fn: T -> IO[U]): IO[U]
|
||||
func lift*(fn: proc(): void): IO[void]
|
||||
func lift*[T](fn: proc(): T): IO[T]
|
||||
func join*[T](io: IO[IO[T]]): IO[T]
|
||||
func map*[T, U](io: IO[seq[T]], fn: T -> U): IO[seq[U]]
|
||||
func map*[T, U](io: IO[T], fn: T -> U): IO[U]
|
||||
func readstr*(stream: FileDesc): IO[string]
|
||||
func run*[T](io: IO[T]): T
|
||||
func strput*(str: string): IO[void]
|
||||
@ -18,7 +18,7 @@ func to_IO*[T](val: T): IO[T]
|
||||
|
||||
# Definitions
|
||||
|
||||
func flatmap*[T, U](io: IO[T], fn: T -> IO[U]): IO[U] = join(io.map(fn))
|
||||
func flatmap*[T, U](io: IO[T], fn: T -> IO[U]): IO[U] = join(map(io, fn))
|
||||
|
||||
func lift*(fn: proc(): void): IO[void] =
|
||||
proc(): void = fn()
|
||||
@ -26,21 +26,10 @@ func lift*(fn: proc(): void): IO[void] =
|
||||
func lift*[T](fn: proc(): T): IO[T] =
|
||||
proc(): T = fn()
|
||||
|
||||
func join*[T](io: IO[IO[T]]): IO[T] = io.map(run)
|
||||
func join*[T](io: IO[IO[T]]): IO[T] = map(io, run)
|
||||
|
||||
func map*[T, U](io: IO[seq[T]], fn: T -> U): IO[seq[U]] =
|
||||
proc(): seq[U] =
|
||||
let list: seq[T] = io()
|
||||
|
||||
if list.len == 0:
|
||||
@[]
|
||||
else:
|
||||
let
|
||||
head: T = list[0]
|
||||
tail: seq[T] = list[1..^1]
|
||||
new: IO[seq[T]] = to_IO tail
|
||||
|
||||
@[fn(head)] & run new.map(fn)
|
||||
func map*[T, U](io: IO[T], fn: T -> U): IO[U] =
|
||||
proc(): U = fn(run(io))
|
||||
|
||||
func readstr*(stream: FileDesc): IO[string] =
|
||||
case stream:
|
||||
|
||||
Reference in New Issue
Block a user