aboutsummaryrefslogtreecommitdiff
path: root/core/runtime
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2021-08-22 12:54:04 +0100
committergingerBill <bill@gingerbill.org>2021-08-22 12:54:04 +0100
commit445ed9be2b526de355d7fac550747b25c8fd7f20 (patch)
tree2196b5c25f947a322752ae42e971b1d771353cb0 /core/runtime
parent8694a0f68a2b5c18ea19e1b8a526aacfd51fc85b (diff)
Use multi-pointers when appropriate
Diffstat (limited to 'core/runtime')
-rw-r--r--core/runtime/core_builtin.odin8
1 files changed, 4 insertions, 4 deletions
diff --git a/core/runtime/core_builtin.odin b/core/runtime/core_builtin.odin
index f4dc6aebe..0fc72fd69 100644
--- a/core/runtime/core_builtin.odin
+++ b/core/runtime/core_builtin.odin
@@ -303,9 +303,9 @@ append_elem :: proc(array: ^$T/[dynamic]$E, arg: E, loc := #caller_location) {
if cap(array)-len(array) > 0 {
a := (^Raw_Dynamic_Array)(array);
when size_of(E) != 0 {
- data := (^E)(a.data);
+ data := ([^]E)(a.data);
assert(condition=data != nil, loc=loc);
- intrinsics.ptr_offset(data, a.len)^ = arg;
+ data[a.len] = arg;
}
a.len += 1;
}
@@ -331,9 +331,9 @@ append_elems :: proc(array: ^$T/[dynamic]$E, args: ..E, loc := #caller_location)
if arg_len > 0 {
a := (^Raw_Dynamic_Array)(array);
when size_of(E) != 0 {
- data := (^E)(a.data);
+ data := ([^]E)(a.data);
assert(condition=data != nil, loc=loc);
- intrinsics.mem_copy(intrinsics.ptr_offset(data, a.len), &args[0], size_of(E) * arg_len);
+ intrinsics.mem_copy(&data[a.len], raw_data(args), size_of(E) * arg_len);
}
a.len += arg_len;
}