Compare commits
28 Commits
0177d86054
...
297ad863c3
Author | SHA1 | Date | |
---|---|---|---|
297ad863c3 | |||
28dffa4cb5 | |||
0169455fc2 | |||
0ec3d0fa35 | |||
69571b344b | |||
ae2556ac9e | |||
4dc3ef8967 | |||
449cffe79f | |||
6794799b5f | |||
a22cfb436e | |||
f3894211e0 | |||
836a0550d9 | |||
249f0190d8 | |||
a09d591e86 | |||
f4638d43b6 | |||
fcbf96af48 | |||
94ac826cde | |||
5d28c51cf1 | |||
89c7bb5253 | |||
69e1cb840c | |||
ea5df2d129 | |||
81be56de33 | |||
ec7d06b135 | |||
3ff53f923d | |||
4c7555dfd8 | |||
68a41d035d | |||
4e1186a305 | |||
34ace36920 |
@ -34,7 +34,7 @@ parse_result_t parse_section_directive(tokenlist_entry_t *current) {
|
||||
|
||||
parse_result_t parse_directive(tokenlist_entry_t *current) {
|
||||
parser_t parsers[] = {parse_dot, parse_section_directive, nullptr};
|
||||
return parse_consecutive(current, NODE_LABEL, parsers);
|
||||
return parse_consecutive(current, NODE_DIRECTIVE, parsers);
|
||||
}
|
||||
|
||||
parse_result_t parse_instruction(tokenlist_entry_t *current) {
|
||||
|
@ -50,7 +50,8 @@ parse_result_t parse_list(tokenlist_entry_t *current, node_id_t id,
|
||||
}
|
||||
|
||||
parse_result_t parse_any(tokenlist_entry_t *current, parser_t parsers[]) {
|
||||
for (parser_t parser = *parsers; parser; parser = *parsers++) {
|
||||
parser_t parser;
|
||||
while ((parser = *parsers++)) {
|
||||
parse_result_t result = parser(current);
|
||||
if (result.err == nullptr)
|
||||
return result;
|
||||
@ -106,7 +107,8 @@ parse_result_t parse_consecutive(tokenlist_entry_t *current, node_id_t id,
|
||||
|
||||
all->id = id;
|
||||
|
||||
for (parser_t parser = *parsers; parser && current; parser = *parsers++) {
|
||||
parser_t parser;
|
||||
while ((parser = *parsers++) && current) {
|
||||
result = parser(current);
|
||||
if (result.err) {
|
||||
ast_node_free(all);
|
||||
|
@ -62,9 +62,19 @@ parse_result_t parse_dot(tokenlist_entry_t *current) {
|
||||
return parse_token(current, TOKEN_DOT, NODE_DOT, nullptr);
|
||||
}
|
||||
|
||||
const char *registers[] = {"rax", "rcx", "rdx", "rbx", "rsp", "rbp",
|
||||
"rsi", "rdi", "r8", "r9", "r10", "r11",
|
||||
"r12", "r13", "r14", "r15", nullptr};
|
||||
const char *registers[] = {
|
||||
// 64-bit registers
|
||||
"rax", "rcx", "rdx", "rbx", "rsp", "rbp", "rsi", "rdi", "r8", "r9", "r10",
|
||||
"r11", "r12", "r13", "r14", "r15",
|
||||
// 32-bit registers
|
||||
"eax", "ecx", "edx", "ebx", "esp", "ebp", "esi", "edi", "r8d", "r9d",
|
||||
"r10d", "r11d", "r12d", "r13d", "r14d", "r15d",
|
||||
// 16-bit registers
|
||||
"ax", "cx", "dx", "bx", "sp", "bp", "si", "di", "r8w", "r9w", "r10w",
|
||||
"r11w", "r12w", "r13w", "r14w", "r15w",
|
||||
// 8-bit low registers
|
||||
"al", "cl", "dl", "bl", "spl", "bpl", "sil", "dil", "r8b", "r9b", "r10b",
|
||||
"r11b", "r12b", "r13b", "r14b", "r15b", nullptr};
|
||||
bool is_register_token(lexer_token_t *token) {
|
||||
for (size_t i = 0; registers[i] != nullptr; ++i)
|
||||
if (strcmp(token->value, registers[i]) == 0)
|
||||
@ -81,4 +91,7 @@ bool is_section_token(lexer_token_t *token) {
|
||||
return strcmp(token->value, "section") == 0;
|
||||
}
|
||||
|
||||
parse_result_t parse_section(tokenlist_entry_t *current) {}
|
||||
parse_result_t parse_section(tokenlist_entry_t *current) {
|
||||
return parse_token(current, TOKEN_IDENTIFIER, NODE_SECTION,
|
||||
is_section_token);
|
||||
}
|
||||
|
@ -1,4 +1,7 @@
|
||||
.section text
|
||||
|
||||
_start:
|
||||
mov eax, ebx
|
||||
mov eax, 555 ; move 555 into eax
|
||||
push 0o777
|
||||
xor eax, 0xDEADBEEF
|
||||
|
Loading…
x
Reference in New Issue
Block a user