mirror of
https://github.com/HigherOrderCO/Kind.git
synced 2024-09-11 20:47:25 +03:00
85ad65b026
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.
7 lines
240 B
Plaintext
7 lines
240 B
Plaintext
List.fold
|
|
: ∀(T: *) ∀(list: (List T)) (List.Folder T)
|
|
= λT λlist λP λcons λnil
|
|
use fold_P = λxs P
|
|
use fold_cons = λhead λtail (cons head (List.fold T tail P cons nil))
|
|
use fold_nil = nil
|
|
(~list fold_P fold_cons fold_nil) |