aboutsummaryrefslogtreecommitdiff
path: root/src/check_builtin.cpp
diff options
context:
space:
mode:
authorblob1807 <12388588+blob1807@users.noreply.github.com>2024-03-01 14:24:51 +1000
committerGitHub <noreply@github.com>2024-03-01 14:24:51 +1000
commitf14babe419bc8c13252cca770a1b244b2e14dd8b (patch)
treedc1c90fb20d0bbb743d94276a00506202e61e095 /src/check_builtin.cpp
parenta95cead8e7dfb747cc5afa58dc8f1a76966d035b (diff)
parent3263e54144a13714b055307ab0d6ab597eacbddb (diff)
Merge branch 'odin-lang:master' into json-better-enum-support
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 d39be37a9..c85fb28d6 100644
--- a/src/check_builtin.cpp
+++ b/src/check_builtin.cpp
@@ -5820,6 +5820,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 = {};