From ba3525d53311dfc89610748ef3ce0a8d9e3756b9 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 15 Apr 2024 18:37:45 +0630 Subject: preprocesser publicly exposes only preprocesser function The preprocess_* functions are now privately contained within the implementation file to help the preprocesser outer function. Furthermore I've simplified the API of the preprocess_* functions by making them only return pp_err_t and store their results in a vector parameter taken by reference. --- asm/preprocesser.cpp | 104 +++++++++++++++++++++++++-------------------------- asm/preprocesser.hpp | 10 ----- 2 files changed, 51 insertions(+), 63 deletions(-) (limited to 'asm') diff --git a/asm/preprocesser.cpp b/asm/preprocesser.cpp index e6d40b6..434a340 100644 --- a/asm/preprocesser.cpp +++ b/asm/preprocesser.cpp @@ -18,8 +18,6 @@ using std::pair, std::vector, std::make_pair, std::string, std::string_view; -#define ERR(E) std::make_pair(tokens, (E)) -#define VAL(E) std::make_pair(E, pp_err_t{pp_err_type_t::OK}) #define VCLEAR(V) \ std::for_each((V).begin(), (V).end(), \ [](token_t *t) \ @@ -27,38 +25,9 @@ using std::pair, std::vector, std::make_pair, std::string, std::string_view; delete t; \ }); -pp_err_t preprocesser(const vector &tokens, - vector &vec_out) +pp_err_t preprocess_use_blocks(const vector &tokens, + vector &vec_out) { - vector use_block_tokens; - pp_err_t pperr{pp_err_type_t::OK}; - std::tie(use_block_tokens, pperr) = preprocess_use_blocks(tokens); - if (pperr.type != pp_err_type_t::OK) - { - vec_out = tokens; - return pperr; - } - - vector const_block_tokens; - std::tie(const_block_tokens, pperr) = - preprocess_const_blocks(use_block_tokens); - if (pperr.type != pp_err_type_t::OK) - { - VCLEAR(tokens); - vec_out = use_block_tokens; - return pperr; - } - - VCLEAR(use_block_tokens); - vec_out = const_block_tokens; - - return pp_err_t{pp_err_type_t::OK}; -} - -pair, pp_err_t> -preprocess_use_blocks(const vector &tokens) -{ - vector new_tokens; for (size_t i = 0; i < tokens.size(); ++i) { token_t *t = tokens[i]; @@ -67,34 +36,34 @@ preprocess_use_blocks(const vector &tokens) if (i + 1 >= tokens.size() || tokens[i + 1]->type != token_type_t::LITERAL_STRING) { - VCLEAR(new_tokens); - return ERR(pp_err_t(pp_err_type_t::EXPECTED_STRING, t)); + VCLEAR(vec_out); + return pp_err_t(pp_err_type_t::EXPECTED_STRING, t); } token_t *name = tokens[i + 1]; auto source = read_file(name->content.c_str()); if (!source) { - VCLEAR(new_tokens); - return ERR(pp_err_t(pp_err_type_t::FILE_NONEXISTENT, name)); + VCLEAR(vec_out); + return pp_err_t(pp_err_type_t::FILE_NONEXISTENT, name); } std::vector ftokens; lerr_t lerr = tokenise_buffer(source.value(), ftokens); if (lerr.type != lerr_type_t::OK) { - VCLEAR(new_tokens); - return ERR(pp_err_t(pp_err_type_t::FILE_PARSE_ERROR, name, lerr)); + VCLEAR(vec_out); + return pp_err_t(pp_err_type_t::FILE_PARSE_ERROR, name, lerr); } - new_tokens.insert(new_tokens.end(), ftokens.begin(), ftokens.end()); + vec_out.insert(vec_out.end(), ftokens.begin(), ftokens.end()); ++i; } else - new_tokens.push_back(new token_t{*t}); + vec_out.push_back(new token_t{*t}); } - return VAL(new_tokens); + return pp_err_t(); } struct const_t @@ -102,8 +71,8 @@ struct const_t size_t start, end; }; -pair, pp_err_t> -preprocess_const_blocks(vector const &tokens) +pp_err_t preprocess_const_blocks(const vector &tokens, + vector &vec_out) { std::unordered_map blocks; for (size_t i = 0; i < tokens.size(); ++i) @@ -132,7 +101,7 @@ preprocess_const_blocks(vector const &tokens) continue; if (i == tokens.size()) - return ERR(pp_err_t{pp_err_type_t::EXPECTED_END}); + return pp_err_t{pp_err_type_t::EXPECTED_END}; block_end = i; @@ -141,12 +110,11 @@ preprocess_const_blocks(vector const &tokens) } } - vector new_tokens; if (blocks.size() == 0) { // Just construct a new vector and carry on for (token_t *token : tokens) - new_tokens.push_back(new token_t{*token}); + vec_out.push_back(new token_t{*token}); } else { @@ -163,22 +131,52 @@ preprocess_const_blocks(vector const &tokens) auto it = blocks.find(token->content); if (it == blocks.end()) { - VCLEAR(new_tokens); - return ERR(pp_err_t(pp_err_type_t::UNKNOWN_NAME, token)); + VCLEAR(vec_out); + return pp_err_t(pp_err_type_t::UNKNOWN_NAME, token); } const_t block = it->second; for (size_t i = block.start; i < block.end; ++i) - new_tokens.push_back(new token_t{*tokens[i]}); + vec_out.push_back(new token_t{*tokens[i]}); } else - new_tokens.push_back(new token_t{*token}); + vec_out.push_back(new token_t{*token}); } } - return VAL(new_tokens); + return pp_err_t(); } +pp_err_t preprocesser(const vector &tokens, + vector &vec_out) +{ + vector use_block_tokens; + pp_err_t pperr = preprocess_use_blocks(tokens, use_block_tokens); + if (pperr.type != pp_err_type_t::OK) + { + vec_out = tokens; + return pperr; + } + + vector const_block_tokens; + pperr = preprocess_const_blocks(use_block_tokens, const_block_tokens); + if (pperr.type != pp_err_type_t::OK) + { + VCLEAR(tokens); + vec_out = use_block_tokens; + return pperr; + } + + VCLEAR(use_block_tokens); + vec_out = const_block_tokens; + + return pp_err_t{pp_err_type_t::OK}; +} + +// TODO: Implement this +pp_err_t preprocess_macro_blocks(const vector &, + vector &); + std::ostream &operator<<(std::ostream &os, pp_err_t &err) { os << "PREPROCESSING_"; @@ -196,7 +194,7 @@ std::ostream &operator<<(std::ostream &os, pp_err_t &err) return os << "FILE_NONEXISTENT"; case FILE_PARSE_ERROR: return os << "FILE_PARSE_ERROR -> \n\t[" << err.reference->content - << "]: " << err.lerr; + << "]:" << err.lerr; case UNKNOWN_NAME: return os << "UNKNOWN_NAME"; } diff --git a/asm/preprocesser.hpp b/asm/preprocesser.hpp index ed5a421..aac3041 100644 --- a/asm/preprocesser.hpp +++ b/asm/preprocesser.hpp @@ -44,14 +44,4 @@ std::ostream &operator<<(std::ostream &, pp_err_t &); pp_err_t preprocesser(const std::vector &, std::vector &); -std::pair, pp_err_t> -preprocess_const_blocks(const std::vector &); - -std::pair, pp_err_t> -preprocess_use_blocks(const std::vector &); - -// TODO: Implement this -std::pair, pp_err_t> -preprocess_macro_blocks(const std::vector &); - #endif -- cgit v1.2.3-13-gbd6f