aboutsummaryrefslogtreecommitdiff
path: root/core/sys
diff options
context:
space:
mode:
authorColin Davidson <colrdavidson@gmail.com>2025-07-28 14:24:46 -0700
committerColin Davidson <colrdavidson@gmail.com>2025-07-28 14:24:46 -0700
commitb88f9194d0d25bd5121f45eb3696b0e1725dfd41 (patch)
tree8f15e33fa41dd191f786b4ad414ab96062d96cbf /core/sys
parent2dae1d8a4134226887a6e6a0aad0318e46e40cde (diff)
parentbe3006dbf26fbe6b51bb489f346793823968aedf (diff)
Merge remote-tracking branch 'live/master' into macharena
Diffstat (limited to 'core/sys')
-rw-r--r--core/sys/darwin/Foundation/NSBlock.odin2
-rw-r--r--core/sys/darwin/darwin.odin2
-rw-r--r--core/sys/darwin/mach_darwin.odin2
-rw-r--r--core/sys/darwin/proc.odin2
-rw-r--r--core/sys/darwin/sync.odin20
-rw-r--r--core/sys/info/platform_darwin.odin2
-rw-r--r--core/sys/kqueue/kqueue.odin2
-rw-r--r--core/sys/posix/arpa_inet.odin2
-rw-r--r--core/sys/posix/dirent.odin2
-rw-r--r--core/sys/posix/dlfcn.odin2
-rw-r--r--core/sys/posix/fcntl.odin2
-rw-r--r--core/sys/posix/fnmatch.odin2
-rw-r--r--core/sys/posix/glob.odin2
-rw-r--r--core/sys/posix/grp.odin2
-rw-r--r--core/sys/posix/langinfo.odin2
-rw-r--r--core/sys/posix/libgen.odin2
-rw-r--r--core/sys/posix/monetary.odin2
-rw-r--r--core/sys/posix/net_if.odin2
-rw-r--r--core/sys/posix/netdb.odin2
-rw-r--r--core/sys/posix/netinet_in.odin2
-rw-r--r--core/sys/posix/poll.odin2
-rw-r--r--core/sys/posix/pthread.odin2
-rw-r--r--core/sys/posix/pwd.odin2
-rw-r--r--core/sys/posix/sched.odin2
-rw-r--r--core/sys/posix/setjmp.odin2
-rw-r--r--core/sys/posix/signal.odin2
-rw-r--r--core/sys/posix/signal_libc.odin2
-rw-r--r--core/sys/posix/stdio.odin2
-rw-r--r--core/sys/posix/stdio_libc.odin2
-rw-r--r--core/sys/posix/stdlib.odin2
-rw-r--r--core/sys/posix/stdlib_libc.odin2
-rw-r--r--core/sys/posix/string.odin2
-rw-r--r--core/sys/posix/string_libc.odin2
-rw-r--r--core/sys/posix/sys_ipc.odin2
-rw-r--r--core/sys/posix/sys_mman.odin2
-rw-r--r--core/sys/posix/sys_msg.odin2
-rw-r--r--core/sys/posix/sys_resource.odin2
-rw-r--r--core/sys/posix/sys_select.odin2
-rw-r--r--core/sys/posix/sys_sem.odin2
-rw-r--r--core/sys/posix/sys_shm.odin2
-rw-r--r--core/sys/posix/sys_socket.odin2
-rw-r--r--core/sys/posix/sys_stat.odin2
-rw-r--r--core/sys/posix/sys_statvfs.odin2
-rw-r--r--core/sys/posix/sys_time.odin2
-rw-r--r--core/sys/posix/sys_times.odin2
-rw-r--r--core/sys/posix/sys_uio.odin2
-rw-r--r--core/sys/posix/sys_utsname.odin2
-rw-r--r--core/sys/posix/sys_wait.odin2
-rw-r--r--core/sys/posix/termios.odin2
-rw-r--r--core/sys/posix/time.odin2
-rw-r--r--core/sys/posix/ulimit.odin2
-rw-r--r--core/sys/posix/unistd.odin2
-rw-r--r--core/sys/posix/unistd_libc.odin2
-rw-r--r--core/sys/posix/utime.odin2
-rw-r--r--core/sys/posix/wordexp.odin2
-rw-r--r--core/sys/windows/ole32.odin5
-rw-r--r--core/sys/windows/util.odin37
57 files changed, 95 insertions, 75 deletions
diff --git a/core/sys/darwin/Foundation/NSBlock.odin b/core/sys/darwin/Foundation/NSBlock.odin
index 1ef5e8a9b..8e65391f4 100644
--- a/core/sys/darwin/Foundation/NSBlock.odin
+++ b/core/sys/darwin/Foundation/NSBlock.odin
@@ -62,7 +62,7 @@ global_block_descriptor := Block_Descriptor{
size = size_of(Internal_Block_Literal),
}
-foreign import libSystem "system:System.framework"
+foreign import libSystem "system:System"
foreign libSystem {
_NSConcreteGlobalBlock: intrinsics.objc_class
_NSConcreteStackBlock: intrinsics.objc_class
diff --git a/core/sys/darwin/darwin.odin b/core/sys/darwin/darwin.odin
index 96cfc7be6..52297505a 100644
--- a/core/sys/darwin/darwin.odin
+++ b/core/sys/darwin/darwin.odin
@@ -4,7 +4,7 @@ package darwin
import "core:c"
@(export)
-foreign import system "system:System.framework"
+foreign import system "system:System"
Bool :: b8
diff --git a/core/sys/darwin/mach_darwin.odin b/core/sys/darwin/mach_darwin.odin
index b66b90325..ce8594a6c 100644
--- a/core/sys/darwin/mach_darwin.odin
+++ b/core/sys/darwin/mach_darwin.odin
@@ -1,6 +1,6 @@
package darwin
-foreign import mach "system:System.framework"
+foreign import mach "system:System"
import "core:c"
import "base:intrinsics"
diff --git a/core/sys/darwin/proc.odin b/core/sys/darwin/proc.odin
index fa5391f6f..ccd05f478 100644
--- a/core/sys/darwin/proc.odin
+++ b/core/sys/darwin/proc.odin
@@ -4,7 +4,7 @@ import "base:intrinsics"
import "core:sys/posix"
-foreign import lib "system:System.framework"
+foreign import lib "system:System"
// Incomplete bindings to the proc API on MacOS, add to when needed.
diff --git a/core/sys/darwin/sync.odin b/core/sys/darwin/sync.odin
index 6d68dc8f8..5f4f16fc3 100644
--- a/core/sys/darwin/sync.odin
+++ b/core/sys/darwin/sync.odin
@@ -3,23 +3,13 @@ package darwin
// #define OS_WAIT_ON_ADDR_AVAILABILITY \
// __API_AVAILABLE(macos(14.4), ios(17.4), tvos(17.4), watchos(10.4))
when ODIN_OS == .Darwin {
-
- when ODIN_PLATFORM_SUBTARGET == .iOS && ODIN_MINIMUM_OS_VERSION >= 17_04_00 {
- WAIT_ON_ADDRESS_AVAILABLE :: true
- } else when ODIN_MINIMUM_OS_VERSION >= 14_04_00 {
- WAIT_ON_ADDRESS_AVAILABLE :: true
+ when ODIN_PLATFORM_SUBTARGET_IOS {
+ WAIT_ON_ADDRESS_AVAILABLE :: ODIN_MINIMUM_OS_VERSION >= 17_04_00
+ ULOCK_WAIT_2_AVAILABLE :: ODIN_MINIMUM_OS_VERSION >= 14_00_00
} else {
- WAIT_ON_ADDRESS_AVAILABLE :: false
+ WAIT_ON_ADDRESS_AVAILABLE :: ODIN_MINIMUM_OS_VERSION >= 14_04_00
+ ULOCK_WAIT_2_AVAILABLE :: ODIN_MINIMUM_OS_VERSION >= 11_00_00
}
-
- when ODIN_PLATFORM_SUBTARGET == .iOS && ODIN_MINIMUM_OS_VERSION >= 14_00_00 {
- ULOCK_WAIT_2_AVAILABLE :: true
- } else when ODIN_MINIMUM_OS_VERSION >= 11_00_00 {
- ULOCK_WAIT_2_AVAILABLE :: true
- } else {
- ULOCK_WAIT_2_AVAILABLE :: false
- }
-
} else {
WAIT_ON_ADDRESS_AVAILABLE :: false
ULOCK_WAIT_2_AVAILABLE :: false
diff --git a/core/sys/info/platform_darwin.odin b/core/sys/info/platform_darwin.odin
index dd7f0fa03..3fc8064ec 100644
--- a/core/sys/info/platform_darwin.odin
+++ b/core/sys/info/platform_darwin.odin
@@ -28,7 +28,7 @@ init_platform :: proc() {
macos_version = {int(version.majorVersion), int(version.minorVersion), int(version.patchVersion)}
- when ODIN_PLATFORM_SUBTARGET == .iOS {
+ when ODIN_PLATFORM_SUBTARGET_IOS {
os_version.platform = .iOS
ws(&b, "iOS")
} else {
diff --git a/core/sys/kqueue/kqueue.odin b/core/sys/kqueue/kqueue.odin
index 56be1cf7a..25ee9bdce 100644
--- a/core/sys/kqueue/kqueue.odin
+++ b/core/sys/kqueue/kqueue.odin
@@ -2,7 +2,7 @@
package kqueue
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/arpa_inet.odin b/core/sys/posix/arpa_inet.odin
index ac850ed49..6edb9e535 100644
--- a/core/sys/posix/arpa_inet.odin
+++ b/core/sys/posix/arpa_inet.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else when ODIN_OS == .Haiku {
foreign import lib "system:network"
} else {
diff --git a/core/sys/posix/dirent.odin b/core/sys/posix/dirent.odin
index 1394f6b9e..cf15dada4 100644
--- a/core/sys/posix/dirent.odin
+++ b/core/sys/posix/dirent.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/dlfcn.odin b/core/sys/posix/dlfcn.odin
index 378c95c32..6c96b0079 100644
--- a/core/sys/posix/dlfcn.odin
+++ b/core/sys/posix/dlfcn.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else when ODIN_OS == .FreeBSD || ODIN_OS == .NetBSD {
foreign import lib "system:dl"
} else {
diff --git a/core/sys/posix/fcntl.odin b/core/sys/posix/fcntl.odin
index bc0b5b5ba..db095c418 100644
--- a/core/sys/posix/fcntl.odin
+++ b/core/sys/posix/fcntl.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/fnmatch.odin b/core/sys/posix/fnmatch.odin
index 04c3d2888..efe179324 100644
--- a/core/sys/posix/fnmatch.odin
+++ b/core/sys/posix/fnmatch.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/glob.odin b/core/sys/posix/glob.odin
index fb90b7546..530481587 100644
--- a/core/sys/posix/glob.odin
+++ b/core/sys/posix/glob.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/grp.odin b/core/sys/posix/grp.odin
index 3694308a0..8e8e69fc2 100644
--- a/core/sys/posix/grp.odin
+++ b/core/sys/posix/grp.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/langinfo.odin b/core/sys/posix/langinfo.odin
index 1fddfe280..195de650d 100644
--- a/core/sys/posix/langinfo.odin
+++ b/core/sys/posix/langinfo.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/libgen.odin b/core/sys/posix/libgen.odin
index 2354bf70d..aa2effd72 100644
--- a/core/sys/posix/libgen.odin
+++ b/core/sys/posix/libgen.odin
@@ -2,7 +2,7 @@
package posix
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/monetary.odin b/core/sys/posix/monetary.odin
index a444bff09..2e4105881 100644
--- a/core/sys/posix/monetary.odin
+++ b/core/sys/posix/monetary.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/net_if.odin b/core/sys/posix/net_if.odin
index 774d11b72..182a049d1 100644
--- a/core/sys/posix/net_if.odin
+++ b/core/sys/posix/net_if.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/netdb.odin b/core/sys/posix/netdb.odin
index ff1cb9d4c..f2f83875f 100644
--- a/core/sys/posix/netdb.odin
+++ b/core/sys/posix/netdb.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/netinet_in.odin b/core/sys/posix/netinet_in.odin
index ec05915de..4b74b87f0 100644
--- a/core/sys/posix/netinet_in.odin
+++ b/core/sys/posix/netinet_in.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/poll.odin b/core/sys/posix/poll.odin
index 44ec767a6..a9e582b51 100644
--- a/core/sys/posix/poll.odin
+++ b/core/sys/posix/poll.odin
@@ -6,7 +6,7 @@ import "base:intrinsics"
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/pthread.odin b/core/sys/posix/pthread.odin
index 36a3cd7b3..c7255baa3 100644
--- a/core/sys/posix/pthread.odin
+++ b/core/sys/posix/pthread.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else when ODIN_OS == .FreeBSD || ODIN_OS == .NetBSD || ODIN_OS == .Linux {
foreign import lib "system:pthread"
} else {
diff --git a/core/sys/posix/pwd.odin b/core/sys/posix/pwd.odin
index 75d15c899..c3ee3c0f6 100644
--- a/core/sys/posix/pwd.odin
+++ b/core/sys/posix/pwd.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sched.odin b/core/sys/posix/sched.odin
index 82b335653..cc509ba8e 100644
--- a/core/sys/posix/sched.odin
+++ b/core/sys/posix/sched.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/setjmp.odin b/core/sys/posix/setjmp.odin
index 926dbd3ad..a26bdb93e 100644
--- a/core/sys/posix/setjmp.odin
+++ b/core/sys/posix/setjmp.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/signal.odin b/core/sys/posix/signal.odin
index 882cd9fa8..69b405c5d 100644
--- a/core/sys/posix/signal.odin
+++ b/core/sys/posix/signal.odin
@@ -6,7 +6,7 @@ import "base:intrinsics"
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/signal_libc.odin b/core/sys/posix/signal_libc.odin
index 7a054ddd7..ba0fbf084 100644
--- a/core/sys/posix/signal_libc.odin
+++ b/core/sys/posix/signal_libc.odin
@@ -9,7 +9,7 @@ import "core:c/libc"
when ODIN_OS == .Windows {
foreign import lib "system:libucrt.lib"
} else when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/stdio.odin b/core/sys/posix/stdio.odin
index 24464dfd8..69c8ad3cb 100644
--- a/core/sys/posix/stdio.odin
+++ b/core/sys/posix/stdio.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/stdio_libc.odin b/core/sys/posix/stdio_libc.odin
index 12706970d..8ccdcc37a 100644
--- a/core/sys/posix/stdio_libc.odin
+++ b/core/sys/posix/stdio_libc.odin
@@ -10,7 +10,7 @@ when ODIN_OS == .Windows {
"system:legacy_stdio_definitions.lib",
}
} else when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/stdlib.odin b/core/sys/posix/stdlib.odin
index 5f1ae1908..0a6e5403c 100644
--- a/core/sys/posix/stdlib.odin
+++ b/core/sys/posix/stdlib.odin
@@ -6,7 +6,7 @@ import "base:intrinsics"
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/stdlib_libc.odin b/core/sys/posix/stdlib_libc.odin
index 6574026f4..e31c51704 100644
--- a/core/sys/posix/stdlib_libc.odin
+++ b/core/sys/posix/stdlib_libc.odin
@@ -9,7 +9,7 @@ import "core:c/libc"
when ODIN_OS == .Windows {
foreign import lib "system:libucrt.lib"
} else when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/string.odin b/core/sys/posix/string.odin
index 3f9dbb43e..3d0c5b7a2 100644
--- a/core/sys/posix/string.odin
+++ b/core/sys/posix/string.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/string_libc.odin b/core/sys/posix/string_libc.odin
index 72164cc4c..d689847ee 100644
--- a/core/sys/posix/string_libc.odin
+++ b/core/sys/posix/string_libc.odin
@@ -4,7 +4,7 @@ package posix
when ODIN_OS == .Windows {
foreign import lib "system:libucrt.lib"
} else when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_ipc.odin b/core/sys/posix/sys_ipc.odin
index bf5938ce1..5814c7211 100644
--- a/core/sys/posix/sys_ipc.odin
+++ b/core/sys/posix/sys_ipc.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_mman.odin b/core/sys/posix/sys_mman.odin
index 0594672ae..2d51083dc 100644
--- a/core/sys/posix/sys_mman.odin
+++ b/core/sys/posix/sys_mman.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_msg.odin b/core/sys/posix/sys_msg.odin
index c578b1fc6..87d5089ea 100644
--- a/core/sys/posix/sys_msg.odin
+++ b/core/sys/posix/sys_msg.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_resource.odin b/core/sys/posix/sys_resource.odin
index ae478382a..a748c2bba 100644
--- a/core/sys/posix/sys_resource.odin
+++ b/core/sys/posix/sys_resource.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_select.odin b/core/sys/posix/sys_select.odin
index a75e58de6..117dee625 100644
--- a/core/sys/posix/sys_select.odin
+++ b/core/sys/posix/sys_select.odin
@@ -6,7 +6,7 @@ import "base:intrinsics"
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_sem.odin b/core/sys/posix/sys_sem.odin
index 069315f87..e876cf74a 100644
--- a/core/sys/posix/sys_sem.odin
+++ b/core/sys/posix/sys_sem.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_shm.odin b/core/sys/posix/sys_shm.odin
index 8f3c56b9c..8ee16e5a3 100644
--- a/core/sys/posix/sys_shm.odin
+++ b/core/sys/posix/sys_shm.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_socket.odin b/core/sys/posix/sys_socket.odin
index 0645893d0..812451219 100644
--- a/core/sys/posix/sys_socket.odin
+++ b/core/sys/posix/sys_socket.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import libc "system:System.framework"
+ foreign import libc "system:System"
} else {
foreign import libc "system:c"
}
diff --git a/core/sys/posix/sys_stat.odin b/core/sys/posix/sys_stat.odin
index 265356e54..df0bf2b49 100644
--- a/core/sys/posix/sys_stat.odin
+++ b/core/sys/posix/sys_stat.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_statvfs.odin b/core/sys/posix/sys_statvfs.odin
index 47c810135..1a332c5ce 100644
--- a/core/sys/posix/sys_statvfs.odin
+++ b/core/sys/posix/sys_statvfs.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_time.odin b/core/sys/posix/sys_time.odin
index 94eafec85..058166759 100644
--- a/core/sys/posix/sys_time.odin
+++ b/core/sys/posix/sys_time.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_times.odin b/core/sys/posix/sys_times.odin
index 73db489a7..636d3e153 100644
--- a/core/sys/posix/sys_times.odin
+++ b/core/sys/posix/sys_times.odin
@@ -2,7 +2,7 @@
package posix
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_uio.odin b/core/sys/posix/sys_uio.odin
index 5770f8058..b4411851b 100644
--- a/core/sys/posix/sys_uio.odin
+++ b/core/sys/posix/sys_uio.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import libc "system:System.framework"
+ foreign import libc "system:System"
} else {
foreign import libc "system:c"
}
diff --git a/core/sys/posix/sys_utsname.odin b/core/sys/posix/sys_utsname.odin
index 5ea8807a7..61f88b584 100644
--- a/core/sys/posix/sys_utsname.odin
+++ b/core/sys/posix/sys_utsname.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/sys_wait.odin b/core/sys/posix/sys_wait.odin
index d3bcdfddd..e12fcd212 100644
--- a/core/sys/posix/sys_wait.odin
+++ b/core/sys/posix/sys_wait.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/termios.odin b/core/sys/posix/termios.odin
index 4ca884e87..b385b7097 100644
--- a/core/sys/posix/termios.odin
+++ b/core/sys/posix/termios.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/time.odin b/core/sys/posix/time.odin
index 88f0153f4..7d55cf15b 100644
--- a/core/sys/posix/time.odin
+++ b/core/sys/posix/time.odin
@@ -5,7 +5,7 @@ import "core:c"
import "core:c/libc"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/ulimit.odin b/core/sys/posix/ulimit.odin
index 0f87641fa..892f6dee4 100644
--- a/core/sys/posix/ulimit.odin
+++ b/core/sys/posix/ulimit.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/unistd.odin b/core/sys/posix/unistd.odin
index b8020317c..b05f1e4fa 100644
--- a/core/sys/posix/unistd.odin
+++ b/core/sys/posix/unistd.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/unistd_libc.odin b/core/sys/posix/unistd_libc.odin
index 74edb6862..85d019f21 100644
--- a/core/sys/posix/unistd_libc.odin
+++ b/core/sys/posix/unistd_libc.odin
@@ -6,7 +6,7 @@ import "core:c"
when ODIN_OS == .Windows {
foreign import lib "system:libucrt.lib"
} else when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/utime.odin b/core/sys/posix/utime.odin
index 98c8166d6..fca0dee59 100644
--- a/core/sys/posix/utime.odin
+++ b/core/sys/posix/utime.odin
@@ -2,7 +2,7 @@
package posix
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/posix/wordexp.odin b/core/sys/posix/wordexp.odin
index a9e6f39a7..92d6aba40 100644
--- a/core/sys/posix/wordexp.odin
+++ b/core/sys/posix/wordexp.odin
@@ -4,7 +4,7 @@ package posix
import "core:c"
when ODIN_OS == .Darwin {
- foreign import lib "system:System.framework"
+ foreign import lib "system:System"
} else {
foreign import lib "system:c"
}
diff --git a/core/sys/windows/ole32.odin b/core/sys/windows/ole32.odin
index 7409d40dc..2e59949e3 100644
--- a/core/sys/windows/ole32.odin
+++ b/core/sys/windows/ole32.odin
@@ -25,11 +25,12 @@ COINIT :: enum DWORD {
SPEED_OVER_MEMORY = 0x8,
}
+IUnknown_UUID_STRING :: "00000000-0000-0000-C000-000000000046"
+IUnknown_UUID := &IID{0x00000000, 0x0000, 0x0000, {0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x46}}
+IUnknownVtbl :: IUnknown_VTable
IUnknown :: struct {
using _iunknown_vtable: ^IUnknown_VTable,
}
-
-IUnknownVtbl :: IUnknown_VTable
IUnknown_VTable :: struct {
QueryInterface: proc "system" (This: ^IUnknown, riid: REFIID, ppvObject: ^rawptr) -> HRESULT,
AddRef: proc "system" (This: ^IUnknown) -> ULONG,
diff --git a/core/sys/windows/util.odin b/core/sys/windows/util.odin
index 30eecf8a1..995e8e0e5 100644
--- a/core/sys/windows/util.odin
+++ b/core/sys/windows/util.odin
@@ -170,15 +170,15 @@ wstring_to_utf8_alloc :: proc(s: wstring, N: int, allocator := context.temp_allo
return string(text[:n]), nil
}
-wstring_to_utf8_buf :: proc(buf: []u8, s: wstring) -> (res: string) {
- n := WideCharToMultiByte(CP_UTF8, WC_ERR_INVALID_CHARS, s, -1, nil, 0, nil, nil)
+wstring_to_utf8_buf :: proc(buf: []u8, s: wstring, N := -1) -> (res: string) {
+ n := WideCharToMultiByte(CP_UTF8, WC_ERR_INVALID_CHARS, s, i32(N), nil, 0, nil, nil)
if n == 0 {
return
} else if int(n) > len(buf) {
return
}
- n2 := WideCharToMultiByte(CP_UTF8, WC_ERR_INVALID_CHARS, s, -1, raw_data(buf), n, nil, nil)
+ n2 := WideCharToMultiByte(CP_UTF8, WC_ERR_INVALID_CHARS, s, i32(N), raw_data(buf), n, nil, nil)
if n2 == 0 {
return
} else if int(n2) > len(buf) {
@@ -196,6 +196,21 @@ wstring_to_utf8_buf :: proc(buf: []u8, s: wstring) -> (res: string) {
wstring_to_utf8 :: proc{wstring_to_utf8_alloc, wstring_to_utf8_buf}
+/*
+Converts a UTF-16 string into a regular UTF-8 `string` and allocates the result.
+If the input is null-terminated, only the part of the input string leading up
+to it will be converted.
+
+*Allocates Using Provided Allocator*
+
+Inputs:
+- s: The string to be converted
+- allocator: (default: context.allocator)
+
+Returns:
+- res: A cloned and converted string
+- err: An optional allocator error if one occured, `nil` otherwise
+*/
utf16_to_utf8_alloc :: proc(s: []u16, allocator := context.temp_allocator) -> (res: string, err: runtime.Allocator_Error) {
if len(s) == 0 {
return "", nil
@@ -203,11 +218,25 @@ utf16_to_utf8_alloc :: proc(s: []u16, allocator := context.temp_allocator) -> (r
return wstring_to_utf8(raw_data(s), len(s), allocator)
}
+/*
+Converts a UTF-16 string into a regular UTF-8 `string`, using `buf` as its backing.
+If the input is null-terminated, only the part of the input string leading up
+to it will be converted.
+
+*Uses `buf` for backing*
+
+Inputs:
+- s: The string to be converted
+- buf: Backing buffer for result string
+
+Returns:
+- res: A converted string, backed byu `buf`
+*/
utf16_to_utf8_buf :: proc(buf: []u8, s: []u16) -> (res: string) {
if len(s) == 0 {
return
}
- return wstring_to_utf8(buf, raw_data(s))
+ return wstring_to_utf8(buf, raw_data(s), len(s))
}
utf16_to_utf8 :: proc{utf16_to_utf8_alloc, utf16_to_utf8_buf}