Index: third_party/freetype/src/raster/ftrend1.c |
diff --git a/third_party/freetype/src/raster/ftrend1.c b/third_party/freetype/src/raster/ftrend1.c |
index aa7f6d56649a001dca03237ca1cd6f6831d38580..f3143928399e8090c082eb0d08985e4a858ab00c 100644 |
--- a/third_party/freetype/src/raster/ftrend1.c |
+++ b/third_party/freetype/src/raster/ftrend1.c |
@@ -4,7 +4,7 @@ |
/* */ |
/* The FreeType glyph rasterizer interface (body). */ |
/* */ |
-/* Copyright 1996-2003, 2005, 2006, 2011, 2013 by */ |
+/* Copyright 1996-2015 by */ |
/* David Turner, Robert Wilhelm, and Werner Lemberg. */ |
/* */ |
/* This file is part of the FreeType project, and may only be used, */ |
@@ -104,7 +104,7 @@ |
{ |
FT_Error error; |
FT_Outline* outline; |
- FT_BBox cbox; |
+ FT_BBox cbox, cbox0; |
FT_UInt width, height, pitch; |
FT_Bitmap* bitmap; |
FT_Memory memory; |
@@ -120,38 +120,11 @@ |
} |
/* check rendering mode */ |
-#ifndef FT_CONFIG_OPTION_PIC |
if ( mode != FT_RENDER_MODE_MONO ) |
{ |
/* raster1 is only capable of producing monochrome bitmaps */ |
- if ( render->clazz == &ft_raster1_renderer_class ) |
- return FT_THROW( Cannot_Render_Glyph ); |
+ return FT_THROW( Cannot_Render_Glyph ); |
} |
- else |
- { |
- /* raster5 is only capable of producing 5-gray-levels bitmaps */ |
- if ( render->clazz == &ft_raster5_renderer_class ) |
- return FT_THROW( Cannot_Render_Glyph ); |
- } |
-#else /* FT_CONFIG_OPTION_PIC */ |
- /* When PIC is enabled, we cannot get to the class object */ |
- /* so instead we check the final character in the class name */ |
- /* ("raster5" or "raster1"). Yes this is a hack. */ |
- /* The "correct" thing to do is have different render function */ |
- /* for each of the classes. */ |
- if ( mode != FT_RENDER_MODE_MONO ) |
- { |
- /* raster1 is only capable of producing monochrome bitmaps */ |
- if ( render->clazz->root.module_name[6] == '1' ) |
- return FT_THROW( Cannot_Render_Glyph ); |
- } |
- else |
- { |
- /* raster5 is only capable of producing 5-gray-levels bitmaps */ |
- if ( render->clazz->root.module_name[6] == '5' ) |
- return FT_THROW( Cannot_Render_Glyph ); |
- } |
-#endif /* FT_CONFIG_OPTION_PIC */ |
outline = &slot->outline; |
@@ -160,14 +133,14 @@ |
FT_Outline_Translate( outline, origin->x, origin->y ); |
/* compute the control box, and grid fit it */ |
- FT_Outline_Get_CBox( outline, &cbox ); |
+ FT_Outline_Get_CBox( outline, &cbox0 ); |
/* undocumented but confirmed: bbox values get rounded */ |
#if 1 |
- cbox.xMin = FT_PIX_ROUND( cbox.xMin ); |
- cbox.yMin = FT_PIX_ROUND( cbox.yMin ); |
- cbox.xMax = FT_PIX_ROUND( cbox.xMax ); |
- cbox.yMax = FT_PIX_ROUND( cbox.yMax ); |
+ cbox.xMin = FT_PIX_ROUND( cbox0.xMin ); |
+ cbox.yMin = FT_PIX_ROUND( cbox0.yMin ); |
+ cbox.xMax = FT_PIX_ROUND( cbox0.xMax ); |
+ cbox.yMax = FT_PIX_ROUND( cbox0.yMax ); |
#else |
cbox.xMin = FT_PIX_FLOOR( cbox.xMin ); |
cbox.yMin = FT_PIX_FLOOR( cbox.yMin ); |
@@ -175,8 +148,28 @@ |
cbox.yMax = FT_PIX_CEIL( cbox.yMax ); |
#endif |
+ /* If either `width' or `height' round to 0, try */ |
+ /* explicitly rounding up/down. In the case of */ |
+ /* glyphs containing only one very narrow feature, */ |
+ /* this gives the drop-out compensation in the scan */ |
+ /* conversion code a chance to do its stuff. */ |
width = (FT_UInt)( ( cbox.xMax - cbox.xMin ) >> 6 ); |
+ if ( width == 0 ) |
+ { |
+ cbox.xMin = FT_PIX_FLOOR( cbox0.xMin ); |
+ cbox.xMax = FT_PIX_CEIL( cbox0.xMax ); |
+ |
+ width = (FT_UInt)( ( cbox.xMax - cbox.xMin ) >> 6 ); |
+ } |
+ |
height = (FT_UInt)( ( cbox.yMax - cbox.yMin ) >> 6 ); |
+ if ( height == 0 ) |
+ { |
+ cbox.yMin = FT_PIX_FLOOR( cbox0.yMin ); |
+ cbox.yMax = FT_PIX_CEIL( cbox0.yMax ); |
+ |
+ height = (FT_UInt)( ( cbox.yMax - cbox.yMin ) >> 6 ); |
+ } |
if ( width > FT_USHORT_MAX || height > FT_USHORT_MAX ) |
{ |
@@ -194,23 +187,12 @@ |
slot->internal->flags &= ~FT_GLYPH_OWN_BITMAP; |
} |
- /* allocate new one, depends on pixel format */ |
- if ( !( mode & FT_RENDER_MODE_MONO ) ) |
- { |
- /* we pad to 32 bits, only for backwards compatibility with FT 1.x */ |
- pitch = FT_PAD_CEIL( width, 4 ); |
- bitmap->pixel_mode = FT_PIXEL_MODE_GRAY; |
- bitmap->num_grays = 256; |
- } |
- else |
- { |
- pitch = ( ( width + 15 ) >> 4 ) << 1; |
- bitmap->pixel_mode = FT_PIXEL_MODE_MONO; |
- } |
+ pitch = ( ( width + 15 ) >> 4 ) << 1; |
+ bitmap->pixel_mode = FT_PIXEL_MODE_MONO; |
bitmap->width = width; |
bitmap->rows = height; |
- bitmap->pitch = pitch; |
+ bitmap->pitch = (int)pitch; |
if ( FT_ALLOC_MULT( bitmap->buffer, pitch, height ) ) |
goto Exit; |
@@ -225,9 +207,6 @@ |
params.source = outline; |
params.flags = 0; |
- if ( bitmap->pixel_mode == FT_PIXEL_MODE_GRAY ) |
- params.flags |= FT_RASTER_FLAG_AA; |
- |
/* render outline into the bitmap */ |
error = render->raster_render( render->raster, ¶ms ); |
@@ -272,35 +251,4 @@ |
) |
- /* This renderer is _NOT_ part of the default modules; you will need */ |
- /* to register it by hand in your application. It should only be */ |
- /* used for backwards-compatibility with FT 1.x anyway. */ |
- /* */ |
- FT_DEFINE_RENDERER( ft_raster5_renderer_class, |
- |
- FT_MODULE_RENDERER, |
- sizeof ( FT_RendererRec ), |
- |
- "raster5", |
- 0x10000L, |
- 0x20000L, |
- |
- 0, /* module specific interface */ |
- |
- (FT_Module_Constructor)ft_raster1_init, |
- (FT_Module_Destructor) 0, |
- (FT_Module_Requester) 0 |
- , |
- |
- FT_GLYPH_FORMAT_OUTLINE, |
- |
- (FT_Renderer_RenderFunc) ft_raster1_render, |
- (FT_Renderer_TransformFunc)ft_raster1_transform, |
- (FT_Renderer_GetCBoxFunc) ft_raster1_get_cbox, |
- (FT_Renderer_SetModeFunc) ft_raster1_set_mode, |
- |
- (FT_Raster_Funcs*) &FT_STANDARD_RASTER_GET |
- ) |
- |
- |
/* END */ |