aboutsummaryrefslogtreecommitdiff
path: root/locker_win.go
diff options
context:
space:
mode:
author2026-02-05 14:35:00 +0300
committer2026-02-05 14:35:00 +0300
commit641a95063946bf7f4b8fdd1e938a917bc3f75cb2 (patch)
treed19a6b92845de37e66b57b305fbcaf9f4816ffe9 /locker_win.go
downloadfqueue-master.tar.gz
fqueue-master.tar.bz2
fqueue-master.tar.xz
fqueue-master.zip
initialHEADmaster
Diffstat (limited to 'locker_win.go')
-rw-r--r--locker_win.go54
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
+}