diff options
| author | jockus <joakim.hentula@gmail.com> | 2020-08-27 08:24:59 +0100 |
|---|---|---|
| committer | jockus <joakim.hentula@gmail.com> | 2020-08-27 08:24:59 +0100 |
| commit | 914c99a15edf325399fb758605b80fe31d5f4813 (patch) | |
| tree | ce86f022b368fb42a61041e01051c80765b86d64 /src/parser.cpp | |
| parent | 8de70ce73dd3fc9740a0589e6167d950d02f244d (diff) | |
| parent | d31c63c0ae76115d1b9aa8b5d1f8bf7130e74977 (diff) | |
Merge branch 'master' into fix-core-path-name-extension
Diffstat (limited to 'src/parser.cpp')
| -rw-r--r-- | src/parser.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/parser.cpp b/src/parser.cpp index 7d794a898..702ef6605 100644 --- a/src/parser.cpp +++ b/src/parser.cpp @@ -3127,6 +3127,7 @@ u32 parse_field_prefixes(AstFile *f) { i32 no_alias_count = 0; i32 c_vararg_count = 0; i32 auto_cast_count = 0; + i32 const_count = 0; for (;;) { FieldPrefixKind kind = is_token_field_prefix(f); @@ -3144,12 +3145,14 @@ u32 parse_field_prefixes(AstFile *f) { case FieldPrefix_no_alias: no_alias_count += 1; advance_token(f); break; case FieldPrefix_c_var_arg: c_vararg_count += 1; advance_token(f); break; case FieldPrefix_auto_cast: auto_cast_count += 1; advance_token(f); break; + case FieldPrefix_const: const_count += 1; advance_token(f); break; } } if (using_count > 1) syntax_error(f->curr_token, "Multiple 'using' in this field list"); if (no_alias_count > 1) syntax_error(f->curr_token, "Multiple '#no_alias' in this field list"); if (c_vararg_count > 1) syntax_error(f->curr_token, "Multiple '#c_vararg' in this field list"); if (auto_cast_count > 1) syntax_error(f->curr_token, "Multiple 'auto_cast' in this field list"); + if (const_count > 1) syntax_error(f->curr_token, "Multiple '#const' in this field list"); u32 field_flags = 0; @@ -3157,6 +3160,7 @@ u32 parse_field_prefixes(AstFile *f) { if (no_alias_count > 0) field_flags |= FieldFlag_no_alias; if (c_vararg_count > 0) field_flags |= FieldFlag_c_vararg; if (auto_cast_count > 0) field_flags |= FieldFlag_auto_cast; + if (const_count > 0) field_flags |= FieldFlag_const; return field_flags; } |