v/vlib/sync/tls_windows.c.v

63 lines
1.7 KiB
V

module sync
// Windows TLS API functions (via C interface)
fn C.TlsAlloc() u32
fn C.TlsSetValue(key u32, voidptr) bool
fn C.TlsGetValue(key u32) voidptr
fn C.TlsFree(key u32) bool
// new_tls creates new TLS storage initialized with the given `value`
pub fn new_tls[T](value T) !ThreadLocalStorage[T] {
$if T !in [i8, i16, i32, i64, u8, u16, u32, u64, isize, usize, f32, f64, rune, int, voidptr,
$pointer] {
return error('new_tls: invalid type ${T.name}')
}
key := C.TlsAlloc()
// Validate key allocation
if key != C.TLS_OUT_OF_INDEXES {
// Initialize storage and verify success
if C.TlsSetValue(key, convert_t_to_voidptr(value)!) {
return ThreadLocalStorage[T]{
key: key
in_use: true
}
} else {
return error('new_tls: Failed to initialize TLS value: ${value}')
}
}
// Handle allocation failure
return error('new_tls: Failed to allocate TLS index')
}
// set updates the `value` in TLS storage.
@[inline]
pub fn (mut t ThreadLocalStorage[T]) set(value T) ! {
if t.in_use {
if !C.TlsSetValue(t.key, convert_t_to_voidptr(value)!) {
return error('set: Failed to update TLS value: ${value}')
}
} else {
return error('set: TLS storage is already destroyed')
}
}
// get retrieves the current value from TLS storage.
@[inline]
pub fn (mut t ThreadLocalStorage[T]) get() !T {
if t.in_use {
return convert_voidptr_to_t[T](C.TlsGetValue(t.key))
}
return error('get: TLS storage is already destroyed')
}
// destroy releases TLS resources (must be called manually).
@[inline]
pub fn (mut t ThreadLocalStorage[T]) destroy() ! {
if C.TlsFree(t.key) {
t.in_use = false
} else {
return error('destroy: Failed to release TLS resources')
}
}