From 4a1a586be9090b6513d467b8eaa658ad087b4dcb Mon Sep 17 00:00:00 2001 From: RuiwenTang Date: Fri, 5 Jul 2024 11:03:44 +0800 Subject: [PATCH] gl_engine: fix memory leak when rendering image --- src/renderer/gl_engine/tvgGlRenderer.cpp | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/renderer/gl_engine/tvgGlRenderer.cpp b/src/renderer/gl_engine/tvgGlRenderer.cpp index e040ce29..eec62995 100644 --- a/src/renderer/gl_engine/tvgGlRenderer.cpp +++ b/src/renderer/gl_engine/tvgGlRenderer.cpp @@ -950,7 +950,10 @@ bool GlRenderer::renderImage(void* data) auto task = new GlRenderTask(mPrograms[RT_Image].get()); task->setDrawDepth(drawDepth); - if (!sdata->geometry->draw(task, mGpuBuffer.get(), RenderUpdateFlag::Image)) return true; + if (!sdata->geometry->draw(task, mGpuBuffer.get(), RenderUpdateFlag::Image)) { + delete task; + return true; + } // matrix buffer {