reformatting, changing the FT_Outline structure:
- "flags" have been renamed to "tags" - "outline_flags" have been renamed to "flags" Look for more re-formatting today..
This commit is contained in:
parent
291afa0992
commit
41dbcbf628
@ -79,7 +79,7 @@
|
||||
|
||||
#endif
|
||||
|
||||
#define PIXEL_BITS 6
|
||||
#define PIXEL_BITS 7
|
||||
#define ONE_PIXEL (1L << PIXEL_BITS)
|
||||
#define PIXEL_MASK (-1L << PIXEL_BITS)
|
||||
#define TRUNC(x) ((x) >> PIXEL_BITS)
|
||||
@ -88,6 +88,8 @@
|
||||
#define CEILING(x) (((x)+ONE_PIXEL-1) & -ONE_PIXEL)
|
||||
#define ROUND(x) (((x)+ONE_PIXEL/2) & -ONE_PIXEL)
|
||||
|
||||
#define UPSCALE(x) (PIXEL_BITS >= 6 ? (x) << (PIXEL_BITS-6) : (x) >> (6-PIXEL_BITS))
|
||||
|
||||
/****************************************************************************/
|
||||
/* */
|
||||
/* INITIALIZE THE CELLS TABLE */
|
||||
@ -137,10 +139,10 @@ void compute_cbox( RAS_ARG_ FT_Outline* outline )
|
||||
}
|
||||
|
||||
/* truncate the bounding box to integer pixels */
|
||||
ras.min_ex = TRUNC( ras.min_ex );
|
||||
ras.min_ey = TRUNC( ras.min_ey );
|
||||
ras.max_ex = TRUNC( CEILING( ras.max_ex ) );
|
||||
ras.max_ey = TRUNC( CEILING( ras.max_ey ) );
|
||||
ras.min_ex = ras.min_ex >> 6;
|
||||
ras.min_ey = ras.min_ey >> 6;
|
||||
ras.max_ex = ( ras.max_ex+63 ) >> 6;
|
||||
ras.max_ey = ( ras.max_ey+63 ) >> 6;
|
||||
}
|
||||
|
||||
|
||||
@ -484,7 +486,7 @@ int render_conic( RAS_ARG_ FT_Vector* control, FT_Vector* to )
|
||||
}
|
||||
|
||||
if (level <= 1)
|
||||
return render_line( RAS_VAR_ to->x, to->y );
|
||||
return render_line( RAS_VAR_ UPSCALE(to->x), UPSCALE(to->y) );
|
||||
|
||||
arc = ras.bez_stack;
|
||||
arc[0] = *to;
|
||||
@ -492,6 +494,11 @@ int render_conic( RAS_ARG_ FT_Vector* control, FT_Vector* to )
|
||||
arc[2].x = ras.x;
|
||||
arc[2].y = ras.y;
|
||||
|
||||
arc[0].x = UPSCALE(arc[0].x);
|
||||
arc[0].y = UPSCALE(arc[0].y);
|
||||
arc[1].x = UPSCALE(arc[1].x);
|
||||
arc[1].y = UPSCALE(arc[1].y);
|
||||
|
||||
levels = ras.lev_stack;
|
||||
top = 0;
|
||||
levels[0] = level;
|
||||
@ -573,7 +580,7 @@ int render_cubic( RAS_ARG_ FT_Vector* control1,
|
||||
}
|
||||
|
||||
if (level <= 1)
|
||||
return render_line( RAS_VAR_ to->x, to->y );
|
||||
return render_line( RAS_VAR_ UPSCALE(to->x), UPSCALE(to->y) );
|
||||
|
||||
arc = ras.bez_stack;
|
||||
arc[0] = *to;
|
||||
@ -582,6 +589,13 @@ int render_cubic( RAS_ARG_ FT_Vector* control1,
|
||||
arc[3].x = ras.x;
|
||||
arc[3].y = ras.y;
|
||||
|
||||
arc[0].x = UPSCALE(arc[0].x);
|
||||
arc[0].y = UPSCALE(arc[0].y);
|
||||
arc[1].x = UPSCALE(arc[1].x);
|
||||
arc[1].y = UPSCALE(arc[1].y);
|
||||
arc[2].x = UPSCALE(arc[2].x);
|
||||
arc[2].y = UPSCALE(arc[2].y);
|
||||
|
||||
levels = ras.lev_stack;
|
||||
top = 0;
|
||||
levels[0] = level;
|
||||
@ -801,7 +815,7 @@ int check_sort( PCell cells, int count )
|
||||
v_start = v_control = v_first;
|
||||
|
||||
point = outline->points + first;
|
||||
tags = outline->flags + first;
|
||||
tags = outline->tags + first;
|
||||
tag = FT_CURVE_TAG( tags[0] );
|
||||
|
||||
/* A contour cannot start with a cubic control point! */
|
||||
@ -812,7 +826,7 @@ int check_sort( PCell cells, int count )
|
||||
if ( tag == FT_Curve_Tag_Conic )
|
||||
{
|
||||
/* first point is conic control. Yes, this happens. */
|
||||
if ( FT_CURVE_TAG( outline->flags[last] ) == FT_Curve_Tag_On )
|
||||
if ( FT_CURVE_TAG( outline->tags[last] ) == FT_Curve_Tag_On )
|
||||
{
|
||||
/* start at last point if it is on the curve */
|
||||
v_start = v_last;
|
||||
@ -947,7 +961,7 @@ int check_sort( PCell cells, int count )
|
||||
FT_Vector v_start;
|
||||
|
||||
FT_Vector* point;
|
||||
char* flags;
|
||||
char* tags;
|
||||
|
||||
int n; /* index of contour in outline */
|
||||
int first; /* index of first point in contour */
|
||||
@ -973,7 +987,7 @@ int check_sort( PCell cells, int count )
|
||||
|
||||
v_start = v_control = v_first;
|
||||
|
||||
tag = FT_CURVE_TAG( outline->flags[first] );
|
||||
tag = FT_CURVE_TAG( outline->tags[first] );
|
||||
index = first;
|
||||
|
||||
/* A contour cannot start with a cubic control point! */
|
||||
@ -987,7 +1001,7 @@ int check_sort( PCell cells, int count )
|
||||
if ( tag == FT_Curve_Tag_Conic )
|
||||
{
|
||||
/* first point is conic control. Yes, this happens. */
|
||||
if ( FT_CURVE_TAG( outline->flags[last] ) == FT_Curve_Tag_On )
|
||||
if ( FT_CURVE_TAG( outline->tags[last] ) == FT_Curve_Tag_On )
|
||||
{
|
||||
/* start at last point if it is on the curve */
|
||||
v_start = v_last;
|
||||
@ -1015,7 +1029,7 @@ int check_sort( PCell cells, int count )
|
||||
return error;
|
||||
|
||||
point = outline->points + first;
|
||||
flags = outline->flags + first;
|
||||
tags = outline->tags + first;
|
||||
|
||||
/* now process each contour point individually */
|
||||
|
||||
@ -1023,9 +1037,9 @@ int check_sort( PCell cells, int count )
|
||||
{
|
||||
index++;
|
||||
point++;
|
||||
flags++;
|
||||
tags++;
|
||||
|
||||
tag = FT_CURVE_TAG( flags[0] );
|
||||
tag = FT_CURVE_TAG( tags[0] );
|
||||
|
||||
switch ( phase )
|
||||
{
|
||||
@ -1113,7 +1127,7 @@ int check_sort( PCell cells, int count )
|
||||
/* end of contour, close curve cleanly */
|
||||
error = 0;
|
||||
|
||||
tag = FT_CURVE_TAG( outline->flags[first] );
|
||||
tag = FT_CURVE_TAG( outline->tags[first] );
|
||||
|
||||
switch ( phase )
|
||||
{
|
||||
@ -1154,13 +1168,17 @@ int check_sort( PCell cells, int count )
|
||||
int Move_To( FT_Vector* to,
|
||||
FT_Raster raster )
|
||||
{
|
||||
TPos x, y;
|
||||
|
||||
/* record current cell, if any */
|
||||
record_cell( (PRaster)raster );
|
||||
|
||||
/* start to a new position */
|
||||
start_cell( (PRaster)raster, TRUNC(to->x), TRUNC(to->y) );
|
||||
((PRaster)raster)->x = to->x;
|
||||
((PRaster)raster)->y = to->y;
|
||||
x = UPSCALE(to->x);
|
||||
y = UPSCALE(to->y);
|
||||
start_cell( (PRaster)raster, TRUNC(x), TRUNC(y) );
|
||||
((PRaster)raster)->x = x;
|
||||
((PRaster)raster)->y = y;
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -1169,7 +1187,7 @@ int check_sort( PCell cells, int count )
|
||||
int Line_To( FT_Vector* to,
|
||||
FT_Raster raster )
|
||||
{
|
||||
return render_line( (PRaster)raster, to->x, to->y );
|
||||
return render_line( (PRaster)raster, UPSCALE(to->x), UPSCALE(to->y) );
|
||||
}
|
||||
|
||||
|
||||
@ -1262,7 +1280,7 @@ int check_sort( PCell cells, int count )
|
||||
/* */
|
||||
|
||||
coverage = area >> (PIXEL_BITS*2+1-8); /* use range 0..256 */
|
||||
if ( ras.outline.outline_flags & ft_outline_even_odd_fill )
|
||||
if ( ras.outline.flags & ft_outline_even_odd_fill )
|
||||
{
|
||||
if (coverage < 0)
|
||||
coverage = -coverage;
|
||||
@ -1285,7 +1303,7 @@ int check_sort( PCell cells, int count )
|
||||
coverage = 255;
|
||||
}
|
||||
|
||||
if (area)
|
||||
if (coverage)
|
||||
{
|
||||
/* see if we can add this span to the current list */
|
||||
count = ras.num_gray_spans;
|
||||
|
@ -158,11 +158,11 @@
|
||||
if ( error )
|
||||
return error;
|
||||
|
||||
glyph->outline.outline_flags |= ft_outline_single_pass |
|
||||
glyph->outline.flags |= ft_outline_single_pass |
|
||||
ft_outline_ignore_dropouts;
|
||||
|
||||
if (force_low)
|
||||
glyph->outline.outline_flags &= ~ft_outline_high_precision;
|
||||
glyph->outline.flags &= ~ft_outline_high_precision;
|
||||
|
||||
/* debugging */
|
||||
#if 0
|
||||
@ -183,9 +183,9 @@
|
||||
&outlines[cur_glyph] );
|
||||
|
||||
/* copy the glyph outline into it */
|
||||
glyph->outline.outline_flags |= ft_outline_single_pass;
|
||||
glyph->outline.flags |= ft_outline_single_pass;
|
||||
if (force_low)
|
||||
glyph->outline.outline_flags &= ~ft_outline_high_precision;
|
||||
glyph->outline.flags &= ~ft_outline_high_precision;
|
||||
|
||||
FT_Copy_Outline( &glyph->outline, &outlines[cur_glyph] );
|
||||
|
||||
@ -218,7 +218,7 @@
|
||||
|
||||
FT_Error ConvertRaster( int index )
|
||||
{
|
||||
outlines[index].outline_flags |= ~ft_outline_single_pass;
|
||||
outlines[index].flags |= ~ft_outline_single_pass;
|
||||
if (use_grays)
|
||||
return grays_raster_render( &raster, &outlines[index], &Bit );
|
||||
else
|
||||
|
@ -189,7 +189,7 @@
|
||||
memset( bit_buffer, 0, size );
|
||||
|
||||
if (low_prec)
|
||||
glyph->outline.outline_flags &= ~ft_outline_high_precision;
|
||||
glyph->outline.flags &= ~ft_outline_high_precision;
|
||||
|
||||
if (use_grays & gray_render)
|
||||
error = grays_raster_render( &raster, &glyph->outline, &bit2 );
|
||||
|
@ -224,36 +224,36 @@
|
||||
/* in FreeType 1.x. */
|
||||
/* */
|
||||
/* <Fields> */
|
||||
/* n_contours :: The number of contours in the outline. */
|
||||
/* n_contours :: The number of contours in the outline. */
|
||||
/* */
|
||||
/* n_points :: The number of points in the outline. */
|
||||
/* n_points :: The number of points in the outline. */
|
||||
/* */
|
||||
/* points :: A pointer to an array of `n_points' FT_Vector */
|
||||
/* elements, giving the outline's point */
|
||||
/* coordinates. */
|
||||
/* points :: A pointer to an array of `n_points' FT_Vector */
|
||||
/* elements, giving the outline's point */
|
||||
/* coordinates. */
|
||||
/* */
|
||||
/* flags :: A pointer to an array of `n_points' chars, */
|
||||
/* giving each outline point's type. If bit 0 is */
|
||||
/* set, the point is `off' the curve, i.e., a */
|
||||
/* Bezier control point, while it is `on' when */
|
||||
/* unset. */
|
||||
/* tags :: A pointer to an array of `n_points' chars, */
|
||||
/* giving each outline point's type. If bit 0 is */
|
||||
/* unset, the point is 'off' the curve, i.e. a */
|
||||
/* Bezier control point, while it is `on' when */
|
||||
/* unset. */
|
||||
/* */
|
||||
/* Bit 1 is meaningful for `off' points only. If */
|
||||
/* set, it indicates a third-order Bezier arc */
|
||||
/* control point; and a second-order control point */
|
||||
/* if unset. */
|
||||
/* Bit 1 is meaningful for `off' points only. If */
|
||||
/* set, it indicates a third-order Bezier arc */
|
||||
/* control point; and a second-order control point */
|
||||
/* if unset. */
|
||||
/* */
|
||||
/* contours :: An array of `n_contours' shorts, giving the end */
|
||||
/* point of each contour within the outline. For */
|
||||
/* example, the first contour is defined by the */
|
||||
/* points `0' to `contours[0]', the second one is */
|
||||
/* defined by the points `contours[0]+1' to */
|
||||
/* `contours[1]', etc. */
|
||||
/* contours :: An array of `n_contours' shorts, giving the end */
|
||||
/* point of each contour within the outline. For */
|
||||
/* example, the first contour is defined by the */
|
||||
/* points `0' to `contours[0]', the second one is */
|
||||
/* defined by the points `contours[0]+1' to */
|
||||
/* `contours[1]', etc. */
|
||||
/* */
|
||||
/* outline_flags :: a set of bit flags used to characterize the */
|
||||
/* outline and give hints to the scan-converter */
|
||||
/* and hinter on how to convert/grid-fit it.. */
|
||||
/* see FT_Outline_Flags.. */
|
||||
/* flags :: a set of bit flags used to characterize the */
|
||||
/* outline and give hints to the scan-converter */
|
||||
/* and hinter on how to convert/grid-fit it.. */
|
||||
/* see FT_Outline_Flags.. */
|
||||
/* */
|
||||
typedef struct FT_Outline_
|
||||
{
|
||||
@ -261,10 +261,10 @@
|
||||
short n_points; /* number of points in the glyph */
|
||||
|
||||
FT_Vector* points; /* the outline's points */
|
||||
char* flags; /* the points flags */
|
||||
char* tags; /* the points flags */
|
||||
short* contours; /* the contour end points */
|
||||
|
||||
int outline_flags; /* outline masks */
|
||||
int flags; /* outline masks */
|
||||
|
||||
} FT_Outline;
|
||||
|
||||
|
@ -398,7 +398,7 @@
|
||||
if ( y < cbox.yMin ) cbox.yMin = y;
|
||||
if ( y > cbox.yMax ) cbox.yMax = y;
|
||||
|
||||
if ( FT_CURVE_TAG( outline->flags[n] ) == FT_Curve_Tag_On )
|
||||
if ( FT_CURVE_TAG( outline->tags[n] ) == FT_Curve_Tag_On )
|
||||
{
|
||||
/* update bbox for `on' points only */
|
||||
if ( x < bbox.xMin ) bbox.xMin = x;
|
||||
|
@ -2053,7 +2053,7 @@
|
||||
FT_Vector v_start;
|
||||
|
||||
FT_Vector* point;
|
||||
char* flags;
|
||||
char* tags;
|
||||
|
||||
int n; /* index of contour in outline */
|
||||
int first; /* index of first point in contour */
|
||||
@ -2079,7 +2079,7 @@
|
||||
|
||||
v_start = v_control = v_first;
|
||||
|
||||
tag = FT_CURVE_TAG( outline->flags[first] );
|
||||
tag = FT_CURVE_TAG( outline->tags[first] );
|
||||
index = first;
|
||||
|
||||
/* A contour cannot start with a cubic control point! */
|
||||
@ -2093,7 +2093,7 @@
|
||||
if ( tag == FT_Curve_Tag_Conic )
|
||||
{
|
||||
/* first point is conic control. Yes, this happens. */
|
||||
if ( FT_CURVE_TAG( outline->flags[last] ) == FT_Curve_Tag_On )
|
||||
if ( FT_CURVE_TAG( outline->tags[last] ) == FT_Curve_Tag_On )
|
||||
{
|
||||
/* start at last point if it is on the curve */
|
||||
v_start = v_last;
|
||||
@ -2121,7 +2121,7 @@
|
||||
return error;
|
||||
|
||||
point = outline->points + first;
|
||||
flags = outline->flags + first;
|
||||
tags = outline->tags + first;
|
||||
|
||||
/* now process each contour point individually */
|
||||
|
||||
@ -2129,9 +2129,9 @@
|
||||
{
|
||||
index++;
|
||||
point++;
|
||||
flags++;
|
||||
tags++;
|
||||
|
||||
tag = FT_CURVE_TAG( flags[0] );
|
||||
tag = FT_CURVE_TAG( tags[0] );
|
||||
|
||||
switch ( phase )
|
||||
{
|
||||
@ -2219,7 +2219,7 @@
|
||||
/* end of contour, close curve cleanly */
|
||||
error = 0;
|
||||
|
||||
tag = FT_CURVE_TAG( outline->flags[first] );
|
||||
tag = FT_CURVE_TAG( outline->tags[first] );
|
||||
|
||||
switch ( phase )
|
||||
{
|
||||
@ -2310,18 +2310,18 @@
|
||||
memory = library->memory;
|
||||
|
||||
if ( ALLOC_ARRAY( outline->points, numPoints * 2L, FT_Pos ) ||
|
||||
ALLOC_ARRAY( outline->flags, numPoints, FT_Byte ) ||
|
||||
ALLOC_ARRAY( outline->tags, numPoints, FT_Byte ) ||
|
||||
ALLOC_ARRAY( outline->contours, numContours, FT_UShort ) )
|
||||
goto Fail;
|
||||
|
||||
outline->n_points = (FT_UShort)numPoints;
|
||||
outline->n_contours = (FT_Short)numContours;
|
||||
outline->outline_flags |= ft_outline_owner;
|
||||
outline->flags |= ft_outline_owner;
|
||||
|
||||
return FT_Err_Ok;
|
||||
|
||||
Fail:
|
||||
outline->outline_flags |= ft_outline_owner;
|
||||
outline->flags |= ft_outline_owner;
|
||||
FT_Done_Outline( library, outline );
|
||||
|
||||
return error;
|
||||
@ -2366,10 +2366,10 @@
|
||||
|
||||
if ( outline )
|
||||
{
|
||||
if ( outline->outline_flags & ft_outline_owner )
|
||||
if ( outline->flags & ft_outline_owner )
|
||||
{
|
||||
FREE( outline->points );
|
||||
FREE( outline->flags );
|
||||
FREE( outline->tags );
|
||||
FREE( outline->contours );
|
||||
}
|
||||
*outline = null_outline;
|
||||
@ -2509,7 +2509,7 @@
|
||||
FT_Memory memory = zone->memory;
|
||||
|
||||
FREE( zone->contours );
|
||||
FREE( zone->flags );
|
||||
FREE( zone->tags );
|
||||
FREE( zone->cur );
|
||||
FREE( zone->org );
|
||||
|
||||
@ -2554,7 +2554,7 @@
|
||||
|
||||
if ( ALLOC_ARRAY( zone->org, maxPoints*2, FT_F26Dot6 ) ||
|
||||
ALLOC_ARRAY( zone->cur, maxPoints*2, FT_F26Dot6 ) ||
|
||||
ALLOC_ARRAY( zone->flags, maxPoints, FT_Byte ) ||
|
||||
ALLOC_ARRAY( zone->tags, maxPoints, FT_Byte ) ||
|
||||
ALLOC_ARRAY( zone->contours, maxContours, FT_UShort ) )
|
||||
{
|
||||
FT_Done_GlyphZone(zone);
|
||||
@ -2599,7 +2599,7 @@
|
||||
/* reallocate the points arrays */
|
||||
if ( REALLOC_ARRAY( zone->org, zone->max_points*2, newPoints*2, FT_F26Dot6 ) ||
|
||||
REALLOC_ARRAY( zone->cur, zone->max_points*2, newPoints*2, FT_F26Dot6 ) ||
|
||||
REALLOC_ARRAY( zone->flags, zone->max_points*2, newPoints, FT_Byte ) )
|
||||
REALLOC_ARRAY( zone->tags, zone->max_points*2, newPoints, FT_Byte ) )
|
||||
goto Exit;
|
||||
|
||||
zone->max_points = newPoints;
|
||||
|
@ -336,7 +336,7 @@
|
||||
* n_contours :: current number of contours in zone
|
||||
* org :: original glyph coordinates (font units/scaled)
|
||||
* cur :: current glyph coordinates (scaled/hinted)
|
||||
* flags :: point control flags
|
||||
* tags :: point control tags
|
||||
* contours :: contour end points
|
||||
*
|
||||
***********************************************************************/
|
||||
@ -352,7 +352,7 @@
|
||||
FT_Vector* org; /* original point coordinates */
|
||||
FT_Vector* cur; /* current point coordinates */
|
||||
|
||||
FT_Byte* flags; /* current touch flags */
|
||||
FT_Byte* tags; /* current touch flags */
|
||||
FT_UShort* contours; /* contour end points */
|
||||
|
||||
} FT_GlyphZone;
|
||||
|
@ -60,18 +60,18 @@
|
||||
MEM_Copy( target->points, source->points,
|
||||
source->n_points * 2 * sizeof ( FT_Pos ) );
|
||||
|
||||
MEM_Copy( target->flags, source->flags,
|
||||
MEM_Copy( target->tags, source->tags,
|
||||
source->n_points * sizeof ( FT_Byte ) );
|
||||
|
||||
MEM_Copy( target->contours, source->contours,
|
||||
source->n_contours * sizeof ( FT_Short ) );
|
||||
|
||||
/* copy all flags, except the "ft_outline_owner" one */
|
||||
is_owner = target->outline_flags & ft_outline_owner;
|
||||
target->outline_flags = source->outline_flags;
|
||||
is_owner = target->flags & ft_outline_owner;
|
||||
target->flags = source->flags;
|
||||
|
||||
target->outline_flags &= ~ft_outline_owner;
|
||||
target->outline_flags |= is_owner;
|
||||
target->flags &= ~ft_outline_owner;
|
||||
target->flags |= is_owner;
|
||||
return FT_Err_Ok;
|
||||
}
|
||||
|
||||
|
@ -4130,8 +4130,8 @@ Scan_DropOuts :
|
||||
#else
|
||||
ras.dropout_mode = 2;
|
||||
#endif
|
||||
ras.second_pass = (outline->outline_flags & ft_outline_single_pass) == 0;
|
||||
SET_High_Precision( outline->outline_flags & ft_outline_high_precision );
|
||||
ras.second_pass = (outline->flags & ft_outline_single_pass) == 0;
|
||||
SET_High_Precision( outline->flags & ft_outline_high_precision );
|
||||
|
||||
switch ( target_map->pixel_mode )
|
||||
{
|
||||
|
@ -164,7 +164,7 @@
|
||||
|
||||
target->org = source->org + np;
|
||||
target->cur = source->cur + np;
|
||||
target->flags = source->flags + np;
|
||||
target->tags = source->tags + np;
|
||||
|
||||
target->contours = source->contours + nc;
|
||||
|
||||
@ -271,10 +271,10 @@
|
||||
stream->cursor += n_ins;
|
||||
|
||||
/*********************************************************************/
|
||||
/* reading the point flags */
|
||||
/* reading the point tags */
|
||||
|
||||
{
|
||||
TT_Byte* flag = load->zone.flags;
|
||||
TT_Byte* flag = load->zone.tags;
|
||||
TT_Byte* limit = flag + n_points;
|
||||
TT_Byte c, count;
|
||||
|
||||
@ -295,7 +295,7 @@
|
||||
{
|
||||
TT_Vector* vec = zone->org;
|
||||
TT_Vector* limit = vec + n_points;
|
||||
TT_Byte* flag = zone->flags;
|
||||
TT_Byte* flag = zone->tags;
|
||||
TT_Pos x = 0;
|
||||
|
||||
for ( ; vec < limit; vec++, flag++ )
|
||||
@ -321,7 +321,7 @@
|
||||
{
|
||||
TT_Vector* vec = zone->org;
|
||||
TT_Vector* limit = vec + n_points;
|
||||
TT_Byte* flag = zone->flags;
|
||||
TT_Byte* flag = zone->tags;
|
||||
TT_Pos x = 0;
|
||||
|
||||
for ( ; vec < limit; vec++, flag++ )
|
||||
@ -363,12 +363,12 @@
|
||||
pp2->x = pp1->x + load->advance;
|
||||
pp2->y = 0;
|
||||
|
||||
/* clear the touch flags */
|
||||
/* clear the touch tags */
|
||||
for ( n = 0; n < n_points; n++ )
|
||||
zone->flags[n] &= FT_Curve_Tag_On;
|
||||
zone->tags[n] &= FT_Curve_Tag_On;
|
||||
|
||||
zone->flags[n_points ] = 0;
|
||||
zone->flags[n_points + 1] = 0;
|
||||
zone->tags[n_points ] = 0;
|
||||
zone->tags[n_points + 1] = 0;
|
||||
}
|
||||
/* Note that we return two more points that are not */
|
||||
/* part of the glyph outline. */
|
||||
@ -870,8 +870,8 @@
|
||||
pp1[0] = loader->pp1;
|
||||
pp1[1] = loader->pp2;
|
||||
|
||||
pts->flags[num_points + 1] = 0;
|
||||
pts->flags[num_points + 2] = 0;
|
||||
pts->tags[num_points + 1] = 0;
|
||||
pts->tags[num_points + 2] = 0;
|
||||
|
||||
/* if hinting, round the phantom points */
|
||||
if ( IS_HINTED(loader->load_flags) )
|
||||
@ -883,7 +883,7 @@
|
||||
{
|
||||
TT_UInt k;
|
||||
for ( k = 0; k < n_points; k++ )
|
||||
pts->flags[k] &= FT_Curve_Tag_On;
|
||||
pts->tags[k] &= FT_Curve_Tag_On;
|
||||
}
|
||||
|
||||
cur_to_org( n_points, pts );
|
||||
@ -959,7 +959,7 @@
|
||||
for ( u = 0; u < num_points + 2; u++ )
|
||||
{
|
||||
glyph->outline.points[u] = loader->base.cur[u];
|
||||
glyph->outline.flags [u] = loader->base.flags[u];
|
||||
glyph->outline.tags [u] = loader->base.tags[u];
|
||||
}
|
||||
|
||||
for ( u = 0; u < num_contours; u++ )
|
||||
@ -970,7 +970,7 @@
|
||||
glyph->outline.n_contours = num_contours;
|
||||
|
||||
/* glyph->outline.second_pass = TRUE; */
|
||||
glyph->outline.outline_flags &= ~ft_outline_single_pass;
|
||||
glyph->outline.flags &= ~ft_outline_single_pass;
|
||||
|
||||
/* translate array so that (0,0) is the glyph's origin */
|
||||
translate_array( (TT_UShort)(num_points + 2),
|
||||
@ -1263,10 +1263,10 @@
|
||||
#endif /* TT_CONFIG_OPTION_BYTECODE_INTERPRETER */
|
||||
|
||||
/* clear all outline flags, except the "owner" one */
|
||||
glyph->outline.outline_flags &= ft_outline_owner;
|
||||
glyph->outline.flags &= ft_outline_owner;
|
||||
|
||||
if (size && size->root.metrics.y_ppem < 24 )
|
||||
glyph->outline.outline_flags |= ft_outline_high_precision;
|
||||
glyph->outline.flags |= ft_outline_high_precision;
|
||||
|
||||
/************************************************************************/
|
||||
/* let's initialise the rest of our loader now */
|
||||
|
@ -1383,7 +1383,7 @@
|
||||
v * 0x10000L,
|
||||
CUR.F_dot_P );
|
||||
#endif
|
||||
zone->flags[point] |= FT_Curve_Tag_Touch_X;
|
||||
zone->tags[point] |= FT_Curve_Tag_Touch_X;
|
||||
}
|
||||
|
||||
v = CUR.GS.freeVector.y;
|
||||
@ -1398,7 +1398,7 @@
|
||||
v * 0x10000L,
|
||||
CUR.F_dot_P );
|
||||
#endif
|
||||
zone->flags[point] |= FT_Curve_Tag_Touch_Y;
|
||||
zone->tags[point] |= FT_Curve_Tag_Touch_Y;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1420,7 +1420,7 @@
|
||||
UNUSED_EXEC;
|
||||
|
||||
zone->cur[point].x += distance;
|
||||
zone->flags[point] |= FT_Curve_Tag_Touch_X;
|
||||
zone->tags[point] |= FT_Curve_Tag_Touch_X;
|
||||
}
|
||||
|
||||
|
||||
@ -1432,7 +1432,7 @@
|
||||
UNUSED_EXEC;
|
||||
|
||||
zone->cur[point].y += distance;
|
||||
zone->flags[point] |= FT_Curve_Tag_Touch_Y;
|
||||
zone->tags[point] |= FT_Curve_Tag_Touch_Y;
|
||||
}
|
||||
|
||||
|
||||
@ -4791,7 +4791,7 @@
|
||||
}
|
||||
}
|
||||
else
|
||||
CUR.pts.flags[point] ^= FT_Curve_Tag_On;
|
||||
CUR.pts.tags[point] ^= FT_Curve_Tag_On;
|
||||
|
||||
CUR.GS.loop--;
|
||||
}
|
||||
@ -4825,7 +4825,7 @@
|
||||
}
|
||||
|
||||
for ( I = L; I <= K; I++ )
|
||||
CUR.pts.flags[I] |= FT_Curve_Tag_On;
|
||||
CUR.pts.tags[I] |= FT_Curve_Tag_On;
|
||||
}
|
||||
|
||||
|
||||
@ -4853,7 +4853,7 @@
|
||||
}
|
||||
|
||||
for ( I = L; I <= K; I++ )
|
||||
CUR.pts.flags[I] &= ~FT_Curve_Tag_On;
|
||||
CUR.pts.tags[I] &= ~FT_Curve_Tag_On;
|
||||
}
|
||||
|
||||
|
||||
@ -4916,14 +4916,14 @@
|
||||
{
|
||||
CUR.zp2.cur[point].x += dx;
|
||||
if ( touch )
|
||||
CUR.zp2.flags[point] |= FT_Curve_Tag_Touch_X;
|
||||
CUR.zp2.tags[point] |= FT_Curve_Tag_Touch_X;
|
||||
}
|
||||
|
||||
if ( CUR.GS.freeVector.y != 0 )
|
||||
{
|
||||
CUR.zp2.cur[point].y += dy;
|
||||
if ( touch )
|
||||
CUR.zp2.flags[point] |= FT_Curve_Tag_Touch_Y;
|
||||
CUR.zp2.tags[point] |= FT_Curve_Tag_Touch_Y;
|
||||
}
|
||||
}
|
||||
|
||||
@ -5597,7 +5597,7 @@
|
||||
dx = CUR.zp0.cur[b0].x - CUR.zp1.cur[a0].x;
|
||||
dy = CUR.zp0.cur[b0].y - CUR.zp1.cur[a0].y;
|
||||
|
||||
CUR.zp2.flags[point] |= FT_Curve_Tag_Touch_Both;
|
||||
CUR.zp2.tags[point] |= FT_Curve_Tag_Touch_Both;
|
||||
|
||||
discriminant = TT_MULDIV( dax, -dby, 0x40 ) +
|
||||
TT_MULDIV( day, dbx, 0x40 );
|
||||
@ -5780,7 +5780,7 @@
|
||||
if ( CUR.GS.freeVector.y != 0 )
|
||||
mask &= ~FT_Curve_Tag_Touch_Y;
|
||||
|
||||
CUR.zp0.flags[point] &= mask;
|
||||
CUR.zp0.tags[point] &= mask;
|
||||
}
|
||||
|
||||
|
||||
@ -5933,7 +5933,7 @@
|
||||
end_point = CUR.pts.contours[contour];
|
||||
first_point = point;
|
||||
|
||||
while ( point <= end_point && (CUR.pts.flags[point] & mask) == 0 )
|
||||
while ( point <= end_point && (CUR.pts.tags[point] & mask) == 0 )
|
||||
point++;
|
||||
|
||||
if ( point <= end_point )
|
||||
@ -5945,7 +5945,7 @@
|
||||
|
||||
while ( point <= end_point )
|
||||
{
|
||||
if ( (CUR.pts.flags[point] & mask) != 0 )
|
||||
if ( (CUR.pts.tags[point] & mask) != 0 )
|
||||
{
|
||||
if ( point > 0 )
|
||||
Interp( cur_touched + 1,
|
||||
@ -7632,7 +7632,7 @@
|
||||
|
||||
MEM_Alloc( save.org, sizeof ( TT_Vector ) * save.n_points );
|
||||
MEM_Alloc( save.cur, sizeof ( TT_Vector ) * save.n_points );
|
||||
MEM_Alloc( save.flags, sizeof ( TT_Byte ) * save.n_points );
|
||||
MEM_Alloc( save.tags, sizeof ( TT_Byte ) * save.n_points );
|
||||
|
||||
exc->instruction_trap = 1;
|
||||
|
||||
@ -7795,7 +7795,7 @@
|
||||
|
||||
MEM_Copy( save.org, pts.org, pts.n_points * sizeof ( TT_Vector ) );
|
||||
MEM_Copy( save.cur, pts.cur, pts.n_points * sizeof ( TT_Vector ) );
|
||||
MEM_Copy( save.flags, pts.flags, pts.n_points );
|
||||
MEM_Copy( save.tags, pts.tags, pts.n_points );
|
||||
|
||||
/* a return indicate the last command */
|
||||
if (ch == '\r')
|
||||
@ -7849,14 +7849,14 @@
|
||||
if ( save.org[A].y != pts.org[A].y ) diff |= 2;
|
||||
if ( save.cur[A].x != pts.cur[A].x ) diff |= 4;
|
||||
if ( save.cur[A].y != pts.cur[A].y ) diff |= 8;
|
||||
if ( save.flags[A] != pts.flags[A] ) diff |= 16;
|
||||
if ( save.tags[A] != pts.tags[A] ) diff |= 16;
|
||||
|
||||
if ( diff )
|
||||
{
|
||||
FT_TRACE0(( "%02hx ", A ));
|
||||
|
||||
if ( diff & 16 ) temp = "(%01hx)"; else temp = " %01hx ";
|
||||
FT_TRACE0(( temp, save.flags[A] & 7 ));
|
||||
FT_TRACE0(( temp, save.tags[A] & 7 ));
|
||||
|
||||
if ( diff & 1 ) temp = "(%08lx)"; else temp = " %08lx ";
|
||||
FT_TRACE0(( temp, save.org[A].x ));
|
||||
@ -7875,7 +7875,7 @@
|
||||
FT_TRACE0(( "%02hx ", A ));
|
||||
|
||||
if ( diff & 16 ) temp = "[%01hx]"; else temp = " %01hx ";
|
||||
FT_TRACE0(( temp, pts.flags[A] & 7 ));
|
||||
FT_TRACE0(( temp, pts.tags[A] & 7 ));
|
||||
|
||||
if ( diff & 1 ) temp = "[%08lx]"; else temp = " %08lx ";
|
||||
FT_TRACE0(( temp, pts.org[A].x ));
|
||||
|
@ -255,7 +255,7 @@
|
||||
cur->n_points = 0;
|
||||
cur->n_contours = 0;
|
||||
cur->points = base->points + base->n_points;
|
||||
cur->flags = base->flags + base->n_points;
|
||||
cur->tags = base->tags + base->n_points;
|
||||
cur->contours = base->contours + base->n_contours;
|
||||
|
||||
error = T1_Parse_CharStrings( decoder,
|
||||
@ -282,7 +282,7 @@
|
||||
cur->n_points = 0;
|
||||
cur->n_contours = 0;
|
||||
cur->points = base->points + base->n_points;
|
||||
cur->flags = base->flags + base->n_points;
|
||||
cur->tags = base->tags + base->n_points;
|
||||
cur->contours = base->contours + base->n_contours;
|
||||
|
||||
error = T1_Parse_CharStrings( decoder,
|
||||
@ -920,12 +920,12 @@
|
||||
if ( REALLOC_ARRAY( builder->base.points,
|
||||
current, builder->max_points, T1_Vector ) ||
|
||||
|
||||
REALLOC_ARRAY( builder->base.flags,
|
||||
REALLOC_ARRAY( builder->base.tags,
|
||||
current, builder->max_points, T1_Byte ) )
|
||||
return error;
|
||||
|
||||
builder->current.points = builder->base.points + increment;
|
||||
builder->current.flags = builder->base.flags + increment;
|
||||
builder->current.tags = builder->base.tags + increment;
|
||||
}
|
||||
|
||||
return T1_Err_Ok;
|
||||
@ -1137,18 +1137,18 @@
|
||||
if ( num_points > 0 )
|
||||
{
|
||||
T1_Vector* source_point;
|
||||
char* source_flags;
|
||||
char* source_tags;
|
||||
T1_Vector* point;
|
||||
char* flags;
|
||||
char* tags;
|
||||
|
||||
error = T1_Add_Points( builder, num_points );
|
||||
if (error) return error;
|
||||
|
||||
point = cur->points + cur->n_points;
|
||||
flags = cur->flags + cur->n_points;
|
||||
tags = cur->tags + cur->n_points;
|
||||
|
||||
source_point = point - 2;
|
||||
source_flags = flags - 2;
|
||||
source_tags = tags - 2;
|
||||
|
||||
cur->n_points += num_points;
|
||||
|
||||
@ -1156,7 +1156,7 @@
|
||||
do
|
||||
{
|
||||
*point++ = *source_point--;
|
||||
*flags++ = *source_flags--;
|
||||
*tags++ = *source_tags--;
|
||||
num_points--;
|
||||
}
|
||||
while (num_points > 0);
|
||||
@ -1252,7 +1252,7 @@
|
||||
vec.y = builder->last.y + dy;
|
||||
|
||||
cur->points[cur->n_points] = vec;
|
||||
cur->flags [cur->n_points] = FT_Curve_Tag_On;
|
||||
cur->tags [cur->n_points] = FT_Curve_Tag_On;
|
||||
|
||||
builder->last = vec;
|
||||
}
|
||||
@ -1301,7 +1301,7 @@
|
||||
vec.x = builder->last.x + dx;
|
||||
vec.y = builder->last.y + dy;
|
||||
cur->points[cur->n_points] = vec;
|
||||
cur->flags [cur->n_points] = FT_Curve_Tag_On;
|
||||
cur->tags [cur->n_points] = FT_Curve_Tag_On;
|
||||
|
||||
builder->last = vec;
|
||||
}
|
||||
@ -1326,7 +1326,7 @@
|
||||
FT_Outline* cur = &builder->current;
|
||||
T1_Vector vec;
|
||||
T1_Vector* points;
|
||||
char* flags;
|
||||
char* tags;
|
||||
|
||||
/* grow buffer if necessary */
|
||||
error = T1_Add_Points ( builder, 3 );
|
||||
@ -1336,19 +1336,19 @@
|
||||
{
|
||||
/* save point */
|
||||
points = cur->points + cur->n_points;
|
||||
flags = cur->flags + cur->n_points;
|
||||
tags = cur->tags + cur->n_points;
|
||||
|
||||
vec.x = builder->last.x + dx1;
|
||||
vec.y = builder->last.y + dy1;
|
||||
points[0] = vec; flags[0] = FT_Curve_Tag_Cubic;
|
||||
points[0] = vec; tags[0] = FT_Curve_Tag_Cubic;
|
||||
|
||||
vec.x += dx2;
|
||||
vec.y += dy2;
|
||||
points[1] = vec; flags[1] = FT_Curve_Tag_Cubic;
|
||||
points[1] = vec; tags[1] = FT_Curve_Tag_Cubic;
|
||||
|
||||
vec.x += dx3;
|
||||
vec.y += dy3;
|
||||
points[2] = vec; flags[2] = FT_Curve_Tag_On;
|
||||
points[2] = vec; tags[2] = FT_Curve_Tag_On;
|
||||
|
||||
builder->last = vec;
|
||||
}
|
||||
@ -1537,10 +1537,10 @@
|
||||
|
||||
glyph->root.format = ft_glyph_format_outline;
|
||||
|
||||
glyph->root.outline.outline_flags &= ft_outline_owner;
|
||||
glyph->root.outline.flags &= ft_outline_owner;
|
||||
|
||||
if ( size->root.metrics.y_ppem < 24 )
|
||||
glyph->root.outline.outline_flags |= ft_outline_high_precision;
|
||||
glyph->root.outline.flags |= ft_outline_high_precision;
|
||||
|
||||
/*
|
||||
glyph->root.outline.second_pass = TRUE;
|
||||
|
@ -238,7 +238,7 @@
|
||||
if ( REALLOC_ARRAY( base->points, current,
|
||||
builder->max_points, T1_Vector ) ||
|
||||
|
||||
REALLOC_ARRAY( base->flags, current,
|
||||
REALLOC_ARRAY( base->tags, current,
|
||||
builder->max_points, T1_Byte ) )
|
||||
{
|
||||
builder->error = error;
|
||||
@ -246,7 +246,7 @@
|
||||
}
|
||||
|
||||
outline->points = base->points + increment;
|
||||
outline->flags = base->flags + increment;
|
||||
outline->tags = base->tags + increment;
|
||||
}
|
||||
return T1_Err_Ok;
|
||||
}
|
||||
@ -264,7 +264,7 @@
|
||||
if (builder->load_points)
|
||||
{
|
||||
FT_Vector* point = outline->points + outline->n_points;
|
||||
FT_Byte* control = (FT_Byte*)outline->flags + outline->n_points;
|
||||
FT_Byte* control = (FT_Byte*)outline->tags + outline->n_points;
|
||||
|
||||
point->x = x;
|
||||
point->y = y;
|
||||
@ -462,7 +462,7 @@
|
||||
cur->n_points = 0;
|
||||
cur->n_contours = 0;
|
||||
cur->points = base->points + base->n_points;
|
||||
cur->flags = base->flags + base->n_points;
|
||||
cur->tags = base->tags + base->n_points;
|
||||
cur->contours = base->contours + base->n_contours;
|
||||
|
||||
error = T1_Parse_CharStrings( decoder,
|
||||
@ -489,7 +489,7 @@
|
||||
cur->n_points = 0;
|
||||
cur->n_contours = 0;
|
||||
cur->points = base->points + base->n_points;
|
||||
cur->flags = base->flags + base->n_points;
|
||||
cur->tags = base->tags + base->n_points;
|
||||
cur->contours = base->contours + base->n_contours;
|
||||
|
||||
error = T1_Parse_CharStrings( decoder,
|
||||
@ -1275,9 +1275,9 @@
|
||||
|
||||
glyph->root.format = ft_glyph_format_outline;
|
||||
|
||||
glyph->root.outline.outline_flags &= ft_outline_owner;
|
||||
glyph->root.outline.flags &= ft_outline_owner;
|
||||
if ( size->root.metrics.y_ppem < 24 )
|
||||
glyph->root.outline.outline_flags |= ft_outline_high_precision;
|
||||
glyph->root.outline.flags |= ft_outline_high_precision;
|
||||
/*
|
||||
glyph->root.outline.second_pass = TRUE;
|
||||
glyph->root.outline.high_precision = ( size->root.metrics.y_ppem < 24 );
|
||||
|
Loading…
Reference in New Issue
Block a user