From d446aa39a96a7498cdfaadfc7debaaf4c47b1414 Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Fri, 23 Apr 2021 03:02:06 +0900 Subject: [PATCH] internal/uidriver/glfw: Bug fix: Always wait for SetFramebuffer In case when the callback is not called, let's use timeout. Updates #1618 --- internal/uidriver/glfw/ui.go | 25 ++++++++++++++++--------- 1 file changed, 16 insertions(+), 9 deletions(-) diff --git a/internal/uidriver/glfw/ui.go b/internal/uidriver/glfw/ui.go index 599ef543d..c84b6d3bf 100644 --- a/internal/uidriver/glfw/ui.go +++ b/internal/uidriver/glfw/ui.go @@ -1208,15 +1208,22 @@ func (u *UserInterface) setWindowSize(width, height int, fullscreen bool) { ch <- struct{}{} }) u.window.SetSize(newW, newH) - if w, h := u.window.GetSize(); w != oldW || h != oldH { - event: - for { - glfw.PollEvents() - select { - case <-ch: - break event - default: - } + // Just after SetSize, GetSize is not reliable especially on Linux/Windows. + // Let's wait for FramebufferSize callback in any cases. + + // Use the timeout as FramebufferSize event might not be fired (#1618). + t := time.NewTimer(time.Second) + defer t.Stop() + + event: + for { + glfw.PollEvents() + select { + case <-ch: + break event + case <-t.C: + break event + default: } } u.window.SetFramebufferSizeCallback(nil)