diff --git a/lib/std/Progress.zig b/lib/std/Progress.zig index b75ad106a4..4f278e67f6 100644 --- a/lib/std/Progress.zig +++ b/lib/std/Progress.zig @@ -103,7 +103,11 @@ pub const Node = struct { } parent.completeOne(); } else { - self.context.done = true; + { + const held = self.context.update_lock.acquire(); + defer held.release(); + self.context.done = true; + } self.context.refresh(); } } diff --git a/lib/std/os/windows/kernel32.zig b/lib/std/os/windows/kernel32.zig index ec4a75afa9..734059a08a 100644 --- a/lib/std/os/windows/kernel32.zig +++ b/lib/std/os/windows/kernel32.zig @@ -299,6 +299,6 @@ pub extern "kernel32" fn SleepConditionVariableSRW( f: ULONG, ) callconv(WINAPI) BOOL; -pub extern "kernel32" fn TryAcquireSRWLockExclusive(s: *SRWLOCK) callconv(WINAPI) BOOL; +pub extern "kernel32" fn TryAcquireSRWLockExclusive(s: *SRWLOCK) callconv(WINAPI) BOOLEAN; pub extern "kernel32" fn AcquireSRWLockExclusive(s: *SRWLOCK) callconv(WINAPI) void; pub extern "kernel32" fn ReleaseSRWLockExclusive(s: *SRWLOCK) callconv(WINAPI) void;