aboutsummaryrefslogtreecommitdiff
path: root/src/parser.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2019-11-17 10:30:37 -0800
committergingerBill <bill@gingerbill.org>2019-11-17 10:30:37 -0800
commitd22e5b697db24e943d2500e69cc98acda63434e3 (patch)
tree4550d2c67922cfe3473d9b2f2619ca8a828728de /src/parser.cpp
parent301ee664e9f10bb47993b9ccf395628606052a64 (diff)
Add new #soa and #vector syntax
Diffstat (limited to 'src/parser.cpp')
-rw-r--r--src/parser.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/parser.cpp b/src/parser.cpp
index 95a0895d6..732c366ee 100644
--- a/src/parser.cpp
+++ b/src/parser.cpp
@@ -1758,6 +1758,17 @@ Ast *parse_operand(AstFile *f, bool lhs) {
} else if (name.string == "defined") {
Ast *tag = ast_basic_directive(f, token, name.string);
return parse_call_expr(f, tag);
+ } else if (name.string == "soa" || name.string == "vector") {
+ Ast *tag = ast_basic_directive(f, token, name.string);
+ Ast *type = parse_type(f);
+ switch (type->kind) {
+ case Ast_ArrayType: type->ArrayType.tag = tag; break;
+ case Ast_DynamicArrayType: type->DynamicArrayType.tag = tag; break;
+ default:
+ syntax_error(type, "Expected an array type after #%.*s, got %.*s", LIT(name.string), LIT(ast_strings[type->kind]));
+ break;
+ }
+ return type;
} else {
operand = ast_tag_expr(f, token, name, parse_expr(f, false));
}