v / vlib / sync / tls_windows.c.v
62 lines · 56 sloc · 1.65 KB · fcbe2e6ce77207e4d35b31cade9d6f1ecef55b5f
Raw
1module sync
2
3// Windows TLS API functions (via C interface)
4fn C.TlsAlloc() u32
5fn C.TlsSetValue(key u32, voidptr) bool
6fn C.TlsGetValue(key u32) voidptr
7fn C.TlsFree(key u32) bool
8
9// new_tls creates new TLS storage initialized with the given `value`
10pub fn new_tls[T](value T) !ThreadLocalStorage[T] {
11 $if T !in [i8, i16, i32, i64, u8, u16, u32, u64, isize, usize, f32, f64, rune, int, voidptr,
12 $pointer] {
13 return error('new_tls: invalid type ${T.name}')
14 }
15
16 key := C.TlsAlloc()
17 // Validate key allocation
18 if key != C.TLS_OUT_OF_INDEXES {
19 // Initialize storage and verify success
20 if C.TlsSetValue(key, convert_t_to_voidptr(value)!) {
21 return ThreadLocalStorage[T]{
22 key: key
23 in_use: true
24 }
25 } else {
26 return error('new_tls: Failed to initialize TLS value: ${value}')
27 }
28 }
29 // Handle allocation failure
30 return error('new_tls: Failed to allocate TLS index')
31}
32
33// set updates the `value` in TLS storage.
34@[inline]
35pub fn (mut t ThreadLocalStorage[T]) set(value T) ! {
36 if t.in_use {
37 if !C.TlsSetValue(t.key, convert_t_to_voidptr(value)!) {
38 return error('set: Failed to update TLS value: ${value}')
39 }
40 } else {
41 return error('set: TLS storage is already destroyed')
42 }
43}
44
45// get retrieves the current value from TLS storage.
46@[inline]
47pub fn (mut t ThreadLocalStorage[T]) get() !T {
48 if t.in_use {
49 return convert_voidptr_to_t[T](C.TlsGetValue(t.key))
50 }
51 return error('get: TLS storage is already destroyed')
52}
53
54// destroy releases TLS resources (must be called manually).
55@[inline]
56pub fn (mut t ThreadLocalStorage[T]) destroy() ! {
57 if C.TlsFree(t.key) {
58 t.in_use = false
59 } else {
60 return error('destroy: Failed to release TLS resources')
61 }
62}
63