aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2022-08-05 11:36:20 +0100
committergingerBill <bill@gingerbill.org>2022-08-05 11:36:20 +0100
commit64ff05303c898a4217ed85a527f24ef569f1e6e7 (patch)
tree17f094a2a5b63822a7e1c5ce95fcdc1a76a05df3
parent6caab6225da912be51cbce5e6498490e6dcba06b (diff)
parent326411498a3e252133b39e0b59d2c0dc711b451e (diff)
Merge branch 'master' of https://github.com/odin-lang/Odin
-rw-r--r--core/os/os2/user.odin20
-rw-r--r--core/runtime/internal.odin7
-rw-r--r--core/sort/sort.odin7
-rw-r--r--core/sys/windows/user32.odin1
4 files changed, 23 insertions, 12 deletions
diff --git a/core/os/os2/user.odin b/core/os/os2/user.odin
index 1fb653b85..00cccd2a7 100644
--- a/core/os/os2/user.odin
+++ b/core/os/os2/user.odin
@@ -6,19 +6,19 @@ import "core:runtime"
user_cache_dir :: proc(allocator: runtime.Allocator) -> (dir: string, err: Error) {
#partial switch ODIN_OS {
case .Windows:
- dir = get_env("LocalAppData")
+ dir = get_env("LocalAppData", allocator)
if dir != "" {
dir = strings.clone_safe(dir, allocator) or_return
}
case .Darwin:
- dir = get_env("HOME")
+ dir = get_env("HOME", allocator)
if dir != "" {
dir = strings.concatenate_safe({dir, "/Library/Caches"}, allocator) or_return
}
case: // All other UNIX systems
- dir = get_env("XDG_CACHE_HOME")
+ dir = get_env("XDG_CACHE_HOME", allocator)
if dir == "" {
- dir = get_env("HOME")
+ dir = get_env("HOME", allocator)
if dir == "" {
return
}
@@ -34,19 +34,19 @@ user_cache_dir :: proc(allocator: runtime.Allocator) -> (dir: string, err: Error
user_config_dir :: proc(allocator: runtime.Allocator) -> (dir: string, err: Error) {
#partial switch ODIN_OS {
case .Windows:
- dir = get_env("AppData")
+ dir = get_env("AppData", allocator)
if dir != "" {
dir = strings.clone_safe(dir, allocator) or_return
}
case .Darwin:
- dir = get_env("HOME")
+ dir = get_env("HOME", allocator)
if dir != "" {
dir = strings.concatenate_safe({dir, "/Library/Application Support"}, allocator) or_return
}
case: // All other UNIX systems
- dir = get_env("XDG_CACHE_HOME")
+ dir = get_env("XDG_CACHE_HOME", allocator)
if dir == "" {
- dir = get_env("HOME")
+ dir = get_env("HOME", allocator)
if dir == "" {
return
}
@@ -59,13 +59,13 @@ user_config_dir :: proc(allocator: runtime.Allocator) -> (dir: string, err: Erro
return
}
-user_home_dir :: proc() -> (dir: string, err: Error) {
+user_home_dir :: proc(allocator: runtime.Allocator) -> (dir: string, err: Error) {
env := "HOME"
#partial switch ODIN_OS {
case .Windows:
env = "USERPROFILE"
}
- if v := get_env(env); v != "" {
+ if v := get_env(env, allocator); v != "" {
return v, nil
}
return "", .Invalid_Path
diff --git a/core/runtime/internal.odin b/core/runtime/internal.odin
index 30798f623..16af84ebc 100644
--- a/core/runtime/internal.odin
+++ b/core/runtime/internal.odin
@@ -341,7 +341,12 @@ string_eq :: proc "contextless" (lhs, rhs: string) -> bool {
string_cmp :: proc "contextless" (a, b: string) -> int {
x := transmute(Raw_String)a
y := transmute(Raw_String)b
- return memory_compare(x.data, y.data, min(x.len, y.len))
+
+ ret := memory_compare(x.data, y.data, min(x.len, y.len))
+ if ret == 0 && x.len != y.len {
+ return -1 if x.len < y.len else +1
+ }
+ return ret
}
string_ne :: #force_inline proc "contextless" (a, b: string) -> bool { return !string_eq(a, b) }
diff --git a/core/sort/sort.odin b/core/sort/sort.odin
index 2ce74294d..a2b4d7ea0 100644
--- a/core/sort/sort.odin
+++ b/core/sort/sort.odin
@@ -684,5 +684,10 @@ compare_f64s :: proc(a, b: f64) -> int {
compare_strings :: proc(a, b: string) -> int {
x := transmute(mem.Raw_String)a
y := transmute(mem.Raw_String)b
- return mem.compare_byte_ptrs(x.data, y.data, min(x.len, y.len))
+
+ ret := mem.compare_byte_ptrs(x.data, y.data, min(x.len, y.len))
+ if ret == 0 && x.len != y.len {
+ return -1 if x.len < y.len else +1
+ }
+ return ret
}
diff --git a/core/sys/windows/user32.odin b/core/sys/windows/user32.odin
index 47de354b6..d0a0d5b0a 100644
--- a/core/sys/windows/user32.odin
+++ b/core/sys/windows/user32.odin
@@ -18,6 +18,7 @@ foreign user32 {
RegisterClassW :: proc(lpWndClass: ^WNDCLASSW) -> ATOM ---
RegisterClassExW :: proc(^WNDCLASSEXW) -> ATOM ---
+ UnregisterClassW :: proc(lpClassName: LPCWSTR, hInstance: HINSTANCE) -> BOOL ---
CreateWindowExW :: proc(
dwExStyle: DWORD,