From 4581329cde6cfb64399be48f58d67310ab19ee1b Mon Sep 17 00:00:00 2001 From: Preston Pan Date: Sat, 7 Jan 2023 09:54:40 -0800 Subject: include working --- README.md | 60 +++++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 55 insertions(+), 5 deletions(-) (limited to 'README.md') diff --git a/README.md b/README.md index a05b2c1..25e5db9 100644 --- a/README.md +++ b/README.md @@ -8,8 +8,58 @@ I plan to add support for macros and other stuff. This is a functional programming language so functions are first-class. ## TODO -- [X] Write the lexer -- [X] Write the parser -- [X] Write hash table -- [X] Write the visitor -- [ ] Write the print functions +Each todo here represents one task that I have not done. +Note that all the tasks that I finished are bigger than +the ones that I have not, and that is simply because I +made this checklist after I did everything in the first +checklist. + +Estimate: 90% done. + +### DONE +- [X] Write the lexer (easy) +- [X] Write the parser (medium-hard) +- [X] Write hash table (medium) +- [X] Write the visitor (hard) +- [X] Write a few print functions (trivial) + +### NOT DONE +- [ ] Write the print function for lists (trivial) +- [ ] Implement macros (medium) +- [ ] Implement a primitive include system (easy-medium) +- [ ] Finish type conversion builtins (easy) +- [ ] Finish read and write builtins (easy) + +### Wishlist +- [ ] Maybe a garbage collector? +- [ ] Write a standard library for math and other utilities + +## BUILDING +To build and install this program on unix-likes, run: +`make && sudo make install` + +## SYNTAX +Programming in this language, you may find some differences from scheme. Here are the basics: +1. You can define anonymous functions with `lambda`. All functions are first class and also self evaluating expressions. +2. Each anonymous function can contain exactly one expression. +3. Each function may have an arbitrary amount of parameters (at least, as many as possible before memory problems occur). +4. String, integer, float, boolean, function, list, and symbol types are supported. +5. You may bind a symbol to an expression in order to create a global variable with `bind`. +6. There are several primitive functions from which you may build more complicated functions. +7. Each final evaluated value will be printed. + +You may find actual code examples in `doc/`. Also, there will be more functionality than +the above, but I have not implemented it yet. Some future ones are: + +8. The only side effects are printing evaluated expressions and writing to files with the `write` builtin. +9. You may define macros. +10. Let's all have fun and play together! + +Wait a second, that last one isn't one of the rules... + +## CONTRIBUTING +If you send diffs to me that improve this code, chances are I will accept the diffs and +try to merge them in. + +## LICENSE +See `./LICENSE`. -- cgit