5 releases (3 breaking)

0.4.0 Jul 6, 2023
0.3.1 Jul 6, 2023
0.3.0 Jul 6, 2023
0.2.0 Sep 7, 2022
0.1.0 Sep 7, 2022

#28 in #coding

MIT license

23KB
459 lines

Simply Script

This project provides an interpreter for "simply script", a super-simple scripting language (inspired by Assembly) that is mostly used for coding puzzles.

Syntax

"simply script" supports the following commands:

Set Command

set |register| |value|

Sets the value (32-bit integer) of the indicated register. Register names can be any combination of letters, numbers, and underscore characters, but must start with a letter. This command essentially serves the purpose of assigning a value to a variable.

Copy Command

cpy |register 1| |register 2|

Copies the value from |register 1| to |register 2|.

Add Command

add |register 1| |register 2|

Adds the value stored in |register 1| to the value stored in |register 2|. Stores the final value in |register 2|.

Sub Command

sub |register 1| |register 2|

Subtracts the value stored in |register 1| from the value stored in |register 2|. Stores the final value in |register 2|.

Jump Command

jmp |register|

The next line to execute will be the line whose value is stored in |register|. Attempting to jump to a line number less than 1 will result in a NegativeExecutionPointer error.

Jump When Zero Command

jwz |register 1| |register 2|

Check the value in |register 1|. If that value is 0, continue execution at the line number stored in |register 2|. Otherwise, continue execution with the next line.

Jump When Negative Command

jwz |register 1| |register 2|

Check the value in |register 1|. If that value is less than 0, continue execution at the line number stored in |register 2|. Otherwise, continue execution with the next line.

Jump When Positive Command

jwz |register 1| |register 2|

Check the value in |register 1|. If that value is greater than 0, continue execution at the line number stored in |register 2|. Otherwise, continue execution with the next line.

Jump Not Zero Command

jnz |register 1| |register 2|

Check the value in |register 1|. If that value is not 0, continue execution at the line number stored in |register 2|. Otherwise, continue execution with the next line.

Greater Than Command

gth |register 1| |register 2|

If the value stored in |register 1| is greater than |register 2|, store 1 in |register 2|, otherwise, store -1 in |register 2|.

Less Than Command

lth |register 1| |register 2|

If the value stored in |register 1| is less than |register 2|, store 1 in |register 2|, otherwise, store -1 in |register 2|.

Output Command

out |register|

Print the value stored in |register| to standard out.

Character Command

chr |register|

Print the value stored in |register| to standard out as an ASCII character if the value is a valid ASCII character code. If the character does not represent a valid ASCII character code, prints a '·' character instead.

Usage

Just write your "simply script" into a text file (like "do_calculation.ok") and run the script with simply do_calculation.ok.

Examples

Countdown

Sets input value to num, then prints all values counting down from num to zero. If num is negative, then nothing is printed.

set num 25
set one 1
set A 9
set B 5
jwn num A
out num
sub one num
jmp B

Print Greater Number

Sets input values to num1 and num2, then identifies and returns the greater number. Just returns one of the numbers if they are equal. By convention, registers holding line numbers for jumps are named "Excel-style" using capital letters (A-Z, AA-ZZ, etc.).

set num1 18
set num2 15
set A 10
set B 11
cpy num2 compare
gth num1 compare
jwp compare A
out num2
jmp B
out num1

Dependencies

~4MB
~82K SLoC