summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarinus Schraal <foser@gentoo.org>2006-09-18 15:53:16 +0000
committerMarinus Schraal <foser@gentoo.org>2006-09-18 15:53:16 +0000
commit7d6d5a0c9551dfe6fcf1e13e2f41398d40f0ab62 (patch)
tree9de8d8e052225cad3fe2b3764112dc717132270a /media-libs
parentClean up. (diff)
downloadgentoo-2-7d6d5a0c9551dfe6fcf1e13e2f41398d40f0ab62.tar.gz
gentoo-2-7d6d5a0c9551dfe6fcf1e13e2f41398d40f0ab62.tar.bz2
gentoo-2-7d6d5a0c9551dfe6fcf1e13e2f41398d40f0ab62.zip
fix for freetype 2.2
(Portage version: 2.1)
Diffstat (limited to 'media-libs')
-rw-r--r--media-libs/fontconfig/ChangeLog8
-rw-r--r--media-libs/fontconfig/files/digest-fontconfig-2.3.2-r23
-rw-r--r--media-libs/fontconfig/files/fontconfig-2.3.2-noftinternals.patch701
-rw-r--r--media-libs/fontconfig/fontconfig-2.3.2-r1.ebuild4
-rw-r--r--media-libs/fontconfig/fontconfig-2.3.2-r2.ebuild99
5 files changed, 812 insertions, 3 deletions
diff --git a/media-libs/fontconfig/ChangeLog b/media-libs/fontconfig/ChangeLog
index b2f8ff037099..10d79da59ac4 100644
--- a/media-libs/fontconfig/ChangeLog
+++ b/media-libs/fontconfig/ChangeLog
@@ -1,6 +1,12 @@
# ChangeLog for media-libs/fontconfig
# Copyright 2002-2006 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/media-libs/fontconfig/ChangeLog,v 1.75 2006/09/17 14:41:16 foser Exp $
+# $Header: /var/cvsroot/gentoo-x86/media-libs/fontconfig/ChangeLog,v 1.76 2006/09/18 15:53:16 foser Exp $
+
+*fontconfig-2.3.2-r2 (18 Sep 2006)
+
+ 18 Sep 2006; Marinus Schraal <foser@gentoo.org> fontconfig-2.3.2-r2.ebuild,
+ fontconfig-2.3.2-noftinternals.patch :
+ Don't break on freetype 2.2 (#140359)
*fontconfig-2.4.1 (17 Sep 2006)
diff --git a/media-libs/fontconfig/files/digest-fontconfig-2.3.2-r2 b/media-libs/fontconfig/files/digest-fontconfig-2.3.2-r2
new file mode 100644
index 000000000000..cfe4f11048a6
--- /dev/null
+++ b/media-libs/fontconfig/files/digest-fontconfig-2.3.2-r2
@@ -0,0 +1,3 @@
+MD5 7354f9f125ea78a8f2851cb9c31d4866 fontconfig-2.3.2.tar.gz 964045
+RMD160 42668475cca88f265a3b12c289eea2ff61ddaa2b fontconfig-2.3.2.tar.gz 964045
+SHA256 6f7b91d328d6408c097ec11777bf4b1c2c710613b573b399794bc5999ff12227 fontconfig-2.3.2.tar.gz 964045
diff --git a/media-libs/fontconfig/files/fontconfig-2.3.2-noftinternals.patch b/media-libs/fontconfig/files/fontconfig-2.3.2-noftinternals.patch
new file mode 100644
index 000000000000..06ee8425d158
--- /dev/null
+++ b/media-libs/fontconfig/files/fontconfig-2.3.2-noftinternals.patch
@@ -0,0 +1,701 @@
+diff -urN fontconfig-2.3.2/src/fcfreetype.c fontconfig-2.3.2-new/src/fcfreetype.c
+--- fontconfig-2.3.2/src/fcfreetype.c 2005-04-21 14:37:43.000000000 +0200
++++ fontconfig-2.3.2-new/src/fcfreetype.c 2005-07-07 13:17:32.224401218 +0200
+@@ -50,14 +50,11 @@
+ #include "fcint.h"
+ #include <ft2build.h>
+ #include FT_FREETYPE_H
+-#include FT_INTERNAL_OBJECTS_H
+ #include FT_TRUETYPE_TABLES_H
+ #include FT_SFNT_NAMES_H
+ #include FT_TRUETYPE_IDS_H
+ #include FT_TYPE1_TABLES_H
+-#include FT_INTERNAL_STREAM_H
+-#include FT_INTERNAL_SFNT_H
+-#include FT_INTERNAL_TRUETYPE_TYPES_H
++#include "fcftglue.h"
+ #if HAVE_FT_GET_X11_FONT_FORMAT
+ #include FT_XFREE86_H
+ #endif
+@@ -65,8 +62,7 @@
+ #if HAVE_FT_GET_BDF_PROPERTY
+ #include FT_BDF_H
+ #include FT_MODULE_H
+-#define HAS_BDF_PROPERTY(f) ((f) && (f)->driver && \
+- (f)->driver->root.clazz->get_interface)
++#define HAS_BDF_PROPERTY(f) ((f))
+ #define MY_Get_BDF_Property(f,n,p) (HAS_BDF_PROPERTY(f) ? \
+ FT_Get_BDF_Property(f,n,p) : \
+ FT_Err_Invalid_Argument)
+@@ -1559,7 +1555,7 @@
+ */
+ if (FcCharSetCount (cs) == 0)
+ {
+- if (!strcmp(FT_MODULE_CLASS(&face->driver->root)->module_name, "pcf"))
++ if (!strcmp(FT_Get_X11_Font_Format(face),"PCF"))
+ goto bail2;
+ }
+
+@@ -2706,8 +2702,7 @@
+ static FT_Error
+ GetScriptTags(FT_Face face, FT_ULong tabletag, FT_ULong **stags, FT_UShort *script_count)
+ {
+- FT_ULong cur_offset, new_offset, base_offset;
+- TT_Face tt_face = (TT_Face)face;
++ FT_ULong cur_offset, new_offset, base_offset;
+ FT_Stream stream = face->stream;
+ FT_Error error;
+ FT_UShort n, p;
+@@ -2716,51 +2711,43 @@
+ if ( !stream )
+ return TT_Err_Invalid_Face_Handle;
+
+- if (( error = tt_face->goto_table( tt_face, tabletag, stream, 0 ) ))
++ if ( (error = fcft_face_goto_table( face, tabletag, stream )) != 0 )
+ return error;
+
+- base_offset = FT_STREAM_POS();
++ base_offset = FCFT_STREAM_POS();
+
+ /* skip version */
+
+- if ( FT_STREAM_SEEK( base_offset + 4L ) || FT_FRAME_ENTER( 2L ) )
+- return error;
+-
+- new_offset = FT_GET_USHORT() + base_offset;
+-
+- FT_FRAME_EXIT();
+-
+- cur_offset = FT_STREAM_POS();
+-
+- if ( FT_STREAM_SEEK( new_offset ) != TT_Err_Ok )
+- return error;
+-
+- base_offset = FT_STREAM_POS();
++ if ( FCFT_STREAM_SEEK( base_offset + 4L ) ||
++ FCFT_READ_USHORT( new_offset ) )
++ return error;
++
++ new_offset += base_offset;
++ cur_offset = FCFT_STREAM_POS();
+
+- if ( FT_FRAME_ENTER( 2L ) )
++ if ( FCFT_STREAM_SEEK( new_offset ) != TT_Err_Ok )
+ return error;
+
+- *script_count = FT_GET_USHORT();
++ base_offset = FCFT_STREAM_POS();
+
+- FT_FRAME_EXIT();
+-
+- if ( FT_SET_ERROR (FT_MEM_ALLOC_ARRAY( *stags, *script_count, FT_ULong )) )
+- return error;
++ if ( FCFT_READ_USHORT(*script_count) ||
++ FCFT_MEM_ALLOC_ARRAY( *stags, *script_count, FT_ULong ) )
++ return error;
+
+ p = 0;
+ for ( n = 0; n < *script_count; n++ )
+ {
+- if ( FT_FRAME_ENTER( 6L ) )
++ if ( FCFT_FRAME_ENTER( 6L ) )
+ goto Fail;
+
+- (*stags)[p] = FT_GET_ULONG();
+- new_offset = FT_GET_USHORT() + base_offset;
++ (*stags)[p] = FCFT_GET_ULONG();
++ new_offset = FCFT_GET_USHORT() + base_offset;
+
+- FT_FRAME_EXIT();
++ FCFT_FRAME_EXIT();
+
+- cur_offset = FT_STREAM_POS();
++ cur_offset = FCFT_STREAM_POS();
+
+- if ( FT_STREAM_SEEK( new_offset ) )
++ if ( FCFT_STREAM_SEEK( new_offset ) )
+ goto Fail;
+
+ if ( error == TT_Err_Ok )
+@@ -2768,7 +2755,7 @@
+ else if ( error != TTO_Err_Empty_Script )
+ goto Fail;
+
+- (void)FT_STREAM_SEEK( cur_offset );
++ (void)FCFT_STREAM_SEEK( cur_offset );
+ }
+
+ if (!p)
+@@ -2784,7 +2771,7 @@
+
+ Fail:
+ *script_count = 0;
+- FT_FREE( *stags );
++ FCFT_FREE( *stags );
+ return error;
+ }
+
+@@ -2841,7 +2828,7 @@
+ if (FcDebug () & FC_DBG_SCANV)
+ printf("complex features in this font: %s\n", complex);
+ bail:
+- FT_FREE(gsubtags);
+- FT_FREE(gpostags);
++ FCFT_FREE(gsubtags);
++ FCFT_FREE(gpostags);
+ return complex;
+ }
+diff -urN fontconfig-2.3.2/src/fcftglue.c fontconfig-2.3.2-new/src/fcftglue.c
+--- fontconfig-2.3.2/src/fcftglue.c 1970-01-01 01:00:00.000000000 +0100
++++ fontconfig-2.3.2-new/src/fcftglue.c 2005-07-07 13:34:48.630254000 +0200
+@@ -0,0 +1,380 @@
++#include "fcftglue.h"
++
++/***************************************************************************/
++/***************************************************************************/
++/***** *****/
++/***** *****/
++/***** *****/
++/***************************************************************************/
++/***************************************************************************/
++
++/* only used internall */
++static FT_Pointer
++fcft_qalloc( FT_Memory memory,
++ FT_ULong size,
++ FT_Error *perror )
++{
++ FT_Error error = 0;
++ FT_Pointer block = NULL;
++
++ if ( size > 0 )
++ {
++ block = memory->alloc( memory, size );
++ if ( !block )
++ error = FT_Err_Out_Of_Memory;
++ }
++
++ *perror = error;
++ return block;
++}
++
++#define FCFT_QALLOC(ptr,size) ( (ptr) = fcft_qalloc( memory, (size), &error ), error != 0 )
++
++
++FCFT_APIDEF( FT_Pointer )
++fcft_alloc( FT_Memory memory,
++ FT_ULong size,
++ FT_Error *perror )
++{
++ FT_Error error = 0;
++ FT_Pointer block = NULL;
++
++ if ( size > 0 )
++ {
++ block = memory->alloc( memory, size );
++ if ( !block )
++ error = FT_Err_Out_Of_Memory;
++ else
++ memset( (char*)block, 0, (size_t)size );
++ }
++
++ *perror = error;
++ return block;
++}
++
++
++FCFT_APIDEF( FT_Pointer )
++fcft_realloc( FT_Memory memory,
++ FT_Pointer block,
++ FT_ULong old_size,
++ FT_ULong new_size,
++ FT_Error *perror )
++{
++ FT_Pointer block2 = NULL;
++ FT_Error error = 0;
++
++ if ( block == NULL )
++ {
++ block2 = fcft_alloc( memory, new_size, &error );
++ }
++ else if ( new_size <= 0 )
++ {
++ fcft_free( memory, block );
++ }
++ else
++ {
++ block2 = fcft_alloc( memory, new_size, &error );
++ if ( !error )
++ {
++ memcpy( (char*)block2, (const char*)block, (size_t)old_size );
++ if ( new_size > old_size )
++ memset( (char*)block2 + old_size, 0, (size_t)(new_size - old_size) );
++ }
++ }
++
++ if ( !error )
++ block = block2;
++
++ *perror = error;
++ return block;
++}
++
++
++FCFT_APIDEF( void )
++fcft_free( FT_Memory memory,
++ FT_Pointer block )
++{
++ if ( block )
++ memory->free( memory, block );
++}
++
++
++FCFT_APIDEF( FT_Long )
++fcft_stream_pos( FT_Stream stream )
++{
++ return stream->pos;
++}
++
++
++FCFT_APIDEF( FT_Error )
++fcft_stream_seek( FT_Stream stream,
++ FT_Long pos )
++{
++ FT_Error error = 0;
++
++ stream->pos = pos;
++ if ( stream->read )
++ {
++ if ( stream->read( stream, pos, 0, 0 ) )
++ error = FT_Err_Invalid_Stream_Operation;
++ }
++ else if ( pos > stream->size )
++ error = FT_Err_Invalid_Stream_Operation;
++
++ return error;
++}
++
++
++FCFT_APIDEF( FT_Error )
++fcft_stream_frame_enter( FT_Stream stream,
++ FT_ULong count )
++{
++ FT_Error error = FT_Err_Ok;
++ FT_ULong read_bytes;
++
++ if ( stream->read )
++ {
++ /* allocate the frame in memory */
++ FT_Memory memory = stream->memory;
++
++
++ if ( FCFT_QALLOC( stream->base, count ) )
++ goto Exit;
++
++ /* read it */
++ read_bytes = stream->read( stream, stream->pos,
++ stream->base, count );
++ if ( read_bytes < count )
++ {
++ FCFT_FREE( stream->base );
++ error = FT_Err_Invalid_Stream_Operation;
++ }
++ stream->cursor = stream->base;
++ stream->limit = stream->cursor + count;
++ stream->pos += read_bytes;
++ }
++ else
++ {
++ /* check current and new position */
++ if ( stream->pos >= stream->size ||
++ stream->pos + count > stream->size )
++ {
++ error = FT_Err_Invalid_Stream_Operation;
++ goto Exit;
++ }
++
++ /* set cursor */
++ stream->cursor = stream->base + stream->pos;
++ stream->limit = stream->cursor + count;
++ stream->pos += count;
++ }
++
++Exit:
++ return error;
++}
++
++
++FCFT_APIDEF( void )
++fcft_stream_frame_exit( FT_Stream stream )
++{
++ if ( stream->read )
++ {
++ FT_Memory memory = stream->memory;
++
++ FCFT_FREE( stream->base );
++ }
++ stream->cursor = 0;
++ stream->limit = 0;
++}
++
++
++FCFT_APIDEF( FT_Byte )
++fcft_stream_get_byte( FT_Stream stream )
++{
++ FT_Byte result = 0;
++
++ if ( stream->cursor < stream->limit )
++ result = *stream->cursor++;
++
++ return result;
++}
++
++
++FCFT_APIDEF( FT_Short )
++fcft_stream_get_short( FT_Stream stream )
++{
++ FT_Byte* p;
++ FT_Short result = 0;
++
++ p = stream->cursor;
++ if ( p + 2 <= stream->limit )
++ {
++ result = (FT_Short)((p[0] << 8) | p[1]);
++ stream->cursor = p+2;
++ }
++ return result;
++}
++
++
++FCFT_APIDEF( FT_Long )
++fcft_stream_get_long( FT_Stream stream )
++{
++ FT_Byte* p;
++ FT_Long result = 0;
++
++ p = stream->cursor;
++ if ( p + 4 <= stream->limit )
++ {
++ result = (FT_Long)(((FT_Long)p[0] << 24) |
++ ((FT_Long)p[1] << 16) |
++ ((FT_Long)p[2] << 8) |
++ p[3] );
++ stream->cursor = p+4;
++ }
++ return result;
++}
++
++
++static FT_Error
++fcft_stream_readp( FT_Stream stream,
++ FT_Byte* *pbuffer,
++ FT_ULong count )
++{
++ FT_Error error = 0;
++
++ if ( stream->read )
++ {
++ FT_ULong read_bytes = stream->read( stream, stream->pos, *pbuffer, count );
++
++ if ( read_bytes != count )
++ goto Fail;
++
++ stream->pos += count;
++ }
++ else
++ {
++ if ( stream->pos >= stream->size ||
++ stream->pos + count > stream->size )
++ goto Fail;
++
++ *pbuffer = stream->base + stream->pos;
++ stream->pos += count;
++ }
++
++Exit:
++ return error;
++
++Fail:
++ error = FT_Err_Invalid_Stream_Operation;
++ goto Exit;
++}
++
++
++FCFT_API( FT_Byte )
++fcft_stream_read_byte( FT_Stream stream,
++ FT_Error *perror )
++{
++ FT_Byte temp[1], *p = temp, result = 0;
++ FT_Error error = fcft_stream_readp( stream, &p, 1 );
++
++ if ( !error )
++ result = *p;
++
++ return error;
++}
++
++FCFT_API( FT_Short )
++fcft_stream_read_short( FT_Stream stream,
++ FT_Error *perror )
++{
++ FT_Byte temp[2], *p = temp;
++ FT_Short result = 0;
++ FT_Error error = fcft_stream_readp( stream, &p, 2 );
++
++ if ( !error )
++ result = (FT_Short)((p[0] << 8) | p[1]);
++
++ return error;
++}
++
++FCFT_API( FT_Long )
++fcft_stream_read_long( FT_Stream stream,
++ FT_Error *perror )
++{
++ FT_Byte temp[4], *p = temp;
++ FT_Long result = 0;
++ FT_Error error = fcft_stream_readp( stream, &p, 4 );
++
++ if ( !error )
++ result = (FT_Long)((FT_Long)(p[0] << 24) |
++ (FT_Long)(p[1] << 16) |
++ (p[2] << 8) |
++ p[3] );
++
++ return error;
++}
++
++
++FCFT_APIDEF( FT_Error )
++fcft_face_goto_table( FT_Face face,
++ FT_ULong the_tag,
++ FT_Stream stream )
++{
++ FT_Error error;
++
++ if ( !FT_IS_SFNT(face) )
++ error = FT_Err_Invalid_Face_Handle;
++ else
++ {
++ /* parse the directory table directly, without using
++ * FreeType's built-in data structures
++ */
++ FT_UInt count, nn;
++ FT_ULong offset = 0;
++
++ if ( face->num_faces > 1 )
++ {
++ /* deal with TrueType collections */
++ FT_ULong offset;
++
++ if ( FCFT_STREAM_SEEK( 12 + face->face_index*4 ) ||
++ FCFT_READ_ULONG(offset) )
++ goto Exit;
++ }
++
++ if ( FCFT_STREAM_SEEK( offset+4 ) ||
++ FCFT_READ_USHORT(count) )
++ goto Exit;
++
++
++ if ( FCFT_STREAM_SEEK( offset+12 ) ||
++ FCFT_FRAME_ENTER( count*16 ) )
++ goto Exit;
++
++ for ( nn = 0; nn < count; nn++ )
++ {
++ FT_ULong tag = FCFT_GET_TAG();
++ FT_ULong checksum = FCFT_GET_ULONG();
++ FT_ULong start = FCFT_GET_ULONG();
++ FT_ULong size = FCFT_GET_ULONG();
++
++ FT_UNUSED(checksum);
++ FT_UNUSED(size);
++
++ if ( tag == the_tag )
++ {
++ error = fcft_stream_seek( stream, offset+start );
++ goto FoundIt;
++ }
++ }
++ error = FT_Err_Table_Missing;
++
++ FoundIt:
++ FCFT_FRAME_EXIT();
++ }
++
++Exit:
++ return error;
++}
++
++#undef FCFT_QALLOC
+diff -urN fontconfig-2.3.2/src/fcftglue.h fontconfig-2.3.2-new/src/fcftglue.h
+--- fontconfig-2.3.2/src/fcftglue.h 1970-01-01 01:00:00.000000000 +0100
++++ fontconfig-2.3.2-new/src/fcftglue.h 2005-07-07 13:15:43.292717000 +0200
+@@ -0,0 +1,135 @@
++/* the following contains code used to prevent FontConfig from
++ * abusing FreeType internals. We simply duplicate some of the FreeType
++ * functionality using only publicly defined APIs and structures
++ */
++#ifndef __FONTCONFIG_FTGLUE_H__
++#define __FONTCONFIG_FTGLUE_H__
++
++#include <ft2build.h>
++#include FT_FREETYPE_H
++
++FT_BEGIN_HEADER
++
++
++/* utility macros */
++#define FCFT_SET_ERR(c) ( (error = (c)) != 0 )
++
++#ifndef FCFT_API
++#define FCFT_API(x) extern x
++#endif
++
++#ifndef FCFT_APIDEF
++#define FCFT_APIDEF(x) x
++#endif
++
++/* stream macros used by the OpenType parser */
++#define FCFT_STREAM_POS() fcft_stream_pos( stream )
++#define FCFT_STREAM_SEEK(pos) FCFT_SET_ERR( fcft_stream_seek( stream, pos ) )
++#define FCFT_FRAME_ENTER(size) FCFT_SET_ERR( fcft_stream_frame_enter( stream, size ) )
++#define FCFT_FRAME_EXIT() fcft_stream_frame_exit( stream )
++
++#define FCFT_GET_BYTE() fcft_stream_get_byte( stream )
++#define FCFT_GET_SHORT() fcft_stream_get_short( stream )
++#define FCFT_GET_LONG() fcft_stream_get_long( stream )
++
++#define FCFT_GET_CHAR() ((FT_Char)FCFT_GET_BYTE())
++#define FCFT_GET_USHORT() ((FT_UShort)FCFT_GET_SHORT())
++#define FCFT_GET_ULONG() ((FT_ULong)FCFT_GET_LONG())
++#define FCFT_GET_TAG() FCFT_GET_ULONG()
++
++#define FCFT_READ_(val,type,suffix) \
++ ( (val) = (type) fcft_stream_read_##suffix (stream, &error), error != 0 )
++
++#define FCFT_READ_BYTE(val) FCFT_READ_(val,FT_Byte,byte)
++#define FCFT_READ_SHORT(val) FCFT_READ_(val,FT_Short,short)
++#define FCFT_READ_LONG(val) FCFT_READ_(val,FT_Long,long)
++
++#define FCFT_READ_CHAR(val) FCFT_READ_(val,FT_Char,byte)
++#define FCFT_READ_USHORT(val) FCFT_READ_(val,FT_UShort,short)
++#define FCFT_READ_ULONG(val) FCFT_READ_(val,FT_ULong,long)
++
++
++FCFT_API( FT_Long )
++fcft_stream_pos( FT_Stream stream );
++
++FCFT_API( FT_Error )
++fcft_stream_seek( FT_Stream stream,
++ FT_Long pos );
++
++FCFT_API( FT_Error )
++fcft_stream_frame_enter( FT_Stream stream,
++ FT_ULong size );
++
++FCFT_API( void )
++fcft_stream_frame_exit( FT_Stream stream );
++
++FCFT_API( FT_Byte )
++fcft_stream_get_byte( FT_Stream stream );
++
++FCFT_API( FT_Short )
++fcft_stream_get_short( FT_Stream stream );
++
++FCFT_API( FT_Long )
++fcft_stream_get_long( FT_Stream stream );
++
++FCFT_API( FT_Byte )
++fcft_stream_read_byte( FT_Stream stream,
++ FT_Error *perror );
++
++FCFT_API( FT_Short )
++fcft_stream_read_short( FT_Stream stream,
++ FT_Error *perror );
++
++FCFT_API( FT_Long )
++fcft_stream_read_long( FT_Stream stream,
++ FT_Error *perror );
++
++FCFT_API( FT_Error )
++fcft_face_goto_table( FT_Face face,
++ FT_ULong tag,
++ FT_Stream stream );
++
++/* memory macros used by the OpenType parser */
++#define FCFT_MEM_ALLOC(_ptr,_size) \
++ ( (_ptr) = fcft_alloc( memory, _size, &error ), error != 0 )
++
++#define FCFT_MEM_REALLOC(_ptr,_oldsz,_newsz) \
++ ( (_ptr) = fcft_realloc( memory, (_ptr), (_oldsz), (_newsz), &error ), error != 0 )
++
++#define FCFT_FREE(_ptr) \
++ FT_BEGIN_STMNT \
++ if ( (_ptr) ) \
++ { \
++ fcft_free( memory, _ptr ); \
++ _ptr = NULL; \
++ } \
++ FT_END_STMNT
++
++#define FCFT_MEM_ALLOC_ARRAY(_ptr,_count,_type) \
++ FCFT_MEM_ALLOC(_ptr,(_count)*sizeof(_type))
++
++#define FCFT_MEM_REALLOC_ARRAY(_ptr,_oldcnt,_newcnt,_type) \
++ FCFT_MEM_REALLOC(_ptr,(_oldcnt)*sizeof(_type),(_newcnt)*sizeof(_type))
++
++
++FCFT_API( FT_Pointer )
++fcft_alloc( FT_Memory memory,
++ FT_ULong size,
++ FT_Error *perror );
++
++FCFT_API( FT_Pointer )
++fcft_realloc( FT_Memory memory,
++ FT_Pointer block,
++ FT_ULong old_size,
++ FT_ULong new_size,
++ FT_Error *perror );
++
++FCFT_API( void )
++fcft_free( FT_Memory memory,
++ FT_Pointer block );
++
++/* */
++
++FT_END_HEADER
++
++#endif /* __OPENTYPE_FCFT_H__ */
+diff -urN fontconfig-2.3.2/src/Makefile.am fontconfig-2.3.2-new/src/Makefile.am
+--- fontconfig-2.3.2/src/Makefile.am 2004-12-05 06:49:20.000000000 +0100
++++ fontconfig-2.3.2-new/src/Makefile.am 2005-07-07 13:09:15.416637082 +0200
+@@ -86,6 +86,7 @@
+ fcdefault.c \
+ fcdir.c \
+ fcfreetype.c \
++ fcftglue.c \
+ fcfs.c \
+ fcinit.c \
+ fclang.c \
+diff -urN fontconfig-2.3.2/src/Makefile.in fontconfig-2.3.2-new/src/Makefile.in
+--- fontconfig-2.3.2/src/Makefile.in 2005-04-27 21:08:51.000000000 +0200
++++ fontconfig-2.3.2-new/src/Makefile.in 2005-07-07 13:09:15.417636939 +0200
+@@ -228,6 +228,7 @@
+ fcdefault.c \
+ fcdir.c \
+ fcfreetype.c \
++ fcftglue.c \
+ fcfs.c \
+ fcinit.c \
+ fclang.c \
+@@ -257,7 +258,7 @@
+ libfontconfig_la_DEPENDENCIES =
+ am_libfontconfig_la_OBJECTS = fcatomic.lo fcblanks.lo fccache.lo \
+ fccfg.lo fccharset.lo fcdbg.lo fcdefault.lo fcdir.lo \
+- fcfreetype.lo fcfs.lo fcinit.lo fclang.lo fclist.lo fcmatch.lo \
++ fcfreetype.lo fcftglue.lo fcfs.lo fcinit.lo fclang.lo fclist.lo fcmatch.lo \
+ fcmatrix.lo fcname.lo fcpat.lo fcstr.lo fcxml.lo
+ libfontconfig_la_OBJECTS = $(am_libfontconfig_la_OBJECTS)
+
diff --git a/media-libs/fontconfig/fontconfig-2.3.2-r1.ebuild b/media-libs/fontconfig/fontconfig-2.3.2-r1.ebuild
index 2d10425ecdc0..df2f8b7eb5f6 100644
--- a/media-libs/fontconfig/fontconfig-2.3.2-r1.ebuild
+++ b/media-libs/fontconfig/fontconfig-2.3.2-r1.ebuild
@@ -1,6 +1,6 @@
# Copyright 1999-2006 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/media-libs/fontconfig/fontconfig-2.3.2-r1.ebuild,v 1.11 2006/09/04 03:43:18 kumba Exp $
+# $Header: /var/cvsroot/gentoo-x86/media-libs/fontconfig/fontconfig-2.3.2-r1.ebuild,v 1.12 2006/09/18 15:53:16 foser Exp $
inherit eutils libtool autotools
@@ -10,7 +10,7 @@ SRC_URI="http://fontconfig.org/release/${P}.tar.gz"
LICENSE="fontconfig"
SLOT="1.0"
-KEYWORDS="~alpha amd64 arm ~hppa ia64 m68k mips ppc ~ppc-macos ppc64 s390 sh sparc x86 ~x86-fbsd"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc-macos ~ppc64 ~s390 ~sh ~sparc ~x86 ~x86-fbsd"
IUSE="doc"
DEPEND=">=media-libs/freetype-2.1.4
diff --git a/media-libs/fontconfig/fontconfig-2.3.2-r2.ebuild b/media-libs/fontconfig/fontconfig-2.3.2-r2.ebuild
new file mode 100644
index 000000000000..256cd854ac2a
--- /dev/null
+++ b/media-libs/fontconfig/fontconfig-2.3.2-r2.ebuild
@@ -0,0 +1,99 @@
+# Copyright 1999-2006 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/media-libs/fontconfig/fontconfig-2.3.2-r2.ebuild,v 1.1 2006/09/18 15:53:16 foser Exp $
+
+inherit eutils libtool autotools
+
+DESCRIPTION="A library for configuring and customizing font access"
+HOMEPAGE="http://fontconfig.org/"
+SRC_URI="http://fontconfig.org/release/${P}.tar.gz"
+
+LICENSE="fontconfig"
+SLOT="1.0"
+KEYWORDS="~alpha amd64 arm ~hppa ia64 m68k mips ppc ~ppc-macos ppc64 s390 sh sparc x86 ~x86-fbsd"
+IUSE="doc"
+
+DEPEND=">=media-libs/freetype-2.1.4
+ >=dev-libs/expat-1.95.3"
+
+src_unpack() {
+ unpack ${A}
+
+ cd "${S}"
+ # alias for Symbol and dingbats font (#124238)
+ epatch "${FILESDIR}"/${P}-symbol_alias.patch
+ # fix pkgconfig includes (#83623)
+ epatch "${FILESDIR}"/${P}-pkg_config.patch
+ # add docbook switch so we can disable it
+ epatch "${FILESDIR}"/${P}-docbook.patch
+ # fix build with ft 2.2 (#140359)
+ epatch ${FILESDIR}/${P}-noftinternals.patch
+
+ eautoreconf
+
+ # elibtoolize
+ epunt_cxx #74077
+}
+
+src_compile() {
+
+ [ "${ARCH}" == "alpha" -a "${CC}" == "ccc" ] && \
+ die "Dont compile fontconfig with ccc, it doesnt work very well"
+
+ # disable docs only disables local docs generation, they come with the tarball
+ econf --disable-docs \
+ --disable-docbook \
+ --with-docdir=/usr/share/doc/${PF} \
+ --with-default-fonts=/usr/share/fonts \
+ --with-add-fonts=/usr/local/share/fonts,/usr/X11R6/lib/X11/fonts \
+ || die
+
+ # this triggers sandbox, we do this ourselves
+ sed -i "s:fc-cache/fc-cache -f -v:sleep 0:" Makefile
+
+ emake -j1 || die
+}
+
+src_install() {
+ make DESTDIR="${D}" install || die
+
+ insinto /etc/fonts
+ doins "${S}"/fonts.conf
+ newins "${S}"/fonts.conf fonts.conf.new
+
+ cd "${S}"
+ newman doc/fonts-conf.5 fonts-conf.5
+ newman fc-cache/fc-cache.man fc-cache.1
+ newman fc-list/fc-list.man fc-list.1
+
+ dohtml doc/fontconfig-user.html
+ dodoc doc/fontconfig-user.{txt,pdf}
+
+ if use doc; then
+ doman doc/Fc*.3
+ dohtml doc/fontconfig-devel.html doc
+ dohtml -r doc/fontconfig-devel
+ dodoc doc/fontconfig-devel.{txt,pdf}
+ fi
+
+ dodoc AUTHORS ChangeLog NEWS README
+}
+
+pkg_postinst() {
+
+ # Changes should be made to /etc/fonts/local.conf, and as we had
+ # too much problems with broken fonts.conf, we force update it ...
+ # <azarah@gentoo.org> (11 Dec 2002)
+ ewarn "Please make fontconfig related changes to /etc/fonts/local.conf,"
+ ewarn "and NOT to /etc/fonts/fonts.conf, as it will be replaced!"
+ mv -f ${ROOT}/etc/fonts/fonts.conf.new ${ROOT}/etc/fonts/fonts.conf
+ rm -f ${ROOT}/etc/fonts/._cfg????_fonts.conf
+
+ if [ "${ROOT}" = "/" ]
+ then
+ echo
+ einfo "Creating font cache..."
+ /usr/bin/fc-cache
+ fi
+
+}