2021-01-10 15:55:29 +01:00
|
|
|
package xevent
|
|
|
|
|
|
|
|
/*
|
2021-01-11 15:57:14 +01:00
|
|
|
#cgo linux LDFLAGS: -lX11 -lXfixes
|
2021-01-10 15:55:29 +01:00
|
|
|
|
|
|
|
#include "xevent.h"
|
|
|
|
*/
|
|
|
|
import "C"
|
|
|
|
|
|
|
|
import (
|
2021-02-14 14:40:17 +01:00
|
|
|
"strings"
|
2021-01-19 21:01:31 +01:00
|
|
|
"time"
|
2021-01-10 15:55:29 +01:00
|
|
|
"unsafe"
|
|
|
|
|
|
|
|
"github.com/kataras/go-events"
|
|
|
|
)
|
|
|
|
|
2021-02-28 17:22:55 +01:00
|
|
|
var Emmiter events.EventEmmiter
|
2021-01-19 21:01:31 +01:00
|
|
|
var file_chooser_dialog_window uint32 = 0
|
2021-01-10 15:55:29 +01:00
|
|
|
|
|
|
|
func init() {
|
2021-02-28 17:22:55 +01:00
|
|
|
Emmiter = events.New()
|
2021-01-10 15:55:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func EventLoop(display string) {
|
|
|
|
displayUnsafe := C.CString(display)
|
|
|
|
defer C.free(unsafe.Pointer(displayUnsafe))
|
|
|
|
|
|
|
|
C.XEventLoop(displayUnsafe)
|
|
|
|
}
|
|
|
|
|
|
|
|
//export goXEventCursorChanged
|
|
|
|
func goXEventCursorChanged(event C.XFixesCursorNotifyEvent) {
|
2021-02-28 17:22:55 +01:00
|
|
|
Emmiter.Emit("cursor-changed", uint64(event.cursor_serial))
|
2021-01-10 15:55:29 +01:00
|
|
|
}
|
|
|
|
|
2021-01-11 15:30:53 +01:00
|
|
|
//export goXEventClipboardUpdated
|
|
|
|
func goXEventClipboardUpdated() {
|
2021-02-28 17:22:55 +01:00
|
|
|
Emmiter.Emit("clipboard-updated")
|
2021-01-11 15:30:53 +01:00
|
|
|
}
|
|
|
|
|
2021-01-19 21:01:31 +01:00
|
|
|
//export goXEventConfigureNotify
|
2021-01-31 15:01:46 +01:00
|
|
|
func goXEventConfigureNotify(display *C.Display, window C.Window, name *C.char, role *C.char) {
|
|
|
|
if C.GoString(role) != "GtkFileChooserDialog" {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: Refactor. Right now processing of this dialog relies on identifying
|
|
|
|
// via its name. When that changes to role, this condition should be removed.
|
|
|
|
if !strings.HasPrefix(C.GoString(name), "Open File") {
|
2021-01-19 21:01:31 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
C.XFileChooserHide(display, window)
|
|
|
|
|
|
|
|
// Because first dialog is not put properly to background
|
|
|
|
time.Sleep(10 * time.Millisecond)
|
|
|
|
C.XFileChooserHide(display, window)
|
2021-01-20 23:47:49 +01:00
|
|
|
|
|
|
|
if file_chooser_dialog_window == 0 {
|
|
|
|
file_chooser_dialog_window = uint32(window)
|
2021-02-28 17:22:55 +01:00
|
|
|
Emmiter.Emit("file-chooser-dialog-opened")
|
2021-01-20 23:47:49 +01:00
|
|
|
}
|
2021-01-18 21:40:57 +01:00
|
|
|
}
|
|
|
|
|
2021-01-19 21:01:31 +01:00
|
|
|
//export goXEventUnmapNotify
|
|
|
|
func goXEventUnmapNotify(window C.Window) {
|
|
|
|
if uint32(window) != file_chooser_dialog_window {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-01-20 23:47:49 +01:00
|
|
|
file_chooser_dialog_window = 0
|
2021-02-28 17:22:55 +01:00
|
|
|
Emmiter.Emit("file-chooser-dialog-closed")
|
2021-01-12 00:09:43 +01:00
|
|
|
}
|
|
|
|
|
2021-01-10 15:55:29 +01:00
|
|
|
//export goXEventError
|
|
|
|
func goXEventError(event *C.XErrorEvent, message *C.char) {
|
2021-02-28 17:22:55 +01:00
|
|
|
Emmiter.Emit("event-error", uint8(event.error_code), C.GoString(message), uint8(event.request_code), uint8(event.minor_code))
|
2021-01-10 15:55:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//export goXEventActive
|
|
|
|
func goXEventActive() C.int {
|
|
|
|
return C.int(1)
|
|
|
|
}
|