mirror of
https://git.FreeBSD.org/ports.git
synced 2025-01-30 10:38:37 +00:00
ec966285b6
year-old patch for that purpose, that's available on MASTER_SITE. While at it, apply some other patches sitting at the same location. Some others were already present in our own files/ -- add the link to the originals in those cases. Turn on MAKE_JOBS_SAFE. Bump PORTREVISION. The port needs a loving maintainer: services.xml file, for example, is rather outdated: the self-testing included breaks for most online translation services (for others the translation-results are slightly different from those recorded at 2005).
52 lines
1.4 KiB
C
52 lines
1.4 KiB
C
Copied from
|
|
|
|
http://nongnu.askapache.com/libtranslate/libtranslate-0.99-charsetparse.diff
|
|
|
|
--- src/modules/translate-generic-service.c Mon Apr 11 23:08:47 2005
|
|
+++ src/modules/translate-generic-service.c Mon Apr 11 23:15:54 2005
|
|
@@ -484,7 +484,7 @@
|
|
|
|
if (SOUP_STATUS_IS_SUCCESSFUL(message->status_code))
|
|
{
|
|
- const char *charset = NULL;
|
|
+ char *charset = NULL;
|
|
|
|
if (flags & TRANSFER_CONVERT)
|
|
{
|
|
@@ -493,14 +493,31 @@
|
|
content_type = translate_generic_service_get_header(message, &info, "Content-Type");
|
|
if (content_type)
|
|
{
|
|
- charset = translate_ascii_strcasestr(content_type, "charset=");
|
|
- if (charset)
|
|
- charset += 8;
|
|
+ const char *tmp;
|
|
+
|
|
+ tmp = translate_ascii_strcasestr(content_type, "charset=");
|
|
+ if (tmp)
|
|
+ {
|
|
+ int len;
|
|
+
|
|
+ tmp += 8;
|
|
+ if (*tmp == '\'' || *tmp == '"')
|
|
+ tmp++;
|
|
+
|
|
+ len = strlen(tmp);
|
|
+ if (len > 0 && (tmp[len - 1] == '\'' || tmp[len - 1] == '"'))
|
|
+ len--;
|
|
+
|
|
+ charset = g_strndup(tmp, len);
|
|
+ }
|
|
}
|
|
}
|
|
|
|
if (charset)
|
|
- response = g_convert(message->response.body, message->response.length, "UTF-8", charset, NULL, NULL, err);
|
|
+ {
|
|
+ response = g_convert(message->response.body, message->response.length, "UTF-8", charset, NULL, NULL, err);
|
|
+ g_free(charset);
|
|
+ }
|
|
else
|
|
{
|
|
if ((flags & TRANSFER_CONVERT) && ! g_utf8_validate(message->response.body, message->response.length, NULL))
|