diff options
| author | gingerBill <bill@gingerbill.org> | 2019-11-17 10:30:37 -0800 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2019-11-17 10:30:37 -0800 |
| commit | d22e5b697db24e943d2500e69cc98acda63434e3 (patch) | |
| tree | 4550d2c67922cfe3473d9b2f2619ca8a828728de /src/parser.cpp | |
| parent | 301ee664e9f10bb47993b9ccf395628606052a64 (diff) | |
Add new #soa and #vector syntax
Diffstat (limited to 'src/parser.cpp')
| -rw-r--r-- | src/parser.cpp | 11 |
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)); } |