aboutsummaryrefslogtreecommitdiffstats
path: root/x11-toolkits/pango
diff options
context:
space:
mode:
authormarcus <marcus@FreeBSD.org>2004-06-01 03:41:46 +0800
committermarcus <marcus@FreeBSD.org>2004-06-01 03:41:46 +0800
commit9b2d796500cd98e45caf4785b8e35fa9bb32e312 (patch)
treed59737bcedd029bb6fc9bf3ae7ae6f56f36249c6 /x11-toolkits/pango
parent70ee535472ac0e027cf6ca1f809a75b9ce82f78f (diff)
downloadfreebsd-ports-gnome-9b2d796500cd98e45caf4785b8e35fa9bb32e312.tar.gz
freebsd-ports-gnome-9b2d796500cd98e45caf4785b8e35fa9bb32e312.tar.zst
freebsd-ports-gnome-9b2d796500cd98e45caf4785b8e35fa9bb32e312.zip
Fix a crash when trying to render non-Hangul unicode characters. This was
especially problematic in pan and evolution. Obtained from: GNOME CVS Tested by: Tom McLaughlin <tmclaugh@sdf.lonestar.org>
Diffstat (limited to 'x11-toolkits/pango')
-rw-r--r--x11-toolkits/pango/Makefile1
-rw-r--r--x11-toolkits/pango/files/patch-hangul85
2 files changed, 86 insertions, 0 deletions
diff --git a/x11-toolkits/pango/Makefile b/x11-toolkits/pango/Makefile
index 5aae206ceffb..a2d15fd5fd21 100644
--- a/x11-toolkits/pango/Makefile
+++ b/x11-toolkits/pango/Makefile
@@ -7,6 +7,7 @@
PORTNAME= pango
PORTVERSION= 1.4.0
+PORTREVISION= 1
CATEGORIES= x11-toolkits
MASTER_SITES= ${MASTER_SITE_GNOME:S,%SUBDIR%,sources/${PORTNAME}/1.4,} \
ftp://ftp.gtk.org/pub/gtk/v2.3/
diff --git a/x11-toolkits/pango/files/patch-hangul b/x11-toolkits/pango/files/patch-hangul
new file mode 100644
index 000000000000..36e55c8ad068
--- /dev/null
+++ b/x11-toolkits/pango/files/patch-hangul
@@ -0,0 +1,85 @@
+===================================================================
+RCS file: /cvs/gnome/pango/modules/hangul/hangul-fc.c,v
+retrieving revision 1.13
+retrieving revision 1.14
+diff -u -r1.13 -r1.14
+--- modules/hangul/hangul-fc.c 2003/09/23 23:11:51 1.13
++++ modules/hangul/hangul-fc.c 2004/04/17 16:17:57 1.14
+@@ -1,7 +1,7 @@
+ /* Pango
+ * hangul-fc.c: Hangul shaper for FreeType based backends
+ *
+- * Copyright (C) 2002 Changwoo Ryu
++ * Copyright (C) 2002-2004 Changwoo Ryu
+ * Author: Changwoo Ryu <cwryu@debian.org>
+ *
+ * This library is free software; you can redistribute it and/or
+@@ -275,6 +275,21 @@
+ render_tone(font, tone, glyphs, n_glyphs, cluster_offset);
+ }
+
++static void
++render_basic (PangoFont *font, gunichar wc,
++ PangoGlyphString *glyphs, int *n_glyphs, int cluster_offset)
++{
++ int index;
++ index = find_char (font, wc);
++ pango_glyph_string_set_size (glyphs, *n_glyphs + 1);
++ if (index)
++ set_glyph (font, glyphs, *n_glyphs, cluster_offset, index);
++ else
++ set_glyph (font, glyphs, *n_glyphs, cluster_offset,
++ get_unknown_glyph (font, wc));
++ (*n_glyphs)++;
++}
++
+ static void
+ hangul_engine_shape (PangoEngineShape *engine,
+ PangoFont *font,
+@@ -307,13 +322,14 @@
+ if (n_jamos)
+ {
+ gunichar prev = jamos[n_jamos - 1];
+- if ((!IS_L (prev) && IS_S (wc)) ||
++ if ((!IS_JAMO (wc) && !IS_S (wc) && !IS_M (wc)) ||
++ (!IS_L (prev) && IS_S (wc)) ||
+ (IS_T (prev) && IS_L (wc)) ||
+ (IS_V (prev) && IS_L (wc)) ||
+ (IS_T (prev) && IS_V (wc)) ||
+- IS_M(prev))
++ IS_M (prev))
+ {
+- /* Draw a syllable. */
++ /* Draw a syllable with these jamos. */
+ render_syllable (font, jamos, n_jamos, glyphs,
+ &n_glyphs, start - text);
+ n_jamos = 0;
+@@ -333,7 +349,12 @@
+ jamos = g_renew (gunichar, jamos, max_jamos);
+ }
+
+- if (IS_S (wc))
++ if (!IS_JAMO (wc) && !IS_S (wc) && !IS_M (wc))
++ {
++ render_basic (font, wc, glyphs, &n_glyphs, start - text);
++ start = g_utf8_next_char (p);
++ }
++ else if (IS_S (wc))
+ {
+ jamos[n_jamos++] = L_FROM_S (wc);
+ jamos[n_jamos++] = V_FROM_S (wc);
+===================================================================
+RCS file: /cvs/gnome/pango/modules/hangul/hangul-defs.h,v
+retrieving revision 1.4
+retrieving revision 1.5
+diff -u -r1.4 -r1.5
+--- modules/hangul/hangul-defs.h 2002/11/03 19:56:24 1.4
++++ modules/hangul/hangul-defs.h 2004/04/17 16:17:57 1.5
+@@ -48,6 +48,7 @@
+ #define HTONE1 0x302E
+ #define HTONE2 0x302F
+
++#define IS_JAMO(wc) (wc >= LBASE && wc <= TEND)
+ #define IS_L(wc) (wc >= LBASE && wc <= LEND)
+ #define IS_V(wc) (wc >= VFILL && wc <= VEND)
+ #define IS_T(wc) (wc > TBASE && wc <= TEND)