Forsp LLVM-based compiler
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Clyne ea55b08698
shortcut push-pops; don't env-copy functions
7 months ago
examples global env; alloca locals 7 months ago
.gitignore break code into separate files 7 months ago
LICENSE add license to files 7 months ago
Makefile switch target to x86-64 7 months ago
README.md readme update; use CC in Makefile 7 months ago
ast.cpp shortcut push-pops; don't env-copy functions 7 months ago
ast.hpp cache sp, minor refactors 7 months ago
llvm.cpp cache sp, minor refactors 7 months ago
llvm.hpp cache sp, minor refactors 7 months ago
main.cpp shortcut push-pops; don't env-copy functions 7 months ago
parser.cpp add license to files 7 months ago
parser.hpp add license to files 7 months ago
support.c switch target to x86-64 7 months ago
test.fp switch target to x86-64 7 months ago
var.cpp shortcut push-pops; don't env-copy functions 7 months ago
var.hpp shortcut push-pops; don't env-copy functions 7 months ago

README.md

forspll

forspll is an implementation of Forsp as an LLVM-based compiler. Forsp is a tiny yet very versatile programming language that mixes features of Forth and Lisp. Through LLVM, Forsp can be compiled into efficient machine code for a wide array of platforms.

forspll features:

  • Lisp-style S-expression syntax
  • Forth-style data stack for parameters/values
  • Linking with C functions (see support.c)
  • Recursion: $self gets pointer to current function

Missing features:

  • Captured variables: Functions/lambdas are not dynamic and do not capture the state of previously declared variables
  • Quote operator: quote/'
  • Built-in dynamic allocations (implement them via platform-specific support.c)

Building

Requires Clang and LLVM development files.

Run make to build the compiler.

Run make prog to compile test.fp and support.c.