From 4df5cd5e7b215fcafc352393362e08669f006359 Mon Sep 17 00:00:00 2001 From: David Turner Date: Fri, 16 Jan 2004 08:46:11 +0000 Subject: [PATCH] * src/base/ftoutln.c (ft_orientation_extremum_compute): fixing infinite loop bug ! --- src/base/ftoutln.c | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/src/base/ftoutln.c b/src/base/ftoutln.c index a0781dc3d..3c59e7c01 100644 --- a/src/base/ftoutln.c +++ b/src/base/ftoutln.c @@ -358,14 +358,11 @@ source->n_contours != target->n_contours ) return FT_Err_Invalid_Argument; - FT_ARRAY_COPY( target->points, source->points, - source->n_points ); + FT_ARRAY_COPY( target->points, source->points, source->n_points ); - FT_ARRAY_COPY( target->tags, source->tags, - source->n_points ); + FT_ARRAY_COPY( target->tags, source->tags, source->n_points ); - FT_ARRAY_COPY( target->contours, source->contours, - source->n_contours ); + FT_ARRAY_COPY( target->contours, source->contours, source->n_contours ); /* copy all flags, except the `FT_OUTLINE_OWNER' one */ is_owner = target->flags & FT_OUTLINE_OWNER; @@ -680,10 +677,12 @@ first = points + extremum->first; last = points + extremum->last; + prev = point; + next = point; + do { - prev = ( point == first ) ? last : point - 1; - + prev = ( prev == first ) ? last : prev - 1; if ( prev == point ) return FT_ORIENTATION_TRUETYPE; /* degenerate case */ @@ -691,8 +690,7 @@ do { - next = ( point == last ) ? first : point + 1; - + next = ( next == last ) ? first : next + 1; if ( next == point ) return FT_ORIENTATION_TRUETYPE; /* shouldn't happen */