mirror of
https://github.com/krgamestudios/Toy.git
synced 2026-04-15 14:54:07 +10:00
Strings, due to their potentially large size, are stored outside of a routine's code section, in the data section. To access the correct string, you must read the jump index, then the real address from the jump table - and extra layer of indirection will result in more flexible data down the road, I hope. Other changes include: * Added string concat operator .. * Added TOY_STRING_MAX_LENGTH * Strings can't be created or concatenated longer than the max length * The parser will display a warning if the bucket is too small for a string at max length, but it will continue * Added TOY_BUCKET_IDEAL to correspend with max string length * The bucket now allocates an address that is 4-byte aligned * Fixed missing entries in the parser rule table * Corrected some failing TOY_BITNESS tests
47 lines
885 B
C
47 lines
885 B
C
#pragma once
|
|
|
|
typedef enum Toy_OpcodeType {
|
|
//variable instructions
|
|
TOY_OPCODE_READ,
|
|
TOY_OPCODE_LOAD,
|
|
TOY_OPCODE_LOAD_LONG, //corner case
|
|
TOY_OPCODE_DECLARE,
|
|
TOY_OPCODE_ASSIGN,
|
|
TOY_OPCODE_ACCESS,
|
|
|
|
//arithmetic instructions
|
|
TOY_OPCODE_ADD,
|
|
TOY_OPCODE_SUBTRACT,
|
|
TOY_OPCODE_MULTIPLY,
|
|
TOY_OPCODE_DIVIDE,
|
|
TOY_OPCODE_MODULO,
|
|
|
|
//comparison instructions
|
|
TOY_OPCODE_COMPARE_EQUAL,
|
|
// TOY_OPCODE_COMPARE_NOT,
|
|
TOY_OPCODE_COMPARE_LESS,
|
|
TOY_OPCODE_COMPARE_LESS_EQUAL,
|
|
TOY_OPCODE_COMPARE_GREATER,
|
|
TOY_OPCODE_COMPARE_GREATER_EQUAL,
|
|
|
|
//logical instructions
|
|
TOY_OPCODE_AND,
|
|
TOY_OPCODE_OR,
|
|
TOY_OPCODE_TRUTHY,
|
|
TOY_OPCODE_NEGATE,
|
|
|
|
//control instructions
|
|
TOY_OPCODE_RETURN,
|
|
|
|
//various action instructions
|
|
TOY_OPCODE_PRINT,
|
|
TOY_OPCODE_CONCAT,
|
|
//TODO: clear the program stack
|
|
|
|
//meta instructions
|
|
TOY_OPCODE_PASS,
|
|
TOY_OPCODE_ERROR,
|
|
TOY_OPCODE_EOF = 255,
|
|
} Toy_OpcodeType;
|
|
|