[Midnightbsd-cvs] mports [15745] trunk/x11-fonts/fontconfig/files: add patches

laffer1 at midnightbsd.org laffer1 at midnightbsd.org
Sun Dec 22 13:25:10 EST 2013


Revision: 15745
          http://svnweb.midnightbsd.org/mports/?rev=15745
Author:   laffer1
Date:     2013-12-22 13:25:09 -0500 (Sun, 22 Dec 2013)
Log Message:
-----------
add patches

Added Paths:
-----------
    trunk/x11-fonts/fontconfig/files/patch-src_fcfreetype.c
    trunk/x11-fonts/fontconfig/files/patch-src_fcxml.c

Added: trunk/x11-fonts/fontconfig/files/patch-src_fcfreetype.c
===================================================================
--- trunk/x11-fonts/fontconfig/files/patch-src_fcfreetype.c	                        (rev 0)
+++ trunk/x11-fonts/fontconfig/files/patch-src_fcfreetype.c	2013-12-22 18:25:09 UTC (rev 15745)
@@ -0,0 +1,65 @@
+From a61e145304da86c8c35b137493bbd8fd5dd1e7f5 Mon Sep 17 00:00:00 2001
+From: Akira TAGOH <akira at tagoh.org>
+Date: Mon, 09 Sep 2013 10:59:31 +0000
+Subject: Fix memory leaks in FcFreeTypeQueryFace
+
+---
+diff --git a/src/fcfreetype.c b/src/fcfreetype.c
+index 02e85cb..e394307 100644
+--- src/fcfreetype.c
++++ src/fcfreetype.c
+@@ -1105,7 +1105,6 @@ FcFreeTypeQueryFace (const FT_Face  face,
+     const char	    *tmp;
+ 
+     FcChar8	    *hashstr = NULL;
+-    char	    *fontdata = NULL;
+     FT_Error	    err;
+     FT_ULong	    len = 0, alen;
+ 
+@@ -1668,15 +1667,21 @@ FcFreeTypeQueryFace (const FT_Face  face,
+     err = FT_Load_Sfnt_Table (face, 0, 0, NULL, &len);
+     if (err == FT_Err_Ok)
+     {
++	char *fontdata;
++
+ 	alen = (len + 63) & ~63;
+ 	fontdata = malloc (alen);
+ 	if (!fontdata)
+ 	    goto bail3;
+ 	err = FT_Load_Sfnt_Table (face, 0, 0, (FT_Byte *)fontdata, &len);
+ 	if (err != FT_Err_Ok)
++	{
++	    free (fontdata);
+ 	    goto bail3;
++	}
+ 	memset (&fontdata[len], 0, alen - len);
+ 	hashstr = FcHashGetSHA256DigestFromMemory (fontdata, len);
++	free (fontdata);
+     }
+     else if (err == FT_Err_Invalid_Face_Handle)
+     {
+@@ -1692,7 +1697,11 @@ FcFreeTypeQueryFace (const FT_Face  face,
+     if (hashstr)
+     {
+ 	if (!FcPatternAddString (pat, FC_HASH, hashstr))
++	{
++	    free (hashstr);
+ 	    goto bail1;
++	}
++	free (hashstr);
+     }
+ bail3:
+ 
+@@ -1783,10 +1792,6 @@ bail3:
+ bail2:
+     FcCharSetDestroy (cs);
+ bail1:
+-    if (hashstr)
+-	free (hashstr);
+-    if (fontdata)
+-	free (fontdata);
+     FcPatternDestroy (pat);
+ bail0:
+     return NULL;
+--
+cgit v0.9.0.2-2-gbebe

Added: trunk/x11-fonts/fontconfig/files/patch-src_fcxml.c
===================================================================
--- trunk/x11-fonts/fontconfig/files/patch-src_fcxml.c	                        (rev 0)
+++ trunk/x11-fonts/fontconfig/files/patch-src_fcxml.c	2013-12-22 18:25:09 UTC (rev 15745)
@@ -0,0 +1,48 @@
+From 3e5f70a16ac6d54f1e01c92ddaa5985deec1b7f9 Mon Sep 17 00:00:00 2001
+From: Akira TAGOH <akira at tagoh.org>
+Date: Mon, 02 Sep 2013 11:51:46 +0000
+Subject: Do not create a config dir for migration when no config files nor dirs
+
+---
+diff --git a/src/fcxml.c b/src/fcxml.c
+index b464b4e..8ff10b6 100644
+--- src/fcxml.c
++++ src/fcxml.c
+@@ -2233,11 +2233,6 @@ FcParseInclude (FcConfigParse *parse)
+ 	    /* No config dir nor file on the XDG directory spec compliant place
+ 	     * so need to guess what it is supposed to be.
+ 	     */
+-	    FcChar8 *parent = FcStrDirname (s);
+-
+-	    if (!FcFileIsDir (parent))
+-		FcMakeDirectory (parent);
+-	    FcStrFree (parent);
+ 	    if (FcStrStr (s, (const FcChar8 *)"conf.d") != NULL)
+ 		goto userdir;
+ 	    else
+@@ -2259,6 +2254,11 @@ FcParseInclude (FcConfigParse *parse)
+ 	{
+ 	    if (FcFileIsDir (filename))
+ 	    {
++		FcChar8 *parent = FcStrDirname (userdir);
++
++		if (!FcFileIsDir (parent))
++		    FcMakeDirectory (parent);
++		FcStrFree (parent);
+ 		if (FcFileIsDir (userdir) ||
+ 		    rename ((const char *)filename, (const char *)userdir) != 0 ||
+ 		    symlink ((const char *)userdir, (const char *)filename) != 0)
+@@ -2272,6 +2272,11 @@ FcParseInclude (FcConfigParse *parse)
+ 	    }
+ 	    else
+ 	    {
++		FcChar8 *parent = FcStrDirname (userconf);
++
++		if (!FcFileIsDir (parent))
++		    FcMakeDirectory (parent);
++		FcStrFree (parent);
+ 		if (FcFileIsFile (userconf) ||
+ 		    rename ((const char *)filename, (const char *)userconf) != 0 ||
+ 		    symlink ((const char *)userconf, (const char *)filename) != 0)
+--
+cgit v0.9.0.2-2-gbebe



More information about the Midnightbsd-cvs mailing list