implemented array subscript parsing
This commit is contained in:
parent
403b2b7161
commit
c566f7d490
4 changed files with 25 additions and 4 deletions
5
lc.c
5
lc.c
|
|
@ -77,6 +77,11 @@ void print_ast(ast_node *node, int depth) {
|
||||||
print_ast(node->expr.binary.left, depth + 1);
|
print_ast(node->expr.binary.left, depth + 1);
|
||||||
print_ast(node->expr.binary.right, depth + 1);
|
print_ast(node->expr.binary.right, depth + 1);
|
||||||
break;
|
break;
|
||||||
|
case NODE_ARRAY_SUBSCRIPT:
|
||||||
|
printf("Array subscript\n");
|
||||||
|
print_ast(node->expr.subscript.expr, depth + 1);
|
||||||
|
print_ast(node->expr.subscript.index, depth + 1);
|
||||||
|
break;
|
||||||
case NODE_UNARY:
|
case NODE_UNARY:
|
||||||
printf("UnaryOp (%s)\n", get_uop_str(node->expr.unary.operator));
|
printf("UnaryOp (%s)\n", get_uop_str(node->expr.unary.operator));
|
||||||
print_ast(node->expr.unary.right, depth + 1);
|
print_ast(node->expr.unary.right, depth + 1);
|
||||||
|
|
|
||||||
14
parser.c
14
parser.c
|
|
@ -233,6 +233,20 @@ ast_node *parse_expression(parser *p)
|
||||||
left = node;
|
left = node;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (match(p, TOKEN_LSQUARE)) {
|
||||||
|
ast_node *index = parse_expression(p);
|
||||||
|
ast_node *node = arena_alloc(p->allocator, sizeof(ast_node));
|
||||||
|
node->type = NODE_ARRAY_SUBSCRIPT;
|
||||||
|
node->expr.subscript.expr = left;
|
||||||
|
node->expr.subscript.index = index;
|
||||||
|
|
||||||
|
if (!match(p, TOKEN_RSQUARE)) {
|
||||||
|
error(p, "expected `]`.");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
return left;
|
return left;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
8
parser.h
8
parser.h
|
|
@ -67,11 +67,9 @@ typedef enum {
|
||||||
NODE_FLOAT,
|
NODE_FLOAT,
|
||||||
NODE_STRING,
|
NODE_STRING,
|
||||||
NODE_CHAR,
|
NODE_CHAR,
|
||||||
NODE_TERNARY,
|
|
||||||
NODE_CAST,
|
NODE_CAST,
|
||||||
NODE_ARRAY_SUBSCRIPT,
|
NODE_ARRAY_SUBSCRIPT,
|
||||||
NODE_ACCESS,
|
NODE_ACCESS,
|
||||||
NODE_ACCESS_PTR,
|
|
||||||
NODE_CALL,
|
NODE_CALL,
|
||||||
NODE_POSTFIX,
|
NODE_POSTFIX,
|
||||||
NODE_UNARY,
|
NODE_UNARY,
|
||||||
|
|
@ -93,8 +91,8 @@ typedef enum {
|
||||||
NODE_VAR_DECL,
|
NODE_VAR_DECL,
|
||||||
NODE_FUNCTION_DEF,
|
NODE_FUNCTION_DEF,
|
||||||
NODE_FUNCTION_DECL,
|
NODE_FUNCTION_DECL,
|
||||||
|
NODE_TERNARY,
|
||||||
NODE_UNIT,
|
NODE_UNIT,
|
||||||
NODE_AS,
|
|
||||||
} node_type;
|
} node_type;
|
||||||
|
|
||||||
typedef struct _ast_node {
|
typedef struct _ast_node {
|
||||||
|
|
@ -126,6 +124,10 @@ typedef struct _ast_node {
|
||||||
char *type;
|
char *type;
|
||||||
usize type_len;
|
usize type_len;
|
||||||
} cast;
|
} cast;
|
||||||
|
struct {
|
||||||
|
struct _ast_node *expr;
|
||||||
|
struct _ast_node *index;
|
||||||
|
} subscript;
|
||||||
struct {
|
struct {
|
||||||
struct _ast_node *expr;
|
struct _ast_node *expr;
|
||||||
struct _ast_node *next;
|
struct _ast_node *next;
|
||||||
|
|
|
||||||
2
test.c
2
test.c
|
|
@ -1 +1 @@
|
||||||
(u64) x
|
x[4
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue