Skip to content

A very simple stack based language interpreter in Rust

License

Notifications You must be signed in to change notification settings

msakuta/rustack

Repository files navigation

Rustack

A very simple stack based language interpreter in Rust

Try it now on your browser! https://msakuta.github.io/rustack/

Overview

This repo is the implementation of the example script used in my book: Rustで作るプログラミング言語 (Japanese).

This is a sister project of mascal, a custom programming language compiler / interpreter.

It has integrated step execution feature that visualize the interpreter state at each execution step.

screenshot-step-execution

The WebAssembly deployment has API access to canvas rendering similar to PostScript graphics, so you can write a program that can render something like below. This example is a rendering of Koch curve which uses recursive calls. You can find the source in source.

koch

This rustack is stack based virtual machine similar to JVM, but it is particularly following the design of PostScript runtime. It uses reverse-polish notation for all operations and functions.

For example, the following program will print 90.

10 20 + 3 * puts

There are example source files in examples, which is step-by-step procedure to implement such a language. Each example source file in examples directory is prefixed with a number, which indicates the step of the particular source file in the progress.

A notable difference from PostScript is that the dictionary stack and the execution stack is the same, i.e. when you call a function, it will implicitly introduce a local namespace.

Wasm demo

As always, I prepared a Wasm interpreter that you can play around with in your browser.

About

A very simple stack based language interpreter in Rust

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published