shithub: freetype+ttf2subf

Download patch

ref: a3a3c5d711268da41c6862b50984605b60feb2aa
parent: 5dbdb6c3c4f681186716234c3738cd3a0d2412a1
author: David Turner <[email protected]>
date: Fri Jan 5 08:15:29 EST 2007

small optimization in the CMAP 4 validator

git/fs: mount .git/fs: mount/attach disallowed
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
 2007-01-04  David Turner  <[email protected]>
 
+	* src/sfnt/ttcmap.c: slight optimization in the CMAP 4 validator
+
 	* src/cff/cffload.c, src/cff/cffload.h, src/cff/cffgload.c,
 	src/cff/cfftypes.h: formatting + do not load the CFF index
 	offsets into memory, since this wastes a *lot* of heap memory
--- a/src/sfnt/ttcmap.c
+++ b/src/sfnt/ttcmap.c
@@ -862,18 +862,19 @@
       FT_UInt  start, end, offset, n;
       FT_UInt  last_start = 0, last_end = 0;
       FT_Int   delta;
+      FT_Byte*  p_start   = starts;
+      FT_Byte*  p_end     = ends;
+      FT_Byte*  p_delta   = deltas;
+      FT_Byte*  p_offset  = offsets;
 
 
       for ( n = 0; n < num_segs; n++ )
       {
-        p = starts + n * 2;
-        start = TT_PEEK_USHORT( p );
-        p = ends + n * 2;
-        end = TT_PEEK_USHORT( p );
-        p = deltas + n * 2;
-        delta = TT_PEEK_SHORT( p );
-        p = offsets + n * 2;
-        offset = TT_PEEK_USHORT( p );
+        p      = p_offset;
+        start  = TT_NEXT_USHORT( p_start );
+        end    = TT_NEXT_USHORT( p_end );
+        delta  = TT_NEXT_SHORT( p_delta );
+        offset = TT_NEXT_USHORT( p_offset );
 
         if ( start > end )
           FT_INVALID_DATA;