summaryrefslogtreecommitdiff
path: root/graphics/dia/patches
diff options
context:
space:
mode:
authorjmcneill <jmcneill@pkgsrc.org>2002-12-30 19:19:18 +0000
committerjmcneill <jmcneill@pkgsrc.org>2002-12-30 19:19:18 +0000
commit90d9e209c5d3445ebc542591f03ee4d42f9b8ff4 (patch)
tree7845647d5f81877445eb618ec27c8ce8502b0839 /graphics/dia/patches
parenta5f3c38031e98f6ca1aae67d484bb6d908458c43 (diff)
downloadpkgsrc-90d9e209c5d3445ebc542591f03ee4d42f9b8ff4.tar.gz
Make dia fallback to UTF-8 if it doesn't understand our charset instead of
segfaulting -- from Jarkko Torppa. Closes pkg/19008. Now that dia works again, remove the BROKEN tag from the Makefile.
Diffstat (limited to 'graphics/dia/patches')
-rw-r--r--graphics/dia/patches/patch-ba45
1 files changed, 41 insertions, 4 deletions
diff --git a/graphics/dia/patches/patch-ba b/graphics/dia/patches/patch-ba
index 1733e12cb6b..ef4eb97928a 100644
--- a/graphics/dia/patches/patch-ba
+++ b/graphics/dia/patches/patch-ba
@@ -1,8 +1,17 @@
-$NetBSD: patch-ba,v 1.1 2002/09/07 17:40:51 mjl Exp $
+$NetBSD: patch-ba,v 1.2 2002/12/30 19:19:18 jmcneill Exp $
---- lib/charconv.c.orig Fri May 17 01:06:50 2002
-+++ lib/charconv.c Sun Sep 1 02:54:46 2002
-@@ -98,7 +98,8 @@
+--- charconv.c.orig Thu May 16 20:06:50 2002
++++ charconv.c Mon Dec 30 15:13:23 2002
+@@ -69,6 +69,8 @@
+ {
+ static char *this_charset = NULL;
+ static int local_is_utf8 = 0;
++ unicode_iconv_t t1 = (unicode_iconv_t)(-1);
++ unicode_iconv_t t2 = (unicode_iconv_t)(-1);
+
+ if (this_charset) {
+ *charset = this_charset;
+@@ -98,7 +100,8 @@
if ((*charset == NULL) ||
(0==strcmp(*charset,"US-ASCII")) ||
@@ -12,3 +21,31 @@ $NetBSD: patch-ba,v 1.1 2002/09/07 17:40:51 mjl Exp $
/* we got basic stupid ASCII here. We use its sane
superset instead. Especially since libxml2 doesn't like
the pedantic name of ASCII. */
+@@ -108,8 +111,25 @@
+ }
+
+ this_charset = *charset;
+- local_is_utf8 = (*charset) && (0==strcmp(*charset,"UTF-8"));
+-
++ if (*charset) {
++ if (strcmp(*charset, "UTF-8") != 0) {
++ if ((t1 = unicode_iconv_open(*charset, "UTF-8")) == (unicode_iconv_t)(-1)
++ || (t2 = unicode_iconv_open("UTF-8", *charset)) ==
++ (unicode_iconv_t)(-1)) {
++ g_warning("unicode_iconv_open() does not understand your charset %s\n",
++ "Using UTF-8 as local. Set LC_CTYPE or CHARSET.",
++ *charset);
++ local_is_utf8 = 1;
++ *charset = "UTF-8";
++ }
++ } else
++ local_is_utf8 = 1;
++ }
++ if (t1 != (unicode_iconv_t)(-1))
++ unicode_iconv_close(t1);
++ if (t2 != (unicode_iconv_t)(-1))
++ unicode_iconv_close(t2);
++
+ return local_is_utf8;
+ }
+