summaryrefslogtreecommitdiff
path: root/src/ast.c
diff options
context:
space:
mode:
authorJohnny Richard <johnny@johnnyrichard.com>2023-04-18 07:13:55 +0200
committerCarlos Maniero <carlosmaniero@gmail.com>2023-04-18 09:54:50 -0300
commite3761429de464c42cc2798dc858bf6b43883d9dc (patch)
tree7a0d37205db4aadc6fc079c5474cb3d36fd25328 /src/ast.c
parentbf2bbaf31487a3935f1a27dc51886d6f53c3d73d (diff)
ast: Create AST visitor to traverse the tree
In the future we want to have the possibility of traverse the tree and pretty print it or generate binary for other platform like LLVM or transpile to C. This solution also implements the gas assembly x86_64 Linux code generation by using the visitor interface. Signed-off-by: Johnny Richard <johnny@johnnyrichard.com>
Diffstat (limited to 'src/ast.c')
-rw-r--r--src/ast.c63
1 files changed, 63 insertions, 0 deletions
diff --git a/src/ast.c b/src/ast.c
new file mode 100644
index 0000000..f8c2713
--- /dev/null
+++ b/src/ast.c
@@ -0,0 +1,63 @@
+/*
+* Copyright (C) 2023 Johnny Richard
+*
+* This program is free software: you can redistribute it and/or modify
+* it under the terms of the GNU General Public License as published by
+* the Free Software Foundation, either version 3 of the License, or
+* (at your option) any later version.
+*
+* This program is distributed in the hope that it will be useful,
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+* GNU General Public License for more details.
+*
+* You should have received a copy of the GNU General Public License
+* along with this program. If not, see <https://www.gnu.org/licenses/>.
+*/
+#include <assert.h>
+#include "ast.h"
+
+void
+ast_node_accept_visitor(ast_node_t *node, ast_visitor_t *visitor)
+{
+ assert(node);
+ assert(node->accept_visitor);
+ node->accept_visitor(node, visitor);
+}
+
+static void
+ast_function_accept_visitor(ast_node_t *node, ast_visitor_t *visitor)
+{
+ visitor->visit_function(visitor, (ast_function_t *) node);
+}
+
+static void
+ast_return_stmt_accept_visitor(ast_node_t *node, ast_visitor_t *visitor)
+{
+ visitor->visit_return_stmt(visitor, (ast_return_stmt_t *) node);
+}
+
+ast_return_stmt_t
+ast_return_stmt_create(uint32_t number)
+{
+ return (ast_return_stmt_t) {
+ .super = (ast_node_t) {
+ .accept_visitor = &ast_return_stmt_accept_visitor
+ },
+ .number = number
+ };
+}
+
+ast_function_t
+ast_function_create(string_view_t name, type_t return_type, ast_return_stmt_t body)
+{
+ return (ast_function_t) {
+ .super = (ast_node_t) {
+ .accept_visitor = &ast_function_accept_visitor
+ },
+ .name = name,
+ .return_type = return_type,
+ .body = body
+ };
+}
+