Minimal functional programming language
(Development is currently on hold)
Like the Whippet, this language [will have] the highest running speed of any [language] of its [size].
The goal is to create a small language that only has the essential features needed to be able to do pretty much anything. No bloat. This will make self-hosting easier and faster.
In this spirit, the under the hood type system is minimal. There are only 5 types:
num
- 64 bit floating point number - this is used for numberschar
- 8 bit number - used to represent charactersbool
- used to represent true and falsefn
- functions are first-class citizens, this is their typearray
- an array of any type (even arrays)
The language is chill with side effects. There is no need to wrap anything in monads.
At the moment the language is interpreted, but the goal is to create a self-hosting compiler. TBD whether to compile directly to assembly, LLVM IR or QBE IL. There is no garbage collector at the moment (TBD 🤨).
Finally, here is a blog-post about some design decisions: Designing a functional programming language.
Compile the interpreter
cargo build --release && mv target/release/ninoi .
Run a example program
./ninoi examples/is-prime.ni
Output
Let's calculate primes! 10000019 10000079 10000103 10000121 10000139 10000141 10000169 10000189 Time in milliseconds: 47
More examples can be found in /examples!
There is an expression-to-AST-diagram program too!
cargo run --bin mermaid "1+2+3 + 1+2/3 + x mod y" > mermaid.md
Documentation can be found in the docs.
There you can find the language specification (WIP) and the grammar specification.
let is_prime_helper:fn = (x:num, i:num):bool => true ? {
x==i => true,
x mod i == 0 => false,
is_prime_helper(x, i + 1)
};
let is_prime:fn = (x:num):bool => x ? {
1 => false,
2 => true,
is_prime_helper(x, 2)
};
print(is_prime(2));
print(is_prime(3));
print(is_prime(4));
print(is_prime(5));
print(is_prime(6));
print(is_prime(7));
Click to expand
- 2023-10-13: Just finished defining the initial complete syntax. Next is to rewrite the lexer, parser and code generator to support the new syntax.
- 2023-10-15: Syntax has been reworked and a grammar definition can be found in [docs](docs/grammar.md). The lexer has been updated to support the new syntax and the parser has been completely rewritten as a recursive descent parser. A code generated has been implemented that can generate LLVM IR. The next steps are to implement more language features. See [milestones](#milestones) for more details.
- 2023-10-17: Created compiler program
- 2023-10-22: Implemented declaring and calling functions. Function calls can be used as values in an expression. The next steps will need to be refactoring and adding unit tests.
- 2023-10-28: Re-wrote the lexer and parser to rust. Added tons of unit tests. Created an interpreter to run `.ni` files.
- 2023-10-29: Any programming language's most important features is correctness and safety. No need for more justification.
- 2023-10-04: Added tail-call optimization. More complex computations are now possible.
- 2024-01-13: Simplified type system to only have 5 types.
- 2024-01-14: Finished expression-to-AST-diagram, added more tests, added more support for arrays and improved printing.
- 2024-02-12: Interpreter now keeps symbols in [scoped-symbols](src/scoped_symbols.rs) leading to a 10x speed improvement compared to the initial symbol table.
- 2024-05-21: The parser has been refactored to use Results, allowing for some basic error reporting during parsing. A lot of unit and end to end tests have been added in order to ensure the correctness.
I will take a break from this project (in order to focus on other projects) and may come back to it in the future.
- Define complete syntax
- numbers
- characters
- booleans
- function declaration and call
- arrays and strings
- built-in functions
- matching
- map
- filter
- reduce
- importing
- anonymous functions
- self-host compiler
- SOLVE ADVENT OF CODE
In order to run the tests, simply run:
cargo test
What is this it, and what is it not? The goal is not to create the next big language that everybody should use. This is more of an experiment in making a minimal compiled functional programming language.
I will work on this in my spare time. No guarantees can be made.
The initial version of this language was written in C. This code has now been removed from the main branch, but can be found here.