Fixes memory leaks due to not releasing font images properly.

This commit is contained in:
Olli Wang 2022-03-26 23:10:06 +08:00
parent 5f65b43f7a
commit 4e42b6c659

View File

@ -396,6 +396,7 @@ void nvgEndFrame(NVGcontext* ctx)
ctx->params.renderFlush(ctx->params.userPtr); ctx->params.renderFlush(ctx->params.userPtr);
if (ctx->fontImageIdx != 0) { if (ctx->fontImageIdx != 0) {
int fontImage = ctx->fontImages[ctx->fontImageIdx]; int fontImage = ctx->fontImages[ctx->fontImageIdx];
ctx->fontImages[ctx->fontImageIdx] = 0;
int i, j, iw, ih; int i, j, iw, ih;
// delete images that smaller than current one // delete images that smaller than current one
if (fontImage == 0) if (fontImage == 0)
@ -404,20 +405,19 @@ void nvgEndFrame(NVGcontext* ctx)
for (i = j = 0; i < ctx->fontImageIdx; i++) { for (i = j = 0; i < ctx->fontImageIdx; i++) {
if (ctx->fontImages[i] != 0) { if (ctx->fontImages[i] != 0) {
int nw, nh; int nw, nh;
nvgImageSize(ctx, ctx->fontImages[i], &nw, &nh); int image = ctx->fontImages[i];
ctx->fontImages[i] = 0;
nvgImageSize(ctx, image, &nw, &nh);
if (nw < iw || nh < ih) if (nw < iw || nh < ih)
nvgDeleteImage(ctx, ctx->fontImages[i]); nvgDeleteImage(ctx, image);
else else
ctx->fontImages[j++] = ctx->fontImages[i]; ctx->fontImages[j++] = image;
} }
} }
// make current font image to first // make current font image to first
ctx->fontImages[j++] = ctx->fontImages[0]; ctx->fontImages[j] = ctx->fontImages[0];
ctx->fontImages[0] = fontImage; ctx->fontImages[0] = fontImage;
ctx->fontImageIdx = 0; ctx->fontImageIdx = 0;
// clear all images after j
for (i = j; i < NVG_MAX_FONTIMAGES; i++)
ctx->fontImages[i] = 0;
} }
} }