aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2024-08-17 00:22:46 +0100
committerGitHub <noreply@github.com>2024-08-17 00:22:46 +0100
commit536a34287311ee8a6e9c69c0b8d93b1ba5779b4e (patch)
treec11b489b30146391e5574ffbaf5ff1bb4359cac7 /src
parente8933e43ecffe1a0cec81e102f077970687a43a2 (diff)
parentf7d7d65bc0f7da6993e117e67e771c7e1741ea06 (diff)
Merge pull request #4092 from laytan/fix-open-bindings
fix `open` bindings
Diffstat (limited to 'src')
-rw-r--r--src/check_decl.cpp15
1 files changed, 15 insertions, 0 deletions
diff --git a/src/check_decl.cpp b/src/check_decl.cpp
index 090b7f615..c60084ec3 100644
--- a/src/check_decl.cpp
+++ b/src/check_decl.cpp
@@ -691,6 +691,13 @@ gb_internal bool sig_compare(TypeCheckSig *a, TypeCheckSig *b, Type *x, Type *y)
}
gb_internal bool signature_parameter_similar_enough(Type *x, Type *y) {
+ if (is_type_bit_set(x)) {
+ x = bit_set_to_int(x);
+ }
+ if (is_type_bit_set(y)) {
+ y = bit_set_to_int(y);
+ }
+
if (sig_compare(is_type_pointer, x, y)) {
return true;
}
@@ -737,6 +744,14 @@ gb_internal bool signature_parameter_similar_enough(Type *x, Type *y) {
return true;
}
+ if (sig_compare(is_type_slice, x, y)) {
+ Type *s1 = core_type(x);
+ Type *s2 = core_type(y);
+ if (signature_parameter_similar_enough(s1->Slice.elem, s2->Slice.elem)) {
+ return true;
+ }
+ }
+
return are_types_identical(x, y);
}