Fix segfault with empty buffer in hb_shape_plan_execute()
Move the empty-buffer check from hb_shape_full() to hb_shape_plan_execute(). Reported by Simon Cozens.
This commit is contained in:
parent
432ffc47a4
commit
26ba4d1e1f
|
@ -293,8 +293,13 @@ hb_shape_plan_execute (hb_shape_plan_t *shape_plan,
|
||||||
num_features,
|
num_features,
|
||||||
shape_plan->shaper_func);
|
shape_plan->shaper_func);
|
||||||
|
|
||||||
if (unlikely (hb_object_is_inert (shape_plan) ||
|
if (unlikely (!buffer->len))
|
||||||
hb_object_is_inert (buffer)))
|
return true;
|
||||||
|
|
||||||
|
assert (!hb_object_is_inert (buffer));
|
||||||
|
assert (buffer->content_type == HB_BUFFER_CONTENT_TYPE_UNICODE);
|
||||||
|
|
||||||
|
if (unlikely (hb_object_is_inert (shape_plan)))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
assert (shape_plan->face_unsafe == font->face);
|
assert (shape_plan->face_unsafe == font->face);
|
||||||
|
|
|
@ -371,11 +371,6 @@ hb_shape_full (hb_font_t *font,
|
||||||
unsigned int num_features,
|
unsigned int num_features,
|
||||||
const char * const *shaper_list)
|
const char * const *shaper_list)
|
||||||
{
|
{
|
||||||
if (unlikely (!buffer->len))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
assert (buffer->content_type == HB_BUFFER_CONTENT_TYPE_UNICODE);
|
|
||||||
|
|
||||||
hb_shape_plan_t *shape_plan = hb_shape_plan_create_cached (font->face, &buffer->props, features, num_features, shaper_list);
|
hb_shape_plan_t *shape_plan = hb_shape_plan_create_cached (font->face, &buffer->props, features, num_features, shaper_list);
|
||||||
hb_bool_t res = hb_shape_plan_execute (shape_plan, font, buffer, features, num_features);
|
hb_bool_t res = hb_shape_plan_execute (shape_plan, font, buffer, features, num_features);
|
||||||
hb_shape_plan_destroy (shape_plan);
|
hb_shape_plan_destroy (shape_plan);
|
||||||
|
|
Loading…
Reference in New Issue