Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rayhanadev/prizm
A toy BrainF-eqsue language.
https://github.com/rayhanadev/prizm
3d arrays brainf custom-language esolang esoteric-language esoteric-programming-language nodejs
Last synced: 10 days ago
JSON representation
A toy BrainF-eqsue language.
- Host: GitHub
- URL: https://github.com/rayhanadev/prizm
- Owner: rayhanadev
- License: mit
- Created: 2020-12-09T15:35:31.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2020-12-09T23:07:12.000Z (about 4 years ago)
- Last Synced: 2024-11-06T22:42:51.633Z (about 2 months ago)
- Topics: 3d, arrays, brainf, custom-language, esolang, esoteric-language, esoteric-programming-language, nodejs
- Language: JavaScript
- Homepage:
- Size: 9.77 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Prizm | 3D Turing Machine
Prizm is just a tiny esolang I made in JS similar to BrainF except you can move in three dimensions for an added challenge.## How to Use
Firstly you create a main.pzm (has to be this!) file. The first line is the length (X) of the prism, the second is height (Y) of the prism, the third is the depth (Z) of the prism, the fourth is the debug settings (true/false) and lastly anything after that is code. The file must be formatted like such or else it will throw an error when reading.For Example:
```pzm
5
5
5
true
+++
F++R+B++
RRRF++
```You control a cursor (X), selector (Y) and pointer (Z) to locate various cells. You increment cells up and down to change their value and can output to the console according to the ASCII value of the cell.
You initially start in the top, left, back corner of the prism and are able to resize it to a limit of 999 cells in any direction. Each cell starts with an initial value of zero.
# Commands
| Symbol | Keyword | Action |
| :----: | ------- | ------ |
| + | Increment Up | Increments a Cell Up |
| - | Increment Down | Increments a Cell Down |
| L | Left | Moves the Cursor Left |
| R | Right | Moves the Cursor Right |
| U | Up | Moves the Selector Up |
| D | Down | Moves the Selector Down |
| F | Forward | Moves the Pointer Forward |
| B | Backward | Moves the Pointer Backward |
| P | Point | Marks a Jump Point |
| J | Jump | Jumps to the first available Jump Point if the cell the jump point marked isn't 0 |
| O | Output | Output the ASCII value of the current cell |
| N | Null | Skips Position on Code/Does Nothing |