zig/lib/std / event/rwlocked.zig

Thread-safe async/await RW lock that protects one piece of data. Functions which are waiting for the lock are suspended, and are resumed when the lock is released, in order.

const std = @import("../std.zig");
const RwLock = std.event.RwLock;

RwLocked()


/// Thread-safe async/await RW lock that protects one piece of data.
/// Functions which are waiting for the lock are suspended, and
/// are resumed when the lock is released, in order.
pub fn RwLocked(comptime T: type) type {
    return struct {
        lock: RwLock,
        locked_data: T,

HeldReadLock


        const Self = @This();

release()


        pub const HeldReadLock = struct {
            value: *const T,
            held: RwLock.HeldRead,

HeldWriteLock


            pub fn release(self: HeldReadLock) void {
                self.held.release();
            }
        };

release()


        pub const HeldWriteLock = struct {
            value: *T,
            held: RwLock.HeldWrite,

init()


            pub fn release(self: HeldWriteLock) void {
                self.held.release();
            }
        };

deinit()


        pub fn init(data: T) Self {
            return Self{
                .lock = RwLock.init(),
                .locked_data = data,
            };
        }

acquireRead()


        pub fn deinit(self: *Self) void {
            self.lock.deinit();
        }

acquireWrite()


        pub fn acquireRead(self: *Self) callconv(.Async) HeldReadLock {
            return HeldReadLock{
                .held = self.lock.acquireRead(),
                .value = &self.locked_data,
            };
        }

        pub fn acquireWrite(self: *Self) callconv(.Async) HeldWriteLock {
            return HeldWriteLock{
                .held = self.lock.acquireWrite(),
                .value = &self.locked_data,
            };
        }
    };
}