aboutsummaryrefslogtreecommitdiff
path: root/src/check_expr.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-11-29 14:22:42 +0000
committergingerBill <bill@gingerbill.org>2020-11-29 14:22:42 +0000
commit39bed567b34a4bd74f7dfa99dd1ddb4621f67190 (patch)
treefae939ebcf343170a3d57f0ee147f7f91c224311 /src/check_expr.cpp
parent2e0fd34e59218ea942e4a378b689dc7cd3f844fa (diff)
Add intrinsics.type_equal_proc; Make `map` use an internal equal procedure to compare keys
Diffstat (limited to 'src/check_expr.cpp')
-rw-r--r--src/check_expr.cpp21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index 4b17b4f27..e2a6089b9 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -6060,6 +6060,27 @@ bool check_builtin_procedure(CheckerContext *c, Operand *operand, Ast *call, i32
break;
}
break;
+
+ case BuiltinProc_type_equal_proc:
+ {
+ Operand op = {};
+ Type *bt = check_type(c, ce->args[0]);
+ Type *type = base_type(bt);
+ if (type == nullptr || type == t_invalid) {
+ error(ce->args[0], "Expected a type for '%.*s'", LIT(builtin_name));
+ return false;
+ }
+ if (!is_type_comparable(type)) {
+ gbString t = type_to_string(type);
+ error(ce->args[0], "Expected a comparable type for '%.*s', got %s", LIT(builtin_name), t);
+ gb_string_free(t);
+ return false;
+ }
+
+ operand->mode = Addressing_Value;
+ operand->type = t_equal_proc;
+ break;
+ }
}
return true;