aboutsummaryrefslogtreecommitdiff
path: root/src/check_builtin.cpp
diff options
context:
space:
mode:
authoravanspector <avanspector@gmail.com>2024-02-25 02:24:58 +0100
committeravanspector <avanspector@gmail.com>2024-02-25 02:24:58 +0100
commit0a6673220bd50c05f8c5c5bd34e79b8f676152e2 (patch)
treedfe13c71ddfe9d654420658a9f23c1c318a5c11d /src/check_builtin.cpp
parent88add0b6b12b6590fd69bb74182f1a7689ae9ff6 (diff)
parenta642ea0b28f8b1edad247b484ae000f20218347d (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.cpp20
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 = {};