]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
gfxmenu: fix memory leak
authorAndrei Borzenkov <arvidjaar@gmail.com>
Sat, 9 Jan 2016 10:43:04 +0000 (13:43 +0300)
committerAndrei Borzenkov <arvidjaar@gmail.com>
Sat, 9 Jan 2016 10:55:28 +0000 (13:55 +0300)
Found by: Coverity scan.
CID: 73766

grub-core/gfxmenu/font.c

index 64d52670bfbcddc9e1f5dafeeba6981afab98455..756c24f20c466e837a1961a63c5223570a9849b0 100644 (file)
@@ -45,6 +45,7 @@ grub_font_draw_string (const char *str, grub_font_t font,
   grub_uint32_t *logical;
   grub_ssize_t logical_len, visual_len;
   struct grub_unicode_glyph *visual, *ptr;
+  grub_err_t err;
 
   logical_len = grub_utf8_to_ucs4_alloc (str, &logical, 0);
   if (logical_len < 0)
@@ -56,24 +57,28 @@ grub_font_draw_string (const char *str, grub_font_t font,
   if (visual_len < 0)
     return grub_errno;
 
+  err = GRUB_ERR_NONE;
   for (ptr = visual, x = left_x; ptr < visual + visual_len; ptr++)
     {
-      grub_err_t err;
       struct grub_font_glyph *glyph;
       glyph = grub_font_construct_glyph (font, ptr);
       if (!glyph)
-       return grub_errno;
+       {
+         err = grub_errno;
+         goto out;
+       }
       err = grub_font_draw_glyph (glyph, color, x, baseline_y);
-      x += glyph->device_width;
       if (err)
-       return err;
+       goto out;
+      x += glyph->device_width;
     }
 
+out:
   for (ptr = visual; ptr < visual + visual_len; ptr++)
     grub_unicode_destroy_glyph (ptr);
   grub_free (visual);
 
-  return GRUB_ERR_NONE;
+  return err;
 }
 
 /* Get the width in pixels of the specified UTF-8 string, when rendered in