ref: 9bd20b7304aae61de5d50ac359cf27132bafd4c1
parent: dd89710f0f643eb0f99a3830e0712d26c7642acd
author: Werner Lemberg <[email protected]>
date: Sat Nov 22 01:24:45 EST 2014
[sfnt] Fix Savannah bug #43656. * src/sfnt/ttcmap.c (tt_cmap4_validate): Fix order of validity tests.
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2014-11-22 Werner Lemberg <[email protected]>
+
+ [sfnt] Fix Savannah bug #43656.
+
+ * src/sfnt/ttcmap.c (tt_cmap4_validate): Fix order of validity
+ tests.
+
2014-11-21 Werner Lemberg <[email protected]>
[type1, type42] Fix Savannah bug #43655.
--- a/src/sfnt/ttcmap.c
+++ b/src/sfnt/ttcmap.c
@@ -845,9 +845,6 @@
p = table + 2; /* skip format */
length = TT_NEXT_USHORT( p );
- if ( length < 16 )
- FT_INVALID_TOO_SHORT;
-
/* in certain fonts, the `length' field is invalid and goes */
/* out of bound. We try to correct this here... */
if ( table + length > valid->limit )
@@ -857,6 +854,9 @@
length = (FT_UInt)( valid->limit - table );
}
+
+ if ( length < 16 )
+ FT_INVALID_TOO_SHORT;
p = table + 6;
num_segs = TT_NEXT_USHORT( p ); /* read segCountX2 */