From 1e7f1bdee91324613a1675642775d6ed32d7e94d Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 15 Apr 2024 18:39:37 +0630 Subject: Changed %const format in preprocesser now Instead of %const() ... %end it will now be %const ... %end i.e. the first symbol after %const will be considered the name of the constant similar to %use. --- asm/preprocesser.cpp | 16 ++-------------- 1 file changed, 2 insertions(+), 14 deletions(-) (limited to 'asm/preprocesser.cpp') diff --git a/asm/preprocesser.cpp b/asm/preprocesser.cpp index 434a340..d68992c 100644 --- a/asm/preprocesser.cpp +++ b/asm/preprocesser.cpp @@ -81,20 +81,9 @@ pp_err_t preprocess_const_blocks(const vector &tokens, if (t->type == token_type_t::PP_CONST) { string_view capture; - if (t->content == "" && (i == tokens.size() - 1 || - tokens[i + 1]->type != token_type_t::SYMBOL)) - return ERR(pp_err_t{pp_err_type_t::EXPECTED_NAME}); - else if (t->content != "") - capture = t->content; - else + if (i + 1 >= tokens.size() || tokens[i + 1]->type != token_type_t::SYMBOL) capture = tokens[++i]->content; - // Check for brackets - auto start = capture.find('('); - auto end = capture.find(')'); - if (start == string::npos || end == string::npos) - return ERR(pp_err_t{pp_err_type_t::EXPECTED_NAME}); - ++i; size_t block_start = i, block_end = 0; for (; i < tokens.size() && tokens[i]->type != token_type_t::PP_END; ++i) @@ -105,8 +94,7 @@ pp_err_t preprocess_const_blocks(const vector &tokens, block_end = i; - blocks[capture.substr(start + 1, end - 1)] = - const_t{block_start, block_end}; + blocks[capture] = const_t{block_start, block_end}; } } -- cgit v1.2.3-13-gbd6f