[glyf] Simplify contour end logic

So no need for infinite loop here
This commit is contained in:
Ebrahim Byagowi 2020-02-26 16:27:04 +03:30
parent 132fcfbc47
commit 4cdaa9d1f4
1 changed files with 24 additions and 31 deletions

View File

@ -1054,8 +1054,6 @@ struct glyf
draw_helper.init (funcs, user_data); draw_helper.init (funcs, user_data);
first_oncurve = first_offcurve = last_offcurve = optional_point_t (); first_oncurve = first_offcurve = last_offcurve = optional_point_t ();
} }
void end_of_contour ()
{ first_oncurve = first_offcurve = last_offcurve = optional_point_t (); }
/* based on https://github.com/RazrFalcon/ttf-parser/blob/master/src/glyf.rs#L292 */ /* based on https://github.com/RazrFalcon/ttf-parser/blob/master/src/glyf.rs#L292 */
void consume_point (const contour_point_t &point) void consume_point (const contour_point_t &point)
@ -1114,8 +1112,6 @@ struct glyf
} }
if (point.is_end_point) if (point.is_end_point)
{
for (;;)
{ {
if (!first_offcurve.is_null && !last_offcurve.is_null) if (!first_offcurve.is_null && !last_offcurve.is_null)
{ {
@ -1123,29 +1119,26 @@ struct glyf
draw_helper.quadratic_to (font->em_scalef_x (last_offcurve.x), font->em_scalef_y (last_offcurve.y), draw_helper.quadratic_to (font->em_scalef_x (last_offcurve.x), font->em_scalef_y (last_offcurve.y),
font->em_scalef_x (mid.x), font->em_scalef_y (mid.y)); font->em_scalef_x (mid.x), font->em_scalef_y (mid.y));
last_offcurve = optional_point_t (); last_offcurve = optional_point_t ();
/* now check the rest */
} }
else if (!first_offcurve.is_null && last_offcurve.is_null)
if (!first_offcurve.is_null && last_offcurve.is_null)
{ {
if (!first_oncurve.is_null) if (!first_oncurve.is_null)
draw_helper.quadratic_to (font->em_scalef_x (first_offcurve.x), font->em_scalef_y (first_offcurve.y), draw_helper.quadratic_to (font->em_scalef_x (first_offcurve.x), font->em_scalef_y (first_offcurve.y),
font->em_scalef_x (first_oncurve.x), font->em_scalef_y (first_oncurve.y)); font->em_scalef_x (first_oncurve.x), font->em_scalef_y (first_oncurve.y));
break;
} }
else if (first_offcurve.is_null && !last_offcurve.is_null) else if (first_offcurve.is_null && !last_offcurve.is_null)
{ {
if (!first_oncurve.is_null) if (!first_oncurve.is_null)
draw_helper.quadratic_to (font->em_scalef_x (last_offcurve.x), font->em_scalef_y (last_offcurve.y), draw_helper.quadratic_to (font->em_scalef_x (last_offcurve.x), font->em_scalef_y (last_offcurve.y),
font->em_scalef_x (first_oncurve.x), font->em_scalef_y (first_oncurve.y)); font->em_scalef_x (first_oncurve.x), font->em_scalef_y (first_oncurve.y));
break;
} }
else /* first_offcurve.is_null && last_offcurve.is_null */ else /* first_offcurve.is_null && last_offcurve.is_null */
{
if (!first_oncurve.is_null) if (!first_oncurve.is_null)
draw_helper.line_to (font->em_scalef_x (first_oncurve.x), font->em_scalef_y (first_oncurve.y)); draw_helper.line_to (font->em_scalef_x (first_oncurve.x), font->em_scalef_y (first_oncurve.y));
break;
} first_oncurve = first_offcurve = last_offcurve = optional_point_t ();
}
end_of_contour ();
draw_helper.end_path (); draw_helper.end_path ();
} }
} }