diff options
author | jmcneill <jmcneill@pkgsrc.org> | 2002-12-30 19:19:18 +0000 |
---|---|---|
committer | jmcneill <jmcneill@pkgsrc.org> | 2002-12-30 19:19:18 +0000 |
commit | 90d9e209c5d3445ebc542591f03ee4d42f9b8ff4 (patch) | |
tree | 7845647d5f81877445eb618ec27c8ce8502b0839 /graphics/dia/patches | |
parent | a5f3c38031e98f6ca1aae67d484bb6d908458c43 (diff) | |
download | pkgsrc-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-ba | 45 |
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; + } + |