diff options
| author | gingerBill <gingerBill@users.noreply.github.com> | 2024-08-17 00:22:46 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-08-17 00:22:46 +0100 |
| commit | 536a34287311ee8a6e9c69c0b8d93b1ba5779b4e (patch) | |
| tree | c11b489b30146391e5574ffbaf5ff1bb4359cac7 /src/check_decl.cpp | |
| parent | e8933e43ecffe1a0cec81e102f077970687a43a2 (diff) | |
| parent | f7d7d65bc0f7da6993e117e67e771c7e1741ea06 (diff) | |
Merge pull request #4092 from laytan/fix-open-bindings
fix `open` bindings
Diffstat (limited to 'src/check_decl.cpp')
| -rw-r--r-- | src/check_decl.cpp | 15 |
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); } |