aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarcus <marcus@FreeBSD.org>2003-03-03 01:14:13 +0800
committermarcus <marcus@FreeBSD.org>2003-03-03 01:14:13 +0800
commit1b5949602aac0bc2670f6d6b5e9116e6bde01a24 (patch)
tree0c9520a26c144be0790023020e1e7cb84b372199
parent03dfbbcd9947152ea2b4b7e4e1109c374ddcb956 (diff)
downloadfreebsd-ports-gnome-1b5949602aac0bc2670f6d6b5e9116e6bde01a24.tar.gz
freebsd-ports-gnome-1b5949602aac0bc2670f6d6b5e9116e6bde01a24.tar.zst
freebsd-ports-gnome-1b5949602aac0bc2670f6d6b5e9116e6bde01a24.zip
Sync fontconfig with the XFree86 4.3.0 release.
* Fixes a segfault * Performs country-independent matching for Chinese languages * Finishes off the UTF-16 conversion code * Adds a section on local.conf to fontconfig.3 Obtained from: XFree86 CVS
-rw-r--r--x11-fonts/fontconfig/Makefile2
-rw-r--r--x11-fonts/fontconfig/files/patch-fc-cvs212
2 files changed, 213 insertions, 1 deletions
diff --git a/x11-fonts/fontconfig/Makefile b/x11-fonts/fontconfig/Makefile
index d4e1988ad990..7cc969bc62e5 100644
--- a/x11-fonts/fontconfig/Makefile
+++ b/x11-fonts/fontconfig/Makefile
@@ -7,7 +7,7 @@
PORTNAME= fontconfig
PORTVERSION= 2.1
-PORTREVISION= 4
+PORTREVISION= 5
CATEGORIES= x11-fonts
MASTER_SITES= http://www.fontconfig.org/fontconfig/release/
DISTNAME= fcpackage.${PORTVERSION:S/./_/}
diff --git a/x11-fonts/fontconfig/files/patch-fc-cvs b/x11-fonts/fontconfig/files/patch-fc-cvs
new file mode 100644
index 000000000000..e1eac2e98829
--- /dev/null
+++ b/x11-fonts/fontconfig/files/patch-fc-cvs
@@ -0,0 +1,212 @@
+--- fc-lang/fc-lang.c 2002/08/22 07:36:43 1.3
++++ fc-lang/fc-lang.c 2002/12/14 02:03:58 1.4
+@@ -165,22 +165,38 @@ static int compare (const void *a, const
+ return FcStrCmpIgnoreCase (*as, *bs);
+ }
+
++#define MAX_LANG 1024
++#define MAX_LANG_SET_MAP ((MAX_LANG + 31) / 32)
++
++#define BitSet(map, id) ((map)[(id)>>5] |= ((FcChar32) 1 << ((id) & 0x1f)))
++#define BitGet(map, id) ((map)[(id)>>5] >> ((id) & 0x1f)) & 1)
++
+ int
+ main (int argc, char **argv)
+ {
+- char *files[1024];
+- FcCharSet *sets[1024];
+- int duplicate[1024];
+- char *names[1024];
++ char *files[MAX_LANG];
++ FcCharSet *sets[MAX_LANG];
++ int duplicate[MAX_LANG];
++ int country[MAX_LANG];
++ char *names[MAX_LANG];
++ char *langs[MAX_LANG];
+ FILE *f;
++ int ncountry = 0;
+ int i = 0;
+ FcCharLeaf **leaves, **sleaves;
+ int total_leaves = 0;
+ int l, sl, tl;
++ int c;
+ char line[1024];
++ FcChar32 map[MAX_LANG_SET_MAP];
++ int num_lang_set_map;
+
+ while (*++argv)
++ {
++ if (i == MAX_LANG)
++ fatal (*argv, 0, "Too many languages");
+ files[i++] = *argv;
++ }
+ files[i] = 0;
+ qsort (files, i, sizeof (char *), compare);
+ i = 0;
+@@ -191,6 +207,10 @@ main (int argc, char **argv)
+ fatal (files[i], 0, strerror (errno));
+ sets[i] = scan (f, files[i]);
+ names[i] = get_name (files[i]);
++ langs[i] = get_lang(names[i]);
++ if (strchr (langs[i], '-'))
++ country[ncountry++] = i;
++
+ total_leaves += sets[i]->num;
+ i++;
+ fclose (f);
+@@ -319,10 +339,54 @@ main (int argc, char **argv)
+ " { FC_REF_CONSTANT, %d, "
+ "(FcCharLeaf **) leaves_%s, "
+ "(FcChar16 *) numbers_%s } },\n",
+- get_lang(names[i]),
++ langs[i],
+ sets[j]->num, names[j], names[j]);
+ }
+ printf ("};\n\n");
++ printf ("#define NUM_LANG_CHAR_SET %d\n", i);
++ num_lang_set_map = (i + 31) / 32;
++ printf ("#define NUM_LANG_SET_MAP %d\n", num_lang_set_map);
++ /*
++ * Dump indices with country codes
++ */
++ if (ncountry)
++ {
++ int ncountry_ent = 0;
++ printf ("\n");
++ printf ("static const FcChar32 fcLangCountrySets[][NUM_LANG_SET_MAP] = {\n");
++ for (c = 0; c < ncountry; c++)
++ {
++ i = country[c];
++ if (i >= 0)
++ {
++ int l = strchr (langs[i], '-') - langs[i];
++ int d, k;
++
++ for (k = 0; k < num_lang_set_map; k++)
++ map[k] = 0;
++
++ BitSet (map, i);
++ for (d = c + 1; d < ncountry; d++)
++ {
++ int j = country[d];
++ if (j >= 0 && !strncmp (langs[j], langs[i], l))
++ {
++ BitSet(map, j);
++ country[d] = -1;
++ }
++ }
++ printf (" {");
++ for (k = 0; k < num_lang_set_map; k++)
++ printf (" 0x%08x,", map[k]);
++ printf (" }, /* %*.*s */\n",
++ l, l, langs[i]);
++ ++ncountry_ent;
++ }
++ }
++ printf ("};\n\n");
++ printf ("#define NUM_COUNTRY_SET %d\n", ncountry_ent);
++ }
++
+ while (fgets (line, sizeof (line), stdin))
+ fputs (line, stdout);
+
+--- src/fccfg.c 2002/08/31 22:17:32 1.23
++++ src/fccfg.c 2002/12/21 02:31:53 1.24
+@@ -1141,7 +1141,11 @@ FcConfigSubstituteWithPat (FcConfig *
+ if ((t->kind == FcMatchFont || kind == FcMatchPattern) &&
+ !FcStrCmpIgnoreCase ((FcChar8 *) t->field,
+ (FcChar8 *) e->field))
++ {
++ if (!st[i].elt)
++ t = 0;
+ break;
++ }
+ }
+ switch (e->op) {
+ case FcOpAssign:
+--- src/fclang.c 2002/08/26 23:34:31 1.7
++++ src/fclang.c 2002/12/14 02:03:59 1.8
+@@ -31,9 +31,6 @@ typedef struct {
+
+ #include "../fc-lang/fclang.h"
+
+-#define NUM_LANG_CHAR_SET (sizeof (fcLangCharSets) / sizeof (fcLangCharSets[0]))
+-#define NUM_LANG_SET_MAP ((NUM_LANG_CHAR_SET + 31) / 32)
+-
+ struct _FcLangSet {
+ FcChar32 map[NUM_LANG_SET_MAP];
+ FcStrSet *extra;
+@@ -339,13 +336,21 @@ FcLangSetCompareStrSet (const FcLangSet
+ FcLangResult
+ FcLangSetCompare (const FcLangSet *lsa, const FcLangSet *lsb)
+ {
+- int i;
++ int i, j;
+ FcLangResult best, r;
+
+ for (i = 0; i < NUM_LANG_SET_MAP; i++)
+ if (lsa->map[i] & lsb->map[i])
+ return FcLangEqual;
+ best = FcLangDifferentLang;
++ for (j = 0; j < NUM_COUNTRY_SET; j++)
++ for (i = 0; i < NUM_LANG_SET_MAP; i++)
++ if ((lsa->map[i] & fcLangCountrySets[j][i]) &&
++ (lsb->map[i] & fcLangCountrySets[j][i]))
++ {
++ best = FcLangDifferentCountry;
++ break;
++ }
+ if (lsa->extra)
+ {
+ r = FcLangSetCompareStrSet (lsb, lsa->extra);
+--- fc-lang/fclang.h 2002/10/21 17:03:47 1.20
++++ fc-lang/fclang.h 2002/12/14 02:03:58 1.21
+@@ -3996,3 +3996,11 @@ static const FcLangCharSet fcLangCharSe
+ { FC_REF_CONSTANT, 1, (FcCharLeaf **) leaves_fj, (FcChar16 *) numbers_fj } },
+ };
+
++#define NUM_LANG_CHAR_SET 175
++#define NUM_LANG_SET_MAP 6
++
++static const FcChar32 fcLangCountrySets[][NUM_LANG_SET_MAP] = {
++ { 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00003e00, }, /* zh */
++};
++
++#define NUM_COUNTRY_SET 1
+--- fontconfig/fcprivate.h 2002/08/22 07:36:44 1.6
++++ fontconfig/fcprivate.h 2002/12/04 10:28:03 1.7
+@@ -87,7 +87,7 @@ _FcPatternVapBuild_bail1: \
+ if (!orig) \
+ FcPatternDestroy (__p__); \
+ _FcPatternVapBuild_bail0: \
+- result = 0; \
++ result = (void*)0; \
+ \
+ _FcPatternVapBuild_return: \
+ ; \
+--- src/fcstr.c 2002/08/31 22:17:32 1.10
++++ src/fcstr.c 2002/12/14 01:59:38 1.11
+@@ -283,7 +283,7 @@ FcUtf16ToUcs4 (const FcChar8 *src_orig,
+ if ((b & 0xfc00) != 0xdc00)
+ return 0;
+ result = ((((FcChar32) a & 0x3ff) << 10) |
+- ((FcChar32) b & 0x3ff)) | 0x10000;
++ ((FcChar32) b & 0x3ff)) + 0x10000;
+ }
+ else
+ result = a;
+--- src/fontconfig.man 2002/10/02 07:11:30 1.7
++++ src/fontconfig.man 2003/02/16 17:44:36 1.8
+@@ -1453,6 +1453,12 @@ match the available fonts. It is in xml
+
+ .B fonts.dtd
+ is a DTD that describes the format of the configuration files.
++
++.B local.conf
++is sourced by the default system-wide fonts.conf file.
++Note that the normal 'make install' procedure for XFree86 is to
++replace any existing fonts.conf file with the new version. Place
++any local customizations in local.conf which this file references.
+
+ .B ~/.fonts.conf
+ is the conventional location for per-user font configuration, although the