From af20f7e9b5e1c1f035148b72382019b08122e97d Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Sun, 3 Apr 2022 20:25:22 -0400 Subject: [PATCH] gl: Don't leak big glyphs We were never resetting the accessed bit of glyphs that are big enough to be stored individually, so these would just accumulate and never be dropped. --- gsk/gl/gskgltexturelibrary.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/gsk/gl/gskgltexturelibrary.c b/gsk/gl/gskgltexturelibrary.c index 3e6463a848..9960985814 100644 --- a/gsk/gl/gskgltexturelibrary.c +++ b/gsk/gl/gskgltexturelibrary.c @@ -108,11 +108,17 @@ gsk_gl_texture_library_real_compact (GskGLTextureLibrary *self, atlased++; } } - else if (!entry->accessed) + else { - gsk_gl_driver_release_texture (self->driver, entry->texture); - g_hash_table_iter_remove (&iter); - dropped++; + if (!entry->accessed) + { + gsk_gl_driver_release_texture (self->driver, entry->texture); + g_hash_table_iter_remove (&iter); + dropped++; + } + + if (periodic_scan) + entry->accessed = FALSE; } } -- 2.30.2