2015-07-13 12:16:30 -04:00
2016-01-09 22:37:43 -05:00
2014-08-01 18:32:50 -07:00
2015-07-18 16:30:21 -04:00
2015-12-07 13:43:22 -05:00

Kraken

The Kraken Programming Language

(try it out online at http://www.kraken-lang.org/)

(vim integration (filetype, syntax highlighting, Syntastic) at https://github.com/Limvot/kraken.vim)

(more info and examples at http://limvot.github.io/kraken/)

The Kraken Programming Language is functional but very much still in development. Currently, it consists of a RNGLALR parser written in C++, an AST intermediate representation, and a C code generator. When compiled, the kraken compiler will take in a text file to be parsed and optionally the grammer file to use and an output file name. Kraken will then generate the RNLALR parsing tables from the grammer or load them from a binary file if Kraken has been run with this exact version of the grammer before. Then it will parse the input and export one .c and .h file along with a .sh script containing the compiler command to compile the C files together into a binary.

It is invoked in this way:

kraken inputKrakenFile

OR

kraken inputKrakenFile inputGrammerFile outputName

Dependencies

It is built using CMake, which is also its only dependency.

Goals

It has the following design goals:

  • Compiled
  • Clean
  • Fast (both running and writing)
  • Good for Systems (including Operating Systems) programming
  • Minimal "magic" code. (no runtime, other libraries automatically included)

It is inspired by C/C++, Scala, and Rust.

Description
Currently, a purely functional F-Expr based Lisp compiled to WebAssembly. History contains multiple iterations of my experiments to explore and create my personal perfect language.
Readme 12 MiB
Languages
Rust 40.6%
NewLisp 12.7%
HTML 11.7%
Shell 7.5%
JavaScript 4.4%
Other 23.1%