* include/freetype/ftcache.h, src/cache/ftccmap.c: modify FTC_CMapCache_Lookup to accept a negative cmap index to mean "use default cached FT_Face's charmap". This fixes Savannah issue #22625
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
diff --git a/ChangeLog b/ChangeLog
index f35316a..6b3054e 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
2008-09-01 david turner <david@freetype.org>
+ * include/freetype/ftcache.h, src/cache/ftccmap.c:
+ modify FTC_CMapCache_Lookup to accept a negative cmap index
+ to mean "use default cached FT_Face's charmap". This fixes
+ Savannah issue #22625
+
* include/freetype/ftoption.h, include/freetype/ftconfig.h,
builds/unix/ftconfig.in, include/freetype/freetype.h,
src/base/ftcalc.c:
diff --git a/include/freetype/ftcache.h b/include/freetype/ftcache.h
index bb03b31..e6c38fc 100644
--- a/include/freetype/ftcache.h
+++ b/include/freetype/ftcache.h
@@ -610,6 +610,7 @@ FT_BEGIN_HEADER
*
* cmap_index ::
* The index of the charmap in the source face.
+ * Any negative value means to use the cache FT_Face's default charmap.
*
* char_code ::
* The character code (in the corresponding charmap).
diff --git a/src/cache/ftccmap.c b/src/cache/ftccmap.c
index aa59307..51bef1e 100644
--- a/src/cache/ftccmap.c
+++ b/src/cache/ftccmap.c
@@ -288,7 +288,19 @@
FT_Error error;
FT_UInt gindex = 0;
FT_UInt32 hash;
+ FT_Int no_cmap_change = 0;
+ if (cmap_index < 0)
+ {
+ /* treat a negative cmap index as a special value that
+ * means you don't want to change the FT_Face's character
+ * map through this call. this can be useful when the
+ * face requester callback already set the face's charmap
+ * to the appropriate value.
+ */
+ no_cmap_change = 1;
+ cmap_index = 0;
+ }
if ( !cache )
{
@@ -311,7 +323,7 @@
* Adobe Acrobat Reader Pack, named `KozMinProVI-Regular.otf',
* which contains more than 5 charmaps.
*/
- if ( cmap_index >= 16 )
+ if ( cmap_index >= 16 && !no_cmap_change )
{
FTC_OldCMapDesc desc = (FTC_OldCMapDesc) face_id;
@@ -393,12 +405,12 @@
old = face->charmap;
cmap = face->charmaps[cmap_index];
- if ( old != cmap )
+ if ( old != cmap && !no_cmap_change )
FT_Set_Charmap( face, cmap );
gindex = FT_Get_Char_Index( face, char_code );
- if ( old != cmap )
+ if ( old != cmap && !no_cmap_change )
FT_Set_Charmap( face, old );
}