Any questions are welcome at [email protected].
Here is how to try out RasmLISP (when using the build system that provides easy linking with the standard library):
- Install dependencies via
make install
. (If you want to change the GC version or its installation directory, just edit install_boehm.sh as needed. Make sure to update the Makefile to change the macro BOEHM_DIR as well.) - Type
make
into your terminal. That will use the test.lisp file in the tests directory. - The Lisp runtime library is compiled properly.
- The compiler is run in debug mode, meaning that the input file (the first argument to it) will be in tests. It can also be run in extern mode (the second flag) to avoid an entry point (
_main
). parser.py
tokenizes and parses the code. Each S-expression is fed into the main function eval_lisp in compiler.py. You can take a peek at that if you want to see how it works.- Once compilation is done the output file is tests/test.asm. The assembler configured in the Makefile will generate a binary, properly linked with the library, in out.
- To run your output file just type
make run
.
If you want to try out a pre-written program, I have a demo of Conway's Game of Life in the tests directory. It uses the curses library (you can read more about the curses bindings in DOCUMENTATION.md). Simply copy its contents into tests/test.asm, and follow the steps above to run the code.