Namespace the lexer module
Future proofing any name collisions.
This commit is contained in:
1004
src/lexer.cpp
1004
src/lexer.cpp
File diff suppressed because it is too large
Load Diff
147
src/lexer.hpp
147
src/lexer.hpp
@@ -18,87 +18,90 @@
|
||||
#include <tuple>
|
||||
#include <vector>
|
||||
|
||||
struct Token
|
||||
namespace Lexer
|
||||
{
|
||||
enum class Type
|
||||
struct Token
|
||||
{
|
||||
PP_CONST, // %const(<symbol>)...
|
||||
PP_USE, // %use <string>
|
||||
PP_END, // %end
|
||||
PP_REFERENCE, // $<symbol>
|
||||
GLOBAL,
|
||||
STAR,
|
||||
LITERAL_NUMBER,
|
||||
LITERAL_CHAR,
|
||||
LITERAL_STRING,
|
||||
NOOP,
|
||||
HALT,
|
||||
PUSH,
|
||||
POP,
|
||||
PUSH_REG,
|
||||
MOV,
|
||||
DUP,
|
||||
MALLOC,
|
||||
MALLOC_STACK,
|
||||
MSET,
|
||||
MSET_STACK,
|
||||
MGET,
|
||||
MGET_STACK,
|
||||
MDELETE,
|
||||
MSIZE,
|
||||
NOT,
|
||||
OR,
|
||||
AND,
|
||||
XOR,
|
||||
EQ,
|
||||
LT,
|
||||
LTE,
|
||||
GT,
|
||||
GTE,
|
||||
PLUS,
|
||||
SUB,
|
||||
MULT,
|
||||
PRINT,
|
||||
JUMP_ABS,
|
||||
JUMP_STACK,
|
||||
JUMP_IF,
|
||||
CALL,
|
||||
CALL_STACK,
|
||||
RET,
|
||||
SYMBOL,
|
||||
} type;
|
||||
size_t column, line;
|
||||
std::string content;
|
||||
enum class Type
|
||||
{
|
||||
PP_CONST, // %const(<symbol>)...
|
||||
PP_USE, // %use <string>
|
||||
PP_END, // %end
|
||||
PP_REFERENCE, // $<symbol>
|
||||
GLOBAL,
|
||||
STAR,
|
||||
LITERAL_NUMBER,
|
||||
LITERAL_CHAR,
|
||||
LITERAL_STRING,
|
||||
NOOP,
|
||||
HALT,
|
||||
PUSH,
|
||||
POP,
|
||||
PUSH_REG,
|
||||
MOV,
|
||||
DUP,
|
||||
MALLOC,
|
||||
MALLOC_STACK,
|
||||
MSET,
|
||||
MSET_STACK,
|
||||
MGET,
|
||||
MGET_STACK,
|
||||
MDELETE,
|
||||
MSIZE,
|
||||
NOT,
|
||||
OR,
|
||||
AND,
|
||||
XOR,
|
||||
EQ,
|
||||
LT,
|
||||
LTE,
|
||||
GT,
|
||||
GTE,
|
||||
PLUS,
|
||||
SUB,
|
||||
MULT,
|
||||
PRINT,
|
||||
JUMP_ABS,
|
||||
JUMP_STACK,
|
||||
JUMP_IF,
|
||||
CALL,
|
||||
CALL_STACK,
|
||||
RET,
|
||||
SYMBOL,
|
||||
} type;
|
||||
size_t column, line;
|
||||
std::string content;
|
||||
|
||||
Token();
|
||||
Token(Token::Type, std::string, size_t col = 0, size_t line = 0);
|
||||
};
|
||||
Token();
|
||||
Token(Token::Type, std::string, size_t col = 0, size_t line = 0);
|
||||
};
|
||||
|
||||
const char *token_type_as_cstr(Token::Type type);
|
||||
const char *token_type_as_cstr(Token::Type type);
|
||||
|
||||
std::ostream &operator<<(std::ostream &, Token &);
|
||||
std::ostream &operator<<(std::ostream &, Token &);
|
||||
|
||||
enum class lerr_type_t
|
||||
{
|
||||
OK = 0,
|
||||
INVALID_CHAR_LITERAL,
|
||||
INVALID_CHAR_LITERAL_ESCAPE_SEQUENCE,
|
||||
INVALID_STRING_LITERAL,
|
||||
INVALID_NUMBER_LITERAL,
|
||||
INVALID_PREPROCESSOR_DIRECTIVE,
|
||||
UNKNOWN_LEXEME,
|
||||
};
|
||||
enum class lerr_type_t
|
||||
{
|
||||
OK = 0,
|
||||
INVALID_CHAR_LITERAL,
|
||||
INVALID_CHAR_LITERAL_ESCAPE_SEQUENCE,
|
||||
INVALID_STRING_LITERAL,
|
||||
INVALID_NUMBER_LITERAL,
|
||||
INVALID_PREPROCESSOR_DIRECTIVE,
|
||||
UNKNOWN_LEXEME,
|
||||
};
|
||||
|
||||
struct lerr_t
|
||||
{
|
||||
size_t col, line;
|
||||
lerr_type_t type;
|
||||
struct lerr_t
|
||||
{
|
||||
size_t col, line;
|
||||
lerr_type_t type;
|
||||
|
||||
lerr_t(lerr_type_t type = lerr_type_t::OK, size_t col = 0, size_t line = 0);
|
||||
};
|
||||
lerr_t(lerr_type_t type = lerr_type_t::OK, size_t col = 0, size_t line = 0);
|
||||
};
|
||||
|
||||
std::ostream &operator<<(std::ostream &, lerr_t &);
|
||||
std::ostream &operator<<(std::ostream &, lerr_t &);
|
||||
|
||||
lerr_t tokenise_buffer(std::string_view, std::vector<Token *> &);
|
||||
lerr_t tokenise_buffer(std::string_view, std::vector<Token *> &);
|
||||
} // namespace Lexer
|
||||
|
||||
#endif
|
||||
|
||||
@@ -30,6 +30,8 @@ extern "C"
|
||||
using std::cout, std::cerr, std::endl;
|
||||
using std::pair, std::string, std::string_view, std::vector;
|
||||
|
||||
using Lexer::Token, Lexer::lerr_t, Lexer::lerr_type_t;
|
||||
|
||||
void usage(const char *program_name, FILE *fp)
|
||||
{
|
||||
fprintf(fp,
|
||||
|
||||
@@ -18,6 +18,8 @@
|
||||
|
||||
using std::pair, std::vector, std::make_pair, std::string, std::string_view;
|
||||
|
||||
using Lexer::Token, Lexer::lerr_t, Lexer::lerr_type_t;
|
||||
|
||||
#define VCLEAR(V) \
|
||||
std::for_each((V).begin(), (V).end(), \
|
||||
[](Token *t) \
|
||||
|
||||
@@ -30,33 +30,34 @@ enum pp_err_type_t
|
||||
|
||||
struct pp_err_t
|
||||
{
|
||||
const Token *reference;
|
||||
const Lexer::Token *reference;
|
||||
pp_err_type_t type;
|
||||
lerr_t lerr;
|
||||
Lexer::lerr_t lerr;
|
||||
|
||||
pp_err_t();
|
||||
pp_err_t(pp_err_type_t);
|
||||
pp_err_t(pp_err_type_t, const Token *);
|
||||
pp_err_t(pp_err_type_t, const Token *, lerr_t);
|
||||
pp_err_t(pp_err_type_t, const Lexer::Token *);
|
||||
pp_err_t(pp_err_type_t, const Lexer::Token *, Lexer::lerr_t);
|
||||
};
|
||||
|
||||
std::ostream &operator<<(std::ostream &, pp_err_t &);
|
||||
|
||||
struct pp_unit_t
|
||||
{
|
||||
const Token *const token;
|
||||
const Lexer::Token *const token;
|
||||
struct
|
||||
{
|
||||
std::string_view name;
|
||||
std::vector<pp_unit_t> elements;
|
||||
} container;
|
||||
|
||||
pp_unit_t(const Token *const);
|
||||
pp_unit_t(const Lexer::Token *const);
|
||||
pp_unit_t(std::string_view, std::vector<pp_unit_t>);
|
||||
};
|
||||
|
||||
std::vector<pp_unit_t> tokens_to_units(const std::vector<Token *> &);
|
||||
std::vector<pp_unit_t> tokens_to_units(const std::vector<Lexer::Token *> &);
|
||||
pp_err_t preprocess_use(std::vector<pp_unit_t> &);
|
||||
pp_err_t preprocesser(const std::vector<Token *> &, std::vector<Token *> &);
|
||||
pp_err_t preprocesser(const std::vector<Lexer::Token *> &,
|
||||
std::vector<Lexer::Token *> &);
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user