37ae98a926f5acc5461fc052eef26529375d6e0c — Chris Waldon 1 year, 8 months ago 25a3d97
content/news: add october newsletter

Signed-off-by: Chris Waldon <christopher.waldon.dev@gmail.com>
2 files changed, 73 insertions(+), 0 deletions(-)

A content/news/2022-10.md
M content/news/index.tmpl
A content/news/2022-10.md => content/news/2022-10.md +72 -0
@@ 0,0 1,72 @@
title: Newsletter, October 2022
shorttitle: October 2022
subtitle: Mipmaps and text patches

This month Elias upgraded our handling of image scaling by automatically generating mipmaps for all images. This ensures that images look good when downscaled, and also boosts performance when downscaling images. You don't need to make any application changes to take advantage of this new feature.

I (Chris) spent the past month entirely focused on font fallback and bidirectional text. It was tricky work, but satisfying, and yesterday I posted the [first patchset](https://lists.sr.ht/~eliasnaur/gio-patches/patches/36683) implementing both font fallback and bidirectional text support. The two features are tightly related, as they both involve enabling lines of text to contain substrings with varying fonts and metadata. Additionally, [benchmark results](https://paste.sr.ht/~whereswaldon/a5b314a3277c8f3f63d9d90f09cab95339322da7) indicate that the majority of text shaping use-cases were made significantly faster by these changes. I'd like to thank Plato Team for supporting the development of these critical text features.

## Sponsorship

This month, Gio thanks the following organizations and community members for their ongoing support!

Supporting the whole team:

- [Plato Team](https://www.platoapp.com/) via GitHub Sponsorship of Elias and Chris.
- [Tailscale](https://tailscale.com/) via OpenCollective.
- [Lucas Rodrigues](https://github.com/Inkeliz/) via GitHub Sponsorship of Gioui and Elias.
- [Denys Smirnov](https://github.com/dennwc) via OpenCollective.
- [Larry Clapp](https://github.com/theclapp) via GitHub Sponsorship of Elias and Chris.

Supporting a maintainer:

- [Matilda Tech](https://github.com/matildatech) via GitHub Sponsorship of Elias.
- [Fino Meng](https://github.com/finomeng) via GitHub Sponsorship of Elias.
- [Chris Waldon](https://github.com/whereswaldon) via GitHub Sponsorship of Elias.
- [Tom Ingleby](https://github.com/tingleby) via GitHub Sponsorship of Elias.
- [Tanguy Herrmann](https://github.com/dolanor) via GitHub Sponsorship of Elias.
- A number of anonymous community members.

Sponsorship money given to Gio enables Elias and I to cover the costs of running Gio's infrastructure, to pay for some of our time spent maintaining and improving Gio, and to plan for funding significant feature work. You can support Gio by contributing on [OpenCollective](https://opencollective.com/gioui) or [GitHub Sponsors](https://github.com/sponsors/gioui).

## core gio

As part of my work on text handling, I dug into `widget.Editor` and extensively tested its current behaviors, fixing some bugs along the way. Elias enabled mipmapping and ensured that Android devices default to the OpenGL backend like Linux currently does.

Chris Waldon:

- __`widget`__: use reliable text direction checks, not heuristics. This commit switches the way in which the editor and helper functions check for RTL text from a heuristic to using the actual text direction. [b46c0f59](https://git.sr.ht/~eliasnaur/gio/commit/b46c0f59)
- __`widget`__: test firstPos. This commit adds a test to lock in the correct behavior of the firstPos helper method. [1be58a2b](https://git.sr.ht/~eliasnaur/gio/commit/1be58a2b)
- __`widget`__: define incrementing combinedPos and test. This commit restructures seekPosition from a complex state-manipulating loop into a simple loop of iteratively applying an increment operation to the combinedPos. The increment operation itself is now tested, and much easier to understand. [b67b3229](https://git.sr.ht/~eliasnaur/gio/commit/b67b3229)
- __`widget`__: test and document clusterIndexFor. This commit adds documentation and tests for the clusterIndexFor helper, making it easier to understand what it does and how to use it safely. [64db3720](https://git.sr.ht/~eliasnaur/gio/commit/64db3720)
- __`widget`__: test positionGreaterOrEqual. This commit adds an exhaustive test case for the positionGreaterOrEqual helper function that our text widgets use to compare locations within shaped text. [dee3cc44](https://git.sr.ht/~eliasnaur/gio/commit/dee3cc44)
- __`widget`__: test and document seekPosition. This commit adds a test for the seekPosition helper, a function which can be used to move a combinedPos forward through a body of text until it approaches a position. [23406645](https://git.sr.ht/~eliasnaur/gio/commit/23406645)
- __`widget`__: redefine >= and ++ on combinedPos. This commit redefines incrementing a combinedPos to either move a single rune forward, *or* transition from EOL->BOL, *or* both. This allows traversal of lines without a trailing newline character to reach the position after the final glyph of content. Fixes [#400](https://todo.sr.ht/~eliasnaur/gio/400) [f7c14e99](https://git.sr.ht/~eliasnaur/gio/commit/f7c14e99)
- __`widget`__: adjust editor tests to new pos iteration. This commit fixes the expectations of our ligature iteration tests to match the new behavior of the text position iterator. Now the cursor can reach the position after the final glyph on a line, if that glyph is not a newline. [9f62230c](https://git.sr.ht/~eliasnaur/gio/commit/9f62230c)

Elias Naur:

- __`app`__: make OpenGL default on Android. Like commit [dbf6429](https://git.sr.ht/~eliasnaur/gio/commit/dbf64290265178823970cccf3e8c4a0b0aa45110), this change makes the OpenGL backend default for Android. [b707b199](https://git.sr.ht/~eliasnaur/gio/commit/b707b199)
- __`app`__: disable OpenGL backend when the `noopengl` tag is present. The tag `noopengl` is useful for testing the Vulkan backend which is no longer default. [e69ef4f0](https://git.sr.ht/~eliasnaur/gio/commit/e69ef4f0)
- __`gpu`__: implement automatic mipmaps for images. All GPU APIs except OpenGL ES 2 can generate mipmaps for textures. This trades 33% more GPU memory use for improved rendering quality and speed for downscaled images. [bebc73db](https://git.sr.ht/~eliasnaur/gio/commit/bebc73db)
- __`gesture,widget`__: detect multi-click on pointer.Press. References: [#455](https://todo.sr.ht/~eliasnaur/gio/455) [5c896eab](https://git.sr.ht/~eliasnaur/gio/commit/5c896eab)
- __`widget`__: implement triple click line selection in Editor. Fixes: [#455](https://todo.sr.ht/~eliasnaur/gio/455) [c67d8cde](https://git.sr.ht/~eliasnaur/gio/commit/c67d8cde)

Egon Elbre:

- __`f32`__: nicer Affine2D string formatting. [dead6e00](https://git.sr.ht/~eliasnaur/gio/commit/dead6e00)

## gio-x

Users of x have reported an error with ambiguous imports for a while, and this month I learned how to fix it. The problem was that we used to keep `gioui.org/x/{notify,haptic,pref,explorer}` in separate go modules because they each added significant dependencies. However, after Go 1.17 that wasn't necessary anymore so we consolidated everything to one module. This left the old modules still existing and available from the go module cache, so that running `go get gioui.org/x/notify@latest` had two candidates: the `notify` package in the `x` module and the old `x/notify` module. It took some research to discover the correct way to retract __every__ version of a module (thanks Dominik Honnef for the help), but now the old modules are no longer available and `go get` should succeed for any package in `x`.

Chris Waldon:

- __`richtext`__: fix interactive span aliasing. This commit fixes a subtle bug that only permitted a single interactive span per richtext.TextStyle. The loop iterating the spans copied the spans as a loop variable and assigned an important piece of tracking metadata only on the copy. This resulted in all interactive spans thinking they were the first, and thus the final span was the only active one. [5b57729](https://git.sr.ht/~whereswaldon/gio-x/commit/5b57729)
- __`notify`__: retract all old module versions. This commit adds back a temporary go.mod to gioui.org/x/notify in order to retract itself and all older versions. It will be removed in a subsequent commit. Fixes [#401](https://todo.sr.ht/~eliasnaur/gio/401) [67f8600](https://git.sr.ht/~whereswaldon/gio-x/commit/67f8600)
- __`notify`__: drop temporary go.{mod,sum}. [55202d2](https://git.sr.ht/~whereswaldon/gio-x/commit/55202d2)
- __`explorer,haptic,pref`__: add temporary retraction go.mods. This commit retracts all versions of explorer, haptic, and pref that were published as separate modules from gioui.org/x. [75f9807](https://git.sr.ht/~whereswaldon/gio-x/commit/75f9807)
- __`explorer,haptic,pref`__: drop temporary go.{mod,sum}. [d485904](https://git.sr.ht/~whereswaldon/gio-x/commit/d485904)

M content/news/index.tmpl => content/news/index.tmpl +1 -0
@@ 3,6 3,7 @@ title: Newsletter
subtitle: Gioverse news
hidechildren: true
    - "./2022-10"
    - "./2022-09"
    - "./2022-08"
    - "./2022-07"