package mem Raw_Any :: struct { data: rawptr, id: typeid, } Raw_String :: struct { data: ^byte, len: int, } Raw_Cstring :: struct { data: ^byte, } Raw_Slice :: struct { data: rawptr, len: int, } Raw_Dynamic_Array :: struct { data: rawptr, len: int, cap: int, allocator: Allocator, } Raw_Map :: struct { hashes: []int, entries: Raw_Dynamic_Array, } Raw_Complex64 :: struct {real, imag: f32} Raw_Complex128 :: struct {real, imag: f64} Raw_Quaternion128 :: struct {imag, jmag, kmag: f32, real: f32} Raw_Quaternion256 :: struct {imag, jmag, kmag: f64, real: f64} Raw_Quaternion128_Vector_Scalar :: struct {vector: [3]f32, scalar: f32} Raw_Quaternion256_Vector_Scalar :: struct {vector: [3]f64, scalar: f64} make_any :: proc "contextless" (data: rawptr, id: typeid) -> any { return transmute(any)Raw_Any{data, id} } raw_array_data :: proc "contextless" (a: $P/^($T/[$N]$E)) -> ^E { return (^E)(a) } raw_string_data :: proc "contextless" (s: $T/string) -> ^byte { return (transmute(Raw_String)s).data } raw_slice_data :: proc "contextless" (a: $T/[]$E) -> ^E { return cast(^E)(transmute(Raw_Slice)a).data } raw_dynamic_array_data :: proc "contextless" (a: $T/[dynamic]$E) -> ^E { return cast(^E)(transmute(Raw_Dynamic_Array)a).data } raw_data :: proc{raw_array_data, raw_string_data, raw_slice_data, raw_dynamic_array_data} Poly_Raw_Map_Entry :: struct($Key, $Value: typeid) { hash: uintptr, next: int, key: Key, value: Value, } Poly_Raw_Map :: struct($Key, $Value: typeid) { hashes: []int, entries: [dynamic]Poly_Raw_Map_Entry(Key, Value), }