commit 079ed9e3569b60f45f5a0362a67c1d3a8b2d3665 (tree)
parent a600df073a9d1d1ebc166fb02582836f597a7f8f
Author: Andrew Kelley <superjoe30@gmail.com>
Date: Wed, 25 Nov 2015 15:40:05 -0700
parser: more AST printing code for debug purposes
Diffstat:
1 file changed, 24 insertions(+), 0 deletions(-)
diff --git a/src/parser.cpp b/src/parser.cpp
@@ -150,6 +150,30 @@ void ast_print(AstNode *node, int indent) {
fprintf(stderr, "%s\n", node_type_str(node->type));
ast_print(node->data.fn_decl.fn_proto, indent + 2);
break;
+ case NodeTypeExpression:
+ switch (node->data.expression.type) {
+ case AstNodeExpressionTypeNumber:
+ fprintf(stderr, "NumberLiteralExpression %s\n", buf_ptr(&node->data.expression.data.number));
+ break;
+ case AstNodeExpressionTypeString:
+ fprintf(stderr, "StringLiteralExpression '%s'\n", buf_ptr(&node->data.expression.data.string));
+ break;
+ case AstNodeExpressionTypeFnCall:
+ fprintf(stderr, "FnCallExpression\n");
+ ast_print(node->data.expression.data.fn_call, indent + 2);
+ break;
+ case AstNodeExpressionTypeUnreachable:
+ fprintf(stderr, "UnreachableExpression\n");
+ break;
+ }
+ break;
+ case NodeTypeFnCall:
+ fprintf(stderr, "%s '%s'\n", node_type_str(node->type), buf_ptr(&node->data.fn_call.name));
+ for (int i = 0; i < node->data.fn_call.params.length; i += 1) {
+ AstNode *child = node->data.fn_call.params.at(i);
+ ast_print(child, indent + 2);
+ }
+ break;
default:
fprintf(stderr, "%s\n", node_type_str(node->type));
break;