diff options
author | Aryadev Chavali <aryadev@aryadevchavali.com> | 2023-11-02 20:52:05 +0000 |
---|---|---|
committer | Aryadev Chavali <aryadev@aryadevchavali.com> | 2023-11-02 20:54:26 +0000 |
commit | 9afeed6d617da4841a031423286a0b3f3804f774 (patch) | |
tree | 2d853a933aba53c4a400a1099f5b9e8b317422d8 | |
parent | bc3f12909380bd7a6f2d6dc76691ec8439b88388 (diff) | |
download | ovm-9afeed6d617da4841a031423286a0b3f3804f774.tar.gz ovm-9afeed6d617da4841a031423286a0b3f3804f774.tar.bz2 ovm-9afeed6d617da4841a031423286a0b3f3804f774.zip |
Made separate tokens for JUMP_ABS and JUMP_STACK
Makes more sense, don't need to fiddle around with strings as much in
the parser due to this!
-rw-r--r-- | asm/lexer.c | 21 | ||||
-rw-r--r-- | asm/lexer.h | 3 | ||||
-rw-r--r-- | asm/parser.c | 24 |
3 files changed, 25 insertions, 23 deletions
diff --git a/asm/lexer.c b/asm/lexer.c index 836dd08..73859c3 100644 --- a/asm/lexer.c +++ b/asm/lexer.c @@ -86,8 +86,10 @@ const char *token_type_as_cstr(token_type_t type) return "MULT"; case TOKEN_PRINT: return "PRINT"; - case TOKEN_JUMP: - return "JUMP"; + case TOKEN_JUMP_ABS: + return "JUMP_ABS"; + case TOKEN_JUMP_STACK: + return "JUMP_STACK"; case TOKEN_JUMP_IF: return "JUMP_IF"; case TOKEN_SYMBOL: @@ -293,16 +295,21 @@ token_t tokenise_symbol(buffer_t *buffer, size_t *column) offset = 5; type = TOKEN_PRINT; } + else if (sym_size >= 8 && strncmp(opcode, "JUMP.ABS", 8) == 0) + { + offset = 8; + type = TOKEN_JUMP_ABS; + } + else if (sym_size >= 10 && strncmp(opcode, "JUMP.STACK", 10) == 0) + { + offset = 10; + type = TOKEN_JUMP_STACK; + } else if (sym_size >= 7 && strncmp(opcode, "JUMP.IF", 7) == 0) { offset = 7; type = TOKEN_JUMP_IF; } - else if (sym_size >= 4 && strncmp(opcode, "JUMP", 4) == 0) - { - offset = 4; - type = TOKEN_JUMP; - } else is_opcode = false; diff --git a/asm/lexer.h b/asm/lexer.h index 2d747bc..687e1a6 100644 --- a/asm/lexer.h +++ b/asm/lexer.h @@ -48,7 +48,8 @@ typedef enum TokenType TOKEN_SUB, TOKEN_MULT, TOKEN_PRINT, - TOKEN_JUMP, + TOKEN_JUMP_ABS, + TOKEN_JUMP_STACK, TOKEN_JUMP_IF, TOKEN_SYMBOL, } token_type_t; diff --git a/asm/parser.c b/asm/parser.c index da0c93c..44c09b4 100644 --- a/asm/parser.c +++ b/asm/parser.c @@ -404,22 +404,16 @@ perr_t parse_next(token_stream_t *stream, presult_t *ret) .type = PRES_COMPLETE_RESULT}; perr = parse_type_inst(stream, &ret->instruction); break; - case TOKEN_JUMP: { - if (token.str_size == 4 && strncmp(token.str, ".ABS", 4) == 0) - { - *ret = (presult_t){.instruction = INST_JUMP_ABS(0)}; - ++stream->used; - if (stream->used >= stream->available) - return PERR_EXPECTED_OPERAND; - return parse_word_label_or_relative(stream, ret); - } - else if (token.str_size == 6 && strncmp(token.str, ".STACK", 6) == 0) - *ret = (presult_t){.instruction = INST_JUMP_STACK, - .type = PRES_COMPLETE_RESULT}; - else - return PERR_UNKNOWN_OPERATOR; + case TOKEN_JUMP_ABS: + *ret = (presult_t){.instruction = INST_JUMP_ABS(0)}; + ++stream->used; + if (stream->used >= stream->available) + return PERR_EXPECTED_OPERAND; + return parse_word_label_or_relative(stream, ret); + case TOKEN_JUMP_STACK: + *ret = (presult_t){.instruction = INST_JUMP_STACK, + .type = PRES_COMPLETE_RESULT}; break; - } case TOKEN_JUMP_IF: { *ret = (presult_t){.instruction = INST_JUMP_IF(BYTE, 0)}; return parse_jump_inst_operand(stream, ret); |