2015-07-06 21:58:53 -04:00
|
|
|
package system
|
|
|
|
|
|
|
|
// This file implements syscalls for Win32 events which are not implemented
|
|
|
|
// in golang.
|
|
|
|
|
|
|
|
import (
|
|
|
|
"syscall"
|
|
|
|
"unsafe"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
procCreateEvent = modkernel32.NewProc("CreateEventW")
|
|
|
|
procOpenEvent = modkernel32.NewProc("OpenEventW")
|
|
|
|
procSetEvent = modkernel32.NewProc("SetEvent")
|
|
|
|
procResetEvent = modkernel32.NewProc("ResetEvent")
|
|
|
|
procPulseEvent = modkernel32.NewProc("PulseEvent")
|
|
|
|
)
|
|
|
|
|
2015-07-28 12:13:12 -04:00
|
|
|
// CreateEvent implements win32 CreateEventW func in golang. It will create an event object.
|
2015-07-06 21:58:53 -04:00
|
|
|
func CreateEvent(eventAttributes *syscall.SecurityAttributes, manualReset bool, initialState bool, name string) (handle syscall.Handle, err error) {
|
|
|
|
namep, _ := syscall.UTF16PtrFromString(name)
|
2015-07-28 12:13:12 -04:00
|
|
|
var _p1 uint32
|
2015-07-06 21:58:53 -04:00
|
|
|
if manualReset {
|
|
|
|
_p1 = 1
|
|
|
|
}
|
2015-07-28 12:13:12 -04:00
|
|
|
var _p2 uint32
|
2015-07-06 21:58:53 -04:00
|
|
|
if initialState {
|
|
|
|
_p2 = 1
|
|
|
|
}
|
|
|
|
r0, _, e1 := procCreateEvent.Call(uintptr(unsafe.Pointer(eventAttributes)), uintptr(_p1), uintptr(_p2), uintptr(unsafe.Pointer(namep)))
|
|
|
|
use(unsafe.Pointer(namep))
|
|
|
|
handle = syscall.Handle(r0)
|
|
|
|
if handle == syscall.InvalidHandle {
|
|
|
|
err = e1
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2015-07-28 12:13:12 -04:00
|
|
|
// OpenEvent implements win32 OpenEventW func in golang. It opens an event object.
|
2015-07-06 21:58:53 -04:00
|
|
|
func OpenEvent(desiredAccess uint32, inheritHandle bool, name string) (handle syscall.Handle, err error) {
|
|
|
|
namep, _ := syscall.UTF16PtrFromString(name)
|
2015-07-28 12:13:12 -04:00
|
|
|
var _p1 uint32
|
2015-07-06 21:58:53 -04:00
|
|
|
if inheritHandle {
|
|
|
|
_p1 = 1
|
|
|
|
}
|
|
|
|
r0, _, e1 := procOpenEvent.Call(uintptr(desiredAccess), uintptr(_p1), uintptr(unsafe.Pointer(namep)))
|
|
|
|
use(unsafe.Pointer(namep))
|
|
|
|
handle = syscall.Handle(r0)
|
|
|
|
if handle == syscall.InvalidHandle {
|
|
|
|
err = e1
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2015-07-28 12:13:12 -04:00
|
|
|
// SetEvent implements win32 SetEvent func in golang.
|
2015-07-06 21:58:53 -04:00
|
|
|
func SetEvent(handle syscall.Handle) (err error) {
|
|
|
|
return setResetPulse(handle, procSetEvent)
|
|
|
|
}
|
|
|
|
|
2015-07-28 12:13:12 -04:00
|
|
|
// ResetEvent implements win32 ResetEvent func in golang.
|
2015-07-06 21:58:53 -04:00
|
|
|
func ResetEvent(handle syscall.Handle) (err error) {
|
|
|
|
return setResetPulse(handle, procResetEvent)
|
|
|
|
}
|
|
|
|
|
2015-07-28 12:13:12 -04:00
|
|
|
// PulseEvent implements win32 PulseEvent func in golang.
|
2015-07-06 21:58:53 -04:00
|
|
|
func PulseEvent(handle syscall.Handle) (err error) {
|
|
|
|
return setResetPulse(handle, procPulseEvent)
|
|
|
|
}
|
|
|
|
|
|
|
|
func setResetPulse(handle syscall.Handle, proc *syscall.LazyProc) (err error) {
|
|
|
|
r0, _, _ := proc.Call(uintptr(handle))
|
|
|
|
if r0 != 0 {
|
|
|
|
err = syscall.Errno(r0)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
var temp unsafe.Pointer
|
|
|
|
|
|
|
|
// use ensures a variable is kept alive without the GC freeing while still needed
|
|
|
|
func use(p unsafe.Pointer) {
|
|
|
|
temp = p
|
|
|
|
}
|