From e4f26f3844c77b8e10dc49f0db95ee34386b3c00 Mon Sep 17 00:00:00 2001 From: xengineering Date: Sun, 14 Jul 2024 15:26:59 +0200 Subject: WIP: Update to gioui.org v0.7.1 TODO: There is a race condition. It has to be fixed since the program immediately crashes. Building the software is possible. --- limox.go | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) (limited to 'limox.go') diff --git a/limox.go b/limox.go index 0b5c2ac..82bb24e 100644 --- a/limox.go +++ b/limox.go @@ -4,7 +4,7 @@ import ( "log" "gioui.org/app" - "gioui.org/io/system" + "gioui.org/io/event" "gioui.org/op" "gioui.org/unit" "gioui.org/widget" @@ -35,16 +35,15 @@ type Limox struct { func NewLimox() Limox { l := Limox{ - Window: app.NewWindow( - app.Title("LimoX"), - app.Size(unit.Dp(400), unit.Dp(600)), - ), + Window: new(app.Window), Operations: op.Ops{}, Theme: material.NewTheme(), sessionOut: make(chan any), State: Disconnected, } + l.Window.Option(app.Title("LimoX")) + l.Window.Option(app.Size(unit.Dp(400), unit.Dp(600))) l.JidEditor.SetText(getLastJid()) l.PwdEditor.SetText(getLastPwd()) @@ -52,16 +51,19 @@ func NewLimox() Limox { } func (l *Limox) run() error { + c := make(chan event.Event) + go func() { + for { + c <- l.Window.Event() + } + }() for { select { - case e := <-l.Window.Events(): + case e := <-c: switch e := e.(type) { - case system.DestroyEvent: + case app.DestroyEvent: return e.Err - case system.FrameEvent: - if l.MainButton.Clicked() { - l.buttonCallback() - } + case app.FrameEvent: l.draw(e) } case data := <-l.sessionOut: -- cgit v1.2.3-70-g09d2