summaryrefslogtreecommitdiff
path: root/src/gas_assembly_generator.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/gas_assembly_generator.c')
-rw-r--r--src/gas_assembly_generator.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/src/gas_assembly_generator.c b/src/gas_assembly_generator.c
index d9feedb..0cce205 100644
--- a/src/gas_assembly_generator.c
+++ b/src/gas_assembly_generator.c
@@ -42,6 +42,9 @@ gas_assembly_generator_compile_variable_assignment(gas_assembly_generator_t *gen
ast_variable_assignment_t *variable_assignment);
static void
+gas_assembly_generator_compile_block(gas_assembly_generator_t *gen, ast_block_t *block);
+
+static void
gas_assembly_generator_compile_variable(gas_assembly_generator_t *gen, ast_variable_t *variable);
static void
@@ -132,6 +135,9 @@ gas_assembly_generator_compile(gas_assembly_generator_t *gen, ast_node_t *ast)
case AST_VARIABLE:
gas_assembly_generator_compile_variable(gen, &ast->data.variable);
break;
+ case AST_BLOCK:
+ gas_assembly_generator_compile_block(gen, &ast->data.block);
+ break;
case AST_UNKOWN_NODE:
assert(false && "unreachable");
}
@@ -153,9 +159,7 @@ gas_assembly_generator_compile_function(gas_assembly_generator_t *gen, ast_funct
fprintf(gen->stream, " push %%rbp\n");
fprintf(gen->stream, " mov %%rsp, %%rbp\n");
- for (size_t i = 0; i < func->body->size; i++) {
- gas_assembly_generator_compile(gen, vector_at(func->body, i));
- }
+ gas_assembly_generator_compile(gen, func->body);
fprintf(gen->stream, " pop %%rbp\n");
}
@@ -258,6 +262,14 @@ gas_assembly_generator_compile_literal(gas_assembly_generator_t *gen, ast_litera
}
static void
+gas_assembly_generator_compile_block(gas_assembly_generator_t *gen, ast_block_t *block)
+{
+ for (size_t i = 0; i < block->body->size; i++) {
+ gas_assembly_generator_compile(gen, vector_at(block->body, i));
+ }
+}
+
+static void
gas_assembly_generator_binary_operation(gas_assembly_generator_t *gen, ast_binary_operation_t *binary_operation)
{
gas_assembly_generator_compile(gen, binary_operation->right);