Powerful meta-programming for powerful types.
Go to file
William J. Bowman 740aaee756
cur is now a pkg and a #lang
These features are currently undocumented.
2015-09-16 12:25:22 -04:00
curnel Knocked off a bunch of TODOs 2015-09-15 18:53:53 -04:00
examples cur is now a pkg and a #lang 2015-09-16 12:25:22 -04:00
lang cur is now a pkg and a #lang 2015-09-16 12:25:22 -04:00
scribblings cur is now a pkg and a #lang 2015-09-16 12:25:22 -04:00
stdlib Knocked off a bunch of TODOs 2015-09-15 18:53:53 -04:00
.gitignore cur is now a pkg and a #lang 2015-09-16 12:25:22 -04:00
cur.rkt cur is now a pkg and a #lang 2015-09-16 12:25:22 -04:00
info.rkt cur is now a pkg and a #lang 2015-09-16 12:25:22 -04:00
LICENSE Updated LICENSE to BSD 2-clause 2015-09-15 16:12:15 -04:00
oll.rkt Knocked off a bunch of TODOs 2015-09-15 18:53:53 -04:00
README.md Updates to the README 2015-09-15 19:00:00 -04:00

cur

A language with static dependent-types and dynamic types, type annotations and parentheses, theorem proving and meta-programming.

Noun
cur (plural curs)

1. (archaic) A mongrel.
2. (archaic) A detestable person.

Getting started

Requires redex-lib version 1.6 if you want answers in a reasonable amount of time. Otherwise, the type-checker may require exponential time or worse.

Open up examples/example.rkt to see a tour of Cur's features.

Open up examples/stlc.rkt to see an example of what advanced meta-programming can let you do.

Open up oll.rkt to see the implementation of the meta-programs used to enable examples/stlc.rkt, including the parsers for BNF syntax and inference rule syntax, and Coq and LaTeX generators.

Open up examples/proofs-for-free.rkt to see an implementation of the translation defined in Proofs for Free as a meta-program.

Open up stdlib/tactics to see tactics, implemented entirely via meta-programming.

Open up anything in stdlib/ to see some standard dependent-type formalisms.

Open up curnel/redex-core.rkt to see the entire "trusted" (after a large test suite) core.