diff options
| author | 2026-02-05 14:35:00 +0300 | |
|---|---|---|
| committer | 2026-02-05 14:35:00 +0300 | |
| commit | 641a95063946bf7f4b8fdd1e938a917bc3f75cb2 (patch) | |
| tree | d19a6b92845de37e66b57b305fbcaf9f4816ffe9 /locker_win.go | |
| download | fqueue-641a95063946bf7f4b8fdd1e938a917bc3f75cb2.tar.gz fqueue-641a95063946bf7f4b8fdd1e938a917bc3f75cb2.tar.bz2 fqueue-641a95063946bf7f4b8fdd1e938a917bc3f75cb2.tar.xz fqueue-641a95063946bf7f4b8fdd1e938a917bc3f75cb2.zip | |
Diffstat (limited to 'locker_win.go')
| -rw-r--r-- | locker_win.go | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/locker_win.go b/locker_win.go new file mode 100644 index 0000000..ec14400 --- /dev/null +++ b/locker_win.go @@ -0,0 +1,54 @@ +//go:build windows +// +build windows + +package fqueue + +import ( + "syscall" + "unsafe" +) + +var ( + modkernel32 = syscall.NewLazyDLL("kernel32.dll") + procLockFileEx = modkernel32.NewProc("LockFileEx") + procUnlockFileEx = modkernel32.NewProc("UnlockFileEx") +) + +func lock(fd int, wait bool) error { + handle := syscall.Handle(fd) + var flags uint32 = 0x00000002 // LOCKFILE_EXCLUSIVE_LOCK + if !wait { + flags |= 0x00000001 // LOCKFILE_FAIL_IMMEDIATELY + } + + var overlapped syscall.Overlapped + r, _, err := procLockFileEx.Call( + uintptr(handle), + uintptr(flags), + 0, + uintptr(^uint32(0)), // максимальное количество байт + uintptr(^uint32(0)), + uintptr(unsafe.Pointer(&overlapped)), + ) + if r == 0 { + return err + } + return nil +} + +func unlock(fd int) error { + handle := syscall.Handle(fd) + var overlapped syscall.Overlapped + + r, _, err := procUnlockFileEx.Call( + uintptr(handle), + 0, + uintptr(^uint32(0)), + uintptr(^uint32(0)), + uintptr(unsafe.Pointer(&overlapped)), + ) + if r == 0 { + return err + } + return nil +} |
