aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2022-11-13 23:24:08 +0000
committergingerBill <bill@gingerbill.org>2022-11-13 23:24:08 +0000
commit3edb3d8d8c16a24371bb401fe0d69ec93e667b27 (patch)
tree86ff2bafa1ac5a726f5f455730462b407b9659df /src
parenta705a2e38bee035d6800999ba6eddd82792594f7 (diff)
Simplify the handling of the hashing calls for `map`s
Diffstat (limited to 'src')
-rw-r--r--src/check_type.cpp20
-rw-r--r--src/llvm_backend.cpp14
2 files changed, 7 insertions, 27 deletions
diff --git a/src/check_type.cpp b/src/check_type.cpp
index 5d7f8d7b5..4d94fce6c 100644
--- a/src/check_type.cpp
+++ b/src/check_type.cpp
@@ -2221,35 +2221,27 @@ void add_map_key_type_dependencies(CheckerContext *ctx, Type *key) {
}
if (is_type_simple_compare(key)) {
- i64 sz = type_size_of(key);
- if (1 <= sz && sz <= 16) {
- char buf[20] = {};
- gb_snprintf(buf, 20, "default_hasher%d", cast(i32)sz);
- add_package_dependency(ctx, "runtime", buf);
- return;
- } else {
- add_package_dependency(ctx, "runtime", "default_hasher_n");
- return;
- }
+ add_package_dependency(ctx, "runtime", "default_hasher");
+ return;
}
if (key->kind == Type_Struct) {
- add_package_dependency(ctx, "runtime", "default_hasher_n");
+ add_package_dependency(ctx, "runtime", "default_hasher");
for_array(i, key->Struct.fields) {
Entity *field = key->Struct.fields[i];
add_map_key_type_dependencies(ctx, field->type);
}
} else if (key->kind == Type_Union) {
- add_package_dependency(ctx, "runtime", "default_hasher_n");
+ add_package_dependency(ctx, "runtime", "default_hasher");
for_array(i, key->Union.variants) {
Type *v = key->Union.variants[i];
add_map_key_type_dependencies(ctx, v);
}
} else if (key->kind == Type_EnumeratedArray) {
- add_package_dependency(ctx, "runtime", "default_hasher_n");
+ add_package_dependency(ctx, "runtime", "default_hasher");
add_map_key_type_dependencies(ctx, key->EnumeratedArray.elem);
} else if (key->kind == Type_Array) {
- add_package_dependency(ctx, "runtime", "default_hasher_n");
+ add_package_dependency(ctx, "runtime", "default_hasher");
add_map_key_type_dependencies(ctx, key->Array.elem);
}
}
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 5b9db7f2b..2ee292880 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -282,23 +282,11 @@ lbValue lb_equal_proc_for_type(lbModule *m, Type *type) {
lbValue lb_simple_compare_hash(lbProcedure *p, Type *type, lbValue data, lbValue seed) {
GB_ASSERT_MSG(is_type_simple_compare(type), "%s", type_to_string(type));
- i64 sz = type_size_of(type);
-
- if (1 <= sz && sz <= 16) {
- char name[32] = {};
- gb_snprintf(name, 32, "default_hasher%d", cast(i32)sz);
-
- auto args = array_make<lbValue>(permanent_allocator(), 2);
- args[0] = data;
- args[1] = seed;
- return lb_emit_runtime_call(p, name, args);
- }
-
auto args = array_make<lbValue>(permanent_allocator(), 3);
args[0] = data;
args[1] = seed;
args[2] = lb_const_int(p->module, t_int, type_size_of(type));
- return lb_emit_runtime_call(p, "default_hasher_n", args);
+ return lb_emit_runtime_call(p, "default_hasher", args);
}
void lb_add_callsite_force_inline(lbProcedure *p, lbValue ret_value) {