Kind/book/List.Concatenator.from_list.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

12 lines
288 B
Plaintext

List.Concatenator.from_list
: ∀(T: *) ∀(xs: (List T)) (List.Concatenator T)
= λT λxs
use P = λxs (List.Concatenator T)
use cons = λhead λtail λnil
(List.cons
T
head
(List.Concatenator.from_list T tail nil)
)
use nil = λnil nil
(~xs P cons nil)