forked from joejulian/gio
9bfa6bc1c2dca43312d3ba442b9004cb87fb2ff6
This fixes an Android regression introduced by
3e601e73c4
app: optimize window context locking
On Android, that change can leave the app window visible but unrendered:
the screen stays black instead of drawing the UI.
The regression is in app/window.go: Refresh can update the underlying
surface state without guaranteeing a subsequent Lock before rendering.
That is a problem for Android, where Refresh and Lock have distinct
roles:
- androidContext.Refresh stages the native window for the EGL surface
- androidContext.Lock performs CreateSurface, when needed, and MakeCurrent
In other words, after Refresh, Android may require another Lock before
GPU work can proceed correctly.
This patch keeps explicit locking, but avoids unconditional per-frame
Lock/Unlock calls. It adds a small amount of state to Window:
- ctxNeedsLock is set when creating a context
- ctxNeedsLock is set after Refresh
- ctxNeedsLock is set after explicit unlock/release paths
- Lock is called before GPU work only when ctxNeedsLock is true
That keeps the optimized steady-state path while restoring the required
Refresh -> Lock sequencing.
I also added a regression test for validateAndProcess that checks:
- Refresh forces a re-lock before drawing/present
- steady-state frames do not re-lock redundantly
Verification:
- go test ./app
Signed-off-by: Joe Julian <me@joejulian.name>
Gio - https://gioui.org
Immediate mode GUI programs in Go for Android, iOS, macOS, Linux, FreeBSD, OpenBSD, Windows, and WebAssembly (experimental).
Installation, examples, documentation
Go to gioui.org.
Issues
File bugs and TODOs through the issue tracker or send an email to ~eliasnaur/gio@todo.sr.ht. For general discussion, use the mailing list: ~eliasnaur/gio@lists.sr.ht.
Contributing
Post discussion to the mailing list and patches to gio-patches. No Sourcehut account is required and you can post without being subscribed.
See the contribution guide for more details.
An official GitHub mirror is available.
Tags
Pre-1.0 tags are provided for reference only, and do not designate releases with ongoing support. Bugfixes will not be backported to older tags.
Tags follow semantic versioning. In particular, as the major version is zero:
- breaking API or behavior changes will increment the minor version component.
- non-breaking changes will increment the patch version component.
Description
Languages
Go
89.6%
C
7%
Java
1.7%
Objective-C
1.6%