diff options
| author | avanspector <avanspector@gmail.com> | 2024-02-25 02:24:58 +0100 |
|---|---|---|
| committer | avanspector <avanspector@gmail.com> | 2024-02-25 02:24:58 +0100 |
| commit | 0a6673220bd50c05f8c5c5bd34e79b8f676152e2 (patch) | |
| tree | dfe13c71ddfe9d654420658a9f23c1c318a5c11d /src/check_builtin.cpp | |
| parent | 88add0b6b12b6590fd69bb74182f1a7689ae9ff6 (diff) | |
| parent | a642ea0b28f8b1edad247b484ae000f20218347d (diff) | |
Merge branch 'haiku' of https://github.com/avanspector/Odin into haiku
Diffstat (limited to 'src/check_builtin.cpp')
| -rw-r--r-- | src/check_builtin.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/check_builtin.cpp b/src/check_builtin.cpp index e00f6c053..e1b1cd693 100644 --- a/src/check_builtin.cpp +++ b/src/check_builtin.cpp @@ -5821,6 +5821,26 @@ gb_internal bool check_builtin_procedure(CheckerContext *c, Operand *operand, As } break; + case BuiltinProc_type_bit_set_backing_type: + { + Operand op = {}; + Type *type = check_type(c, ce->args[0]); + Type *bt = base_type(type); + if (bt == nullptr || bt == t_invalid) { + error(ce->args[0], "Expected a type for '%.*s'", LIT(builtin_name)); + return false; + } + if (bt->kind != Type_BitSet) { + gbString s = type_to_string(type); + error(ce->args[0], "Expected a bit_set type for '%.*s', got %s", LIT(builtin_name), s); + return false; + } + + operand->mode = Addressing_Type; + operand->type = bit_set_to_int(bt); + break; + } + case BuiltinProc_type_equal_proc: { Operand op = {}; |