A minimalistic programming language written in C89.
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
Ludovic 'Archivist' Lagouardette badef437ff Fixed bad commenting habits vor 6 Monaten
.idea added type support vor 6 Monaten
test The most practical way to print "Hello World" vor 6 Monaten
.gitignore Initial commit vor 6 Monaten
CMakeLists.txt Added README.md contents vor 6 Monaten
LICENSE Added README.md contents vor 6 Monaten
README.md added more docs vor 6 Monaten
bench.c Added coroutine handling vor 6 Monaten
ink.h C-ified more stuff that was not C-ified, removed some unused vars vor 6 Monaten
lib.c Fixed bad commenting habits vor 6 Monaten
main.c Added garbage collection (and a memory corruption bug) vor 6 Monaten

README.md

ink

ink is a minimalistic interpreted programming language, tentatively implemented exclusively in C98. It features coroutines and can currently only manipulate integers. Part of the code may not be compliant with C98 and I will try to fix that in time.

It is fully self-contained and doesn't rely on a working standard library beyond the following:

  • malloc
  • realloc
  • free
  • putchar

To make the library not use the standard library, build it with NOSTDLIB defined as a preprocessor directive.

All of these functions need to work for ink to work. It is easy to add new functions to the interpreter. In the future, I will add a garbage collector to handle cleaning dynamically allocated resources.

It is possible to segregate unsafe allocations (allocations that should be hidden from the interpreter) by setting the inner_ versions of the library functions to different allocation functions.

Limits

  • Token size is limited to 127 bytes (see ink_lex)
  • Values and indices are limited to the platform size of int
  • Main function has a size limit of 256 tokens (see ink_compile)
  • Functions have a size limit of 256 tokens (see ink_parse)
  • Functions have a count limit 128 labels (see ink_parse)
  • Only non-main functions can use labels