Fix few memory errors
This commit is contained in:
parent
7c464a1ec5
commit
eaa1f9a64b
3 changed files with 13 additions and 8 deletions
|
@ -63,10 +63,10 @@ grub_font_draw_string (const char *str, grub_font_t font,
|
||||||
if (!glyph)
|
if (!glyph)
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
err = grub_font_draw_glyph (glyph, color, x, baseline_y);
|
err = grub_font_draw_glyph (glyph, color, x, baseline_y);
|
||||||
|
x += glyph->device_width;
|
||||||
grub_free (glyph);
|
grub_free (glyph);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
x += glyph->device_width;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
grub_free (visual);
|
grub_free (visual);
|
||||||
|
|
|
@ -130,13 +130,16 @@ grub_unicode_glyph_dup (const struct grub_unicode_glyph *in)
|
||||||
if (!out)
|
if (!out)
|
||||||
return NULL;
|
return NULL;
|
||||||
grub_memcpy (out, in, sizeof (*in));
|
grub_memcpy (out, in, sizeof (*in));
|
||||||
out->combining = grub_malloc (in->ncomb * sizeof (*in));
|
if (in->combining)
|
||||||
if (!out->combining)
|
|
||||||
{
|
{
|
||||||
grub_free (out);
|
out->combining = grub_malloc (in->ncomb * sizeof (*in));
|
||||||
return NULL;
|
if (!out->combining)
|
||||||
|
{
|
||||||
|
grub_free (out);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
grub_memcpy (out->combining, in->combining, in->ncomb * sizeof (*in));
|
||||||
}
|
}
|
||||||
grub_memcpy (out->combining, in->combining, in->ncomb * sizeof (*in));
|
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -282,7 +282,8 @@ grub_utf8_to_ucs4_alloc (const char *msg, grub_uint32_t **unicode_msg,
|
||||||
msg_len = grub_utf8_to_ucs4 (*unicode_msg, msg_len,
|
msg_len = grub_utf8_to_ucs4 (*unicode_msg, msg_len,
|
||||||
(grub_uint8_t *) msg, -1, 0);
|
(grub_uint8_t *) msg, -1, 0);
|
||||||
|
|
||||||
*last_position = *unicode_msg + msg_len;
|
if (last_position)
|
||||||
|
*last_position = *unicode_msg + msg_len;
|
||||||
|
|
||||||
return msg_len;
|
return msg_len;
|
||||||
}
|
}
|
||||||
|
@ -529,13 +530,14 @@ grub_unicode_aglomerate_comb (const grub_uint32_t *in, grub_size_t inlen,
|
||||||
|| comb_type == GRUB_UNICODE_COMB_ME
|
|| comb_type == GRUB_UNICODE_COMB_ME
|
||||||
|| comb_type == GRUB_UNICODE_COMB_MN)
|
|| comb_type == GRUB_UNICODE_COMB_MN)
|
||||||
last_comb_pointer = out->ncomb;
|
last_comb_pointer = out->ncomb;
|
||||||
n = grub_realloc (out->combining,
|
n = grub_realloc (out->combining,
|
||||||
sizeof (n[0]) * (out->ncomb + 1));
|
sizeof (n[0]) * (out->ncomb + 1));
|
||||||
if (!n)
|
if (!n)
|
||||||
{
|
{
|
||||||
grub_errno = GRUB_ERR_NONE;
|
grub_errno = GRUB_ERR_NONE;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
out->combining = n;
|
||||||
|
|
||||||
for (j = last_comb_pointer; j < out->ncomb; j++)
|
for (j = last_comb_pointer; j < out->ncomb; j++)
|
||||||
if (out->combining[j].type > comb_type)
|
if (out->combining[j].type > comb_type)
|
||||||
|
|
Loading…
Reference in a new issue