|
@@ -177,8 +177,70 @@ mem_resize :: #force_inline proc(ptr: rawptr, old_size, new_size: int, alignment
|
|
new_ptr = raw_data(new_data)
|
|
new_ptr = raw_data(new_data)
|
|
return
|
|
return
|
|
}
|
|
}
|
|
-memory_equal :: proc "contextless" (a, b: rawptr, n: int) -> bool {
|
|
|
|
- return memory_compare(a, b, n) == 0
|
|
|
|
|
|
+memory_equal :: proc "contextless" (x, y: rawptr, n: int) -> bool {
|
|
|
|
+ switch {
|
|
|
|
+ case n == 0: return true
|
|
|
|
+ case x == y: return true
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ a, b := ([^]byte)(x), ([^]byte)(y)
|
|
|
|
+ length := uint(n)
|
|
|
|
+
|
|
|
|
+ when size_of(uint) == 8 {
|
|
|
|
+ if word_length := length >> 3; word_length != 0 {
|
|
|
|
+ for i in 0..<word_length {
|
|
|
|
+ if intrinsics.unaligned_load((^u64)(a)) != intrinsics.unaligned_load((^u64)(b)) {
|
|
|
|
+ return false
|
|
|
|
+ }
|
|
|
|
+ a = a[size_of(u64):]
|
|
|
|
+ b = b[size_of(u64):]
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if length & 4 != 0 {
|
|
|
|
+ if intrinsics.unaligned_load((^u32)(a)) != intrinsics.unaligned_load((^u32)(b)) {
|
|
|
|
+ return false
|
|
|
|
+ }
|
|
|
|
+ a = a[size_of(u32):]
|
|
|
|
+ b = b[size_of(u32):]
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if length & 2 != 0 {
|
|
|
|
+ if intrinsics.unaligned_load((^u16)(a)) != intrinsics.unaligned_load((^u16)(b)) {
|
|
|
|
+ return false
|
|
|
|
+ }
|
|
|
|
+ a = a[size_of(u16):]
|
|
|
|
+ b = b[size_of(u16):]
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if length & 1 != 0 && a[0] != b[0] {
|
|
|
|
+ return false
|
|
|
|
+ }
|
|
|
|
+ return true
|
|
|
|
+ } else {
|
|
|
|
+ if word_length := length >> 2; word_length != 0 {
|
|
|
|
+ for i in 0..<word_length {
|
|
|
|
+ if intrinsics.unaligned_load((^u32)(a)) != intrinsics.unaligned_load((^u32)(b)) {
|
|
|
|
+ return false
|
|
|
|
+ }
|
|
|
|
+ a = a[size_of(u32):]
|
|
|
|
+ b = b[size_of(u32):]
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ length &= 3
|
|
|
|
+
|
|
|
|
+ if length != 0 {
|
|
|
|
+ for i in 0..<length {
|
|
|
|
+ if a[i] != b[i] {
|
|
|
|
+ return false
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return true
|
|
|
|
+ }
|
|
|
|
+
|
|
}
|
|
}
|
|
memory_compare :: proc "contextless" (a, b: rawptr, n: int) -> int #no_bounds_check {
|
|
memory_compare :: proc "contextless" (a, b: rawptr, n: int) -> int #no_bounds_check {
|
|
switch {
|
|
switch {
|
|
@@ -261,69 +323,10 @@ memory_compare_zero :: proc "contextless" (a: rawptr, n: int) -> int #no_bounds_
|
|
string_eq :: proc "contextless" (lhs, rhs: string) -> bool {
|
|
string_eq :: proc "contextless" (lhs, rhs: string) -> bool {
|
|
x := transmute(Raw_String)lhs
|
|
x := transmute(Raw_String)lhs
|
|
y := transmute(Raw_String)rhs
|
|
y := transmute(Raw_String)rhs
|
|
- switch {
|
|
|
|
- case x.len != y.len: return false
|
|
|
|
- case x.len == 0: return true
|
|
|
|
- case x.data == y.data: return true
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- a, b := x.data, y.data
|
|
|
|
- length := uint(x.len)
|
|
|
|
-
|
|
|
|
- when size_of(uint) == 8 {
|
|
|
|
- if word_length := length >> 3; word_length != 0 {
|
|
|
|
- for i in 0..<word_length {
|
|
|
|
- if intrinsics.unaligned_load((^u64)(a)) != intrinsics.unaligned_load((^u64)(b)) {
|
|
|
|
- return false
|
|
|
|
- }
|
|
|
|
- a = a[size_of(u64):]
|
|
|
|
- b = b[size_of(u64):]
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if length & 4 != 0 {
|
|
|
|
- if intrinsics.unaligned_load((^u32)(a)) != intrinsics.unaligned_load((^u32)(b)) {
|
|
|
|
- return false
|
|
|
|
- }
|
|
|
|
- a = a[size_of(u32):]
|
|
|
|
- b = b[size_of(u32):]
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if length & 2 != 0 {
|
|
|
|
- if intrinsics.unaligned_load((^u16)(a)) != intrinsics.unaligned_load((^u16)(b)) {
|
|
|
|
- return false
|
|
|
|
- }
|
|
|
|
- a = a[size_of(u16):]
|
|
|
|
- b = b[size_of(u16):]
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if length & 1 != 0 && a[0] != b[0] {
|
|
|
|
- return false
|
|
|
|
- }
|
|
|
|
- return true
|
|
|
|
- } else {
|
|
|
|
- if word_length := length >> 2; word_length != 0 {
|
|
|
|
- for i in 0..<word_length {
|
|
|
|
- if intrinsics.unaligned_load((^u32)(a)) != intrinsics.unaligned_load((^u32)(b)) {
|
|
|
|
- return false
|
|
|
|
- }
|
|
|
|
- a = a[size_of(u32):]
|
|
|
|
- b = b[size_of(u32):]
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- length &= 3
|
|
|
|
-
|
|
|
|
- if length != 0 {
|
|
|
|
- for i in 0..<length {
|
|
|
|
- if a[i] != b[i] {
|
|
|
|
- return false
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- return true
|
|
|
|
|
|
+ if x.len != y.len {
|
|
|
|
+ return false
|
|
}
|
|
}
|
|
|
|
+ return #force_inline memory_equal(x.data, y.data, x.len)
|
|
}
|
|
}
|
|
|
|
|
|
string_cmp :: proc "contextless" (a, b: string) -> int {
|
|
string_cmp :: proc "contextless" (a, b: string) -> int {
|