Kind/book/List.find.kind2
Victor Taelin 85ad65b026 use-notation
Now, there are two local binders:

let x = ...
use x = ...

The 'let' binder will create a local definition, type-check it, and
assign a name to it. When compiled, it will create 'dup' nodes.

The 'use' binder is just an alias. It will not bind a new variable, and,
when compiled, will create inline copies. Also, for type-checking, it
allows creating aliases that are definitionaly equal for the checker.
2024-03-08 17:39:37 -03:00

13 lines
353 B
Plaintext

List.find
: ∀(A: *) ∀(cond: ∀(x: A) Bool) ∀(list: (List A))
(Maybe A)
= λA λcond λlist
use P = λx (Maybe A)
use cons = λhead λtail
use found = (cond head)
use P = λx (Maybe A)
use true = (Maybe.some A head)
use false = (List.find A cond tail)
(~found P true false)
use nil = (Maybe.none A)
(~list P cons nil)