Skip to content

Latest commit

 

History

History
83 lines (58 loc) · 3.95 KB

README.md

File metadata and controls

83 lines (58 loc) · 3.95 KB

Stackline

An esoteric language inspired by Wireworld and ORCA.

  • It operates with packets of data sent across wires.
  • These packets are handled with a stack-based language.
  • It is Turing-complete (it can interpret Brainfuck, for instance), but it tries not to be too deep of a tarpit.
  • Loops and conditions can be visually expressed, variables are accessible from within the stack-based language.

examples/parallelism.txt, rendered with the CLI interface

How it works

The world is divided into a grid of cells: each cell has a state (an integer) and a "char" (a Unicode codepoint).

The state of a cell defines which action it will do in the current simulation step:

  • 0, dormant, does nothing
  • 1, active, executes an associated function and usually gets as new state 2
  • 2, resting, does nothing (also used by the packet system to clean up)
  • 3, waiting, waits on some other cell(s) to finish work

The char defines what the action will be. For instance:

  • -, |, + are wires, they transmit signals respectively horizontally, vertically and orthogonally
  • >, <, ^, v are diodes, they only transmit signal to one direction
  • # sends an incomming signal down and waits on a result, which it then sends horizontally
  • : executes a set of instructions on its right, then either transmits the signal down and holds or transmits the signal up back to a #
  • p is used to debug things, printing them on lines below p that are preceded by a colon. You should use this with caution, as it can break stuff.
  • ! creates an empty signal and transmits it orthogonally

Finally, data travels on the wire and between the cells. This data is manipulated by instructions, which use a simple stack-based language. Here are some of them, but a full list is available in the reference sheet:

  • p, pushes a number or a string onto the stack. For instance, p-2.3 pushes -2.3 and p"Oh?" pushes Oh?.
  • d, duplicates the topmost item from the stack. It can take an optional number parameter to specify the n-th element from the top of the stack to pop: p3d pushes 3 twice on the stack and p2p3d1 pushes 3, 2, 3.
  • +, -, /, *, % perform basic arithmetic operations on the two topmost elements of the stack, popping them and pushing the result

When put together, we can write simple programs. The following programs creates a new, empty signal, then puts 0 on it and enters a loop (the rectangular pattern). The loop adds one on the stack and sums it with the previous value, it then prints the result.

!-#-->+<--+--p
  :p0 |   |  :
      +#--+
       :p1
       :+

More complex programs can be expressed in this language. You can find some in the examples folder!

A reference sheet of every character used in this language is available at characters.md. We recommend that you have a read of it or that you keep it at hand whenever you're analyzing someone else's code written in Stackline.

Installing

To install and run this software, you will need git (or any git frontend, like Github Desktop) and node.js.

Clone this repository, then navigate into it:

git clone https://github.com/adri326/stackline
cd stackline

Then, install the required dependencies using npm:

npm install

Running

You can run the simulation by calling node . followed by the path of the source file. The source file should be encoded in UTF-8. For instance, the following runs the "Hello world" example:

node . examples/hello-world.txt

Simply hit Ctrl-C to stop the simulation whenever you want.