aboutsummaryrefslogtreecommitdiff
path: root/src/checker.cpp
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2022-11-17 15:29:28 +0000
committerGitHub <noreply@github.com>2022-11-17 15:29:28 +0000
commit15bbdb2030510b9d15918536c7da8af3a376c0be (patch)
tree60210e6a4ea6d6a34f286f1f4770e4f6fbd2737d /src/checker.cpp
parent48c9c1682c347adb7e743a6a6f8c70f08420c197 (diff)
parent3949e2220feca6c718a27ecc0fd5cb1cde56f7b7 (diff)
Merge pull request #2181 from odin-lang/map-dev
New `map` internals
Diffstat (limited to 'src/checker.cpp')
-rw-r--r--src/checker.cpp28
1 files changed, 19 insertions, 9 deletions
diff --git a/src/checker.cpp b/src/checker.cpp
index dd81e2a48..4d1ef4614 100644
--- a/src/checker.cpp
+++ b/src/checker.cpp
@@ -922,10 +922,13 @@ void init_universal(void) {
{
Type *equal_args[2] = {t_rawptr, t_rawptr};
- t_equal_proc = alloc_type_proc_from_types(equal_args, 2, t_bool, false, ProcCC_Contextless);
+ t_equal_proc = alloc_type_proc_from_types(equal_args, gb_count_of(equal_args), t_bool, false, ProcCC_Contextless);
Type *hasher_args[2] = {t_rawptr, t_uintptr};
- t_hasher_proc = alloc_type_proc_from_types(hasher_args, 2, t_uintptr, false, ProcCC_Contextless);
+ t_hasher_proc = alloc_type_proc_from_types(hasher_args, gb_count_of(hasher_args), t_uintptr, false, ProcCC_Contextless);
+
+ Type *map_get_args[3] = {/*map*/t_rawptr, /*hash*/t_uintptr, /*key*/t_rawptr};
+ t_map_get_proc = alloc_type_proc_from_types(map_get_args, gb_count_of(map_get_args), t_rawptr, false, ProcCC_Contextless);
}
// Constants
@@ -1933,7 +1936,8 @@ void add_type_info_type_internal(CheckerContext *c, Type *t) {
init_map_internal_types(bt);
add_type_info_type_internal(c, bt->Map.key);
add_type_info_type_internal(c, bt->Map.value);
- add_type_info_type_internal(c, bt->Map.internal_type);
+ add_type_info_type_internal(c, t_uintptr); // hash value
+ add_type_info_type_internal(c, t_allocator);
break;
case Type_Tuple:
@@ -2155,7 +2159,8 @@ void add_min_dep_type_info(Checker *c, Type *t) {
init_map_internal_types(bt);
add_min_dep_type_info(c, bt->Map.key);
add_min_dep_type_info(c, bt->Map.value);
- add_min_dep_type_info(c, bt->Map.internal_type);
+ add_min_dep_type_info(c, t_uintptr); // hash value
+ add_min_dep_type_info(c, t_allocator);
break;
case Type_Tuple:
@@ -2838,16 +2843,21 @@ void init_core_source_code_location(Checker *c) {
return;
}
t_source_code_location = find_core_type(c, str_lit("Source_Code_Location"));
- t_source_code_location_ptr = alloc_type_pointer(t_allocator);
+ t_source_code_location_ptr = alloc_type_pointer(t_source_code_location);
}
void init_core_map_type(Checker *c) {
- if (t_map_hash != nullptr) {
+ if (t_map_info != nullptr) {
return;
}
- t_map_hash = find_core_type(c, str_lit("Map_Hash"));
- t_map_header = find_core_type(c, str_lit("Map_Header"));
- t_map_header_table = find_core_type(c, str_lit("Map_Header_Table"));
+ init_mem_allocator(c);
+ t_map_info = find_core_type(c, str_lit("Map_Info"));
+ t_map_cell_info = find_core_type(c, str_lit("Map_Cell_Info"));
+ t_raw_map = find_core_type(c, str_lit("Raw_Map"));
+
+ t_map_info_ptr = alloc_type_pointer(t_map_info);
+ t_map_cell_info_ptr = alloc_type_pointer(t_map_cell_info);
+ t_raw_map_ptr = alloc_type_pointer(t_raw_map);
}
void init_preload(Checker *c) {