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.
25 lines
595 B
Plaintext
25 lines
595 B
Plaintext
Kind.Book.show.go
|
|
: ∀(book: (List (Pair String Kind.Term)))
|
|
String.Concatenator
|
|
= λbook
|
|
use P = λx String.Concatenator
|
|
use cons = λhead λtail
|
|
use P = λx String.Concatenator
|
|
use new = λhead.fst λhead.snd λnil
|
|
(Kind.Text.show.go
|
|
head.fst
|
|
(Kind.Text.show.go
|
|
" = "
|
|
(Kind.Term.show.go
|
|
head.snd
|
|
Nat.zero
|
|
(Kind.Text.show.go
|
|
String.newline
|
|
(Kind.Book.show.go tail nil)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
(~head P new)
|
|
use nil = λnil nil
|
|
(~book P cons nil) |