summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSergey Kuleshov <sergey@gentoo.org>2003-10-25 14:46:21 +0000
committerSergey Kuleshov <sergey@gentoo.org>2003-10-25 14:46:21 +0000
commitf8c329ea225f4adb9f08eaee6e0189767b1ff85f (patch)
tree59c37ca6fd6452a52adad8ac2c08f01ed0c47fae /media-sound/xmms/files
parentFixed a bug in russian-charset-csa20 patch. (diff)
downloadgentoo-2-f8c329ea225f4adb9f08eaee6e0189767b1ff85f.tar.gz
gentoo-2-f8c329ea225f4adb9f08eaee6e0189767b1ff85f.tar.bz2
gentoo-2-f8c329ea225f4adb9f08eaee6e0189767b1ff85f.zip
Fixed a bug in russian-charset-csa20 patch.
Diffstat (limited to 'media-sound/xmms/files')
-rw-r--r--media-sound/xmms/files/xmms-1.2.8-russian-charset-csa20.patch100
1 files changed, 60 insertions, 40 deletions
diff --git a/media-sound/xmms/files/xmms-1.2.8-russian-charset-csa20.patch b/media-sound/xmms/files/xmms-1.2.8-russian-charset-csa20.patch
index da7ed8496d08..7ee57e05c82b 100644
--- a/media-sound/xmms/files/xmms-1.2.8-russian-charset-csa20.patch
+++ b/media-sound/xmms/files/xmms-1.2.8-russian-charset-csa20.patch
@@ -246,8 +246,8 @@ diff -dPNur xmms-1.2.8/Input/vorbis/vorbis.c xmms-1.2.8-patched/Input/vorbis/vor
return displaytitle;
diff -dPNur xmms-1.2.8/libxmms/charset_auto_russian.h xmms-1.2.8-patched/libxmms/charset_auto_russian.h
--- xmms-1.2.8/libxmms/charset_auto_russian.h 1970-01-01 01:00:00.000000000 +0100
-+++ xmms-1.2.8-patched/libxmms/charset_auto_russian.h 2003-10-24 02:03:57.000000000 +0200
-@@ -0,0 +1,585 @@
++++ xmms-1.2.8-patched/libxmms/charset_auto_russian.h 2003-10-24 18:22:39.000000000 +0200
+@@ -0,0 +1,592 @@
+/*
+Originaly stealed from GPPL's (http://gppl.terminal.ru) autorecode-xmms1.2.7 patch,
+
@@ -259,7 +259,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset_auto_russian.h xmms-1.2.8-patched/libxmms
+ New tables, new algorithm to detect even upercase phrases (~99.7% of right answers)
+
+csa19:
-+ Enca support
++ CP866 support
+*/
+
+typedef struct lng_stat {
@@ -764,9 +764,12 @@ diff -dPNur xmms-1.2.8/libxmms/charset_auto_russian.h xmms-1.2.8-patched/libxmms
+ int bytes=0,rflag=0;
+ unsigned char tmp;
+ int res=0;
++ long l;
+
-+ if (!len) len=strlen(buf);
-+ for (i=0;i<len;i++) {
++ l=strlen(buf);
++ if ((len)&&(l>len)) l=len;
++
++ for (i=0;i<l;i++) {
+ if (buf[i]<128) continue;
+
+ if (bytes>0) {
@@ -801,7 +804,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset_auto_russian.h xmms-1.2.8-patched/libxmms
+ }
+
+ if ((buf[i]==0xD0)||(buf[i]==0xD1)) {
-+ if (i+1==len) break;
++ if (i+1==l) break;
+
+ }
+ }
@@ -811,8 +814,12 @@ diff -dPNur xmms-1.2.8/libxmms/charset_auto_russian.h xmms-1.2.8-patched/libxmms
+static int check_cp866(unsigned char *buf, int len) {
+ long i;
+ int res=0;
-+ if (!len) len=strlen(buf);
-+ for (i=0;i<len;i++) {
++ long l;
++
++ l=strlen(buf);
++ if ((len)&&(l>len)) l=len;
++
++ for (i=0;i<l;i++) {
+ if ((buf[i]>=0x80)&&(buf[i]<=0x9F)) res++;
+ else if ((buf[i]>=0xA0)&&(buf[i]<=0xAF)) res++;
+ else if ((buf[i]>=0xC0)&&(buf[i]<0xE0)) res-=2;
@@ -835,8 +842,8 @@ diff -dPNur xmms-1.2.8/libxmms/charset_auto_russian.h xmms-1.2.8-patched/libxmms
+}
diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
--- xmms-1.2.8/libxmms/charset.c 1970-01-01 01:00:00.000000000 +0100
-+++ xmms-1.2.8-patched/libxmms/charset.c 2003-10-24 03:01:40.000000000 +0200
-@@ -0,0 +1,848 @@
++++ xmms-1.2.8-patched/libxmms/charset.c 2003-10-24 19:10:29.000000000 +0200
+@@ -0,0 +1,870 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
@@ -889,7 +896,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+static int xmms_autocharset_fs = 1;
+static int xmms_charset_fm = 1;
+
-+static int xmms_autocharset_changed = 0;
++static int xmms_autocharset_changed = -1;
+static iconv_t *xmms_autocharset = NULL;
+static iconv_t *xmms_autocharset_id2utf = NULL;
+static iconv_t *xmms_autocharset_id2id = NULL;
@@ -984,6 +991,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ xmms_autocharset_fs=fs;
+ xmms_charset_fm=fm;
+ xmms_autocharset_changed=1;
++ xmms_charset_changed=1;
+}
+
+void xmms_autocharset_init(int m) {
@@ -992,7 +1000,9 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+}
+
+void xmms_autocharset_free() {
++#ifdef AUTO_ENCA_SUPPORT
+ int i,j;
++#endif
+ xmms_autocharset_iconv_close();
+#ifdef AUTO_ENCA_SUPPORT
+ for (i=0;i<autocharset_list_ni;i++)
@@ -1014,10 +1024,12 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ const char **encodings;
+ const char *output, *id3, *fs;
+ int i;
++
++ assert(xmms_autocharset_changed>=0);
+
+ if ((!xmms_autocharset_changed)&&(!xmms_charset_changed)) return;
+ xmms_autocharset_iconv_close();
-+ xmms_autocharset_changed=0;
++ xmms_autocharset_changed=-1;
+
+ xmms_autocharset_number = xmms_autocharset_number_charsets(0);
+ if (!xmms_autocharset_number) return;
@@ -1088,12 +1100,14 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+
+ }
+ }
++ xmms_autocharset_changed=0;
+}
+
+
+static iconv_t xmms_autocharset_get(char *buf, int len) {
+ int i;
+ xmms_autocharset_iconv_open();
++ if (xmms_autocharset_changed<0) return (iconv_t)-1;
+ if ((xmms_autocharset)&&(xmms_autocharset_number>0)) {
+ i=autocharset_list[xmms_autocharset_mode].func(buf,len);
+ if (i<xmms_autocharset_number) return xmms_autocharset[i];
@@ -1104,6 +1118,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+static iconv_t xmms_autocharset_get_id2id(char *buf, int len) {
+ int i;
+ xmms_autocharset_iconv_open();
++ if (xmms_autocharset_changed<0) return (iconv_t)-1;
+ if ((xmms_autocharset_id2id)&&(xmms_autocharset_number>0)) {
+ i=autocharset_list[xmms_autocharset_mode].func(buf,len);
+ if (i<xmms_autocharset_number) return xmms_autocharset_id2id[i];
@@ -1114,6 +1129,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+static iconv_t xmms_autocharset_get_id2utf(char *buf, int len) {
+ int i;
+ xmms_autocharset_iconv_open();
++ if (xmms_autocharset_changed<0) return (iconv_t)-1;
+ if ((xmms_autocharset_id2utf)&&(xmms_autocharset_number>0)) {
+ i=autocharset_list[xmms_autocharset_mode].func(buf,len);
+ if (i<xmms_autocharset_number) return xmms_autocharset_id2utf[i];
@@ -1124,6 +1140,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+static iconv_t xmms_autocharset_get_id2fs(char *buf, int len) {
+ int i;
+ xmms_autocharset_iconv_open();
++ if (xmms_autocharset_changed<0) return (iconv_t)-1;
+ if ((xmms_autocharset_id2fs)&&(xmms_autocharset_number>0)) {
+ i=autocharset_list[xmms_autocharset_mode].func(buf,len);
+ if (i<xmms_autocharset_number) return xmms_autocharset_id2fs[i];
@@ -1439,7 +1456,6 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ }
+ } else {
+ perror("iconv convert: convert");
-+// perror(buf);
+ return NULL;
+ }
+ }
@@ -1468,6 +1484,8 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ iconv_t icnv;
+
+ xmms_charset_iconv_open();
++ xmms_autocharset_iconv_open();
++
+ icnv = xmms_autocharset_get(buf,len);
+
+ if (icnv == (iconv_t)-2) return NULL;
@@ -1490,7 +1508,9 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+char *xmms_charset_recode_fs(char *buf, int len, int *rlen) {
+ iconv_t icnv;
+ char *tmp1, *tmp2;
++
+ xmms_charset_iconv_open();
++
+ if (xmms_autocharset_fs) {
+ icnv = xmms_autocharset_get(buf,len);
+ if (icnv != (iconv_t)-1) {
@@ -1504,7 +1524,8 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ } else return tmp1;
+ }
+ }
-+ else return xmms_charset_recode(iconv_output,tmp1,0,rlen);
++ else if (iconv_output!=(iconv_t)-1) return xmms_charset_recode(iconv_output,buf,len,rlen);
++ else return NULL;
+ }
+ }
+ if (iconv_fs != (iconv_t)-1)
@@ -1514,7 +1535,9 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+
+char *xmms_charset_recode_fsout(char *buf, int len, int *rlen) {
+ iconv_t icnv;
++
+ xmms_charset_iconv_open();
++
+ if (xmms_autocharset_fs) {
+ icnv = xmms_autocharset_get(buf,len);
+ if (icnv == (iconv_t)-2) return NULL;
@@ -1532,7 +1555,6 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ int i;
+*/
+ if (!xmms_charset_fm) return NULL;
-+
+ xmms_charset_iconv_open();
+/*
+ if (xmms_autocharset_fs) {
@@ -1574,17 +1596,18 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ iconv_t icnv;
+
+ if (!xmms_charset_fm) return NULL;
-+
+ xmms_charset_iconv_open();
++
+ icnv = xmms_autocharset_get_id2fs(buf,len);
+
+ if (icnv==(iconv_t)-2) return NULL;
+
-+ if (icnv != (iconv_t)-1)
++ if (icnv != (iconv_t)-1) {
+ return xmms_charset_recode(icnv, buf, len, rlen);
-+
-+ if (iconv_pl2fs != (iconv_t)-1)
++ }
++ if (iconv_pl2fs != (iconv_t)-1) {
+ return xmms_charset_recode(iconv_pl2fs, buf, len, rlen);
++ }
+ return NULL;
+}
+
@@ -1608,14 +1631,21 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ if (!xmms_charset_fm) return NULL;
+ if (!xmms_autocharset_fs) return NULL;
+
++ xmms_charset_iconv_open();
++ xmms_autocharset_iconv_open();
++ if (xmms_autocharset_changed<0) return NULL;
++ if (!xmms_autocharset_fs2id) return NULL;
++
++
+ if (check_file(path,buf)) return NULL;
+ encodings = autocharset_list[xmms_autocharset_mode].encodings;
+
+ len=strlen(buf);
+ for (i=0;encodings[i];i++) {
-+ if (xmms_autocharset_fs2id[i]>(iconv_t)0) {
++ if ((xmms_autocharset_fs2id[i]!=(iconv_t)-1)&&(xmms_autocharset_fs2id[i]!=(iconv_t)-2)) {
+ tmp=xmms_charset_recode(xmms_autocharset_fs2id[i],buf,len,0);
+ if (tmp) {
++ puts(tmp);
+ if (check_file(path,tmp)) return tmp;
+ free(tmp);
+ }
@@ -1659,8 +1689,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+ icnv = xmms_autocharset_get_id2utf(buf,len);
+ if (icnv==(iconv_t)-2) return NULL;
+ if (icnv!=(iconv_t)-1) {
-+ str = xmms_charset_recode(icnv, buf, len, &rlen);
-+ puts(str);
++ str = xmms_charset_recode(icnv, buf, len, rlen);
+ if (str) return str;
+ }
+ }
@@ -1687,8 +1716,8 @@ diff -dPNur xmms-1.2.8/libxmms/charset.c xmms-1.2.8-patched/libxmms/charset.c
+
diff -dPNur xmms-1.2.8/libxmms/charset_config.h xmms-1.2.8-patched/libxmms/charset_config.h
--- xmms-1.2.8/libxmms/charset_config.h 1970-01-01 01:00:00.000000000 +0100
-+++ xmms-1.2.8-patched/libxmms/charset_config.h 2003-10-24 01:37:22.000000000 +0200
-@@ -0,0 +1,46 @@
++++ xmms-1.2.8-patched/libxmms/charset_config.h 2003-10-24 13:31:47.000000000 +0200
+@@ -0,0 +1,37 @@
+/* Misc configuration options */
+
+#define CHARSET_MAX_STRING_SIZE 1024 /* 256 symbols in UTF-32 */
@@ -1706,21 +1735,17 @@ diff -dPNur xmms-1.2.8/libxmms/charset_config.h xmms-1.2.8-patched/libxmms/chars
+ {"Russian", &autocharset_russian, {"CP1251","KOI8-R","UTF-8","IBM866"} },
+ {"Russian UpCase",&autocharset_russian_uc, {"CP1251","KOI8-R","UTF-8","IBM866"} }
+}},
-+{"uk","Ukrainian",{"Default","KOI8-U","CP1251","UTF-8","IBM855","MACCYRILLIC","ISO8859-5","CP1125", NULL},1,{
-+ {"Off", NULL, {NULL}}
++{"uk","Ukrainian",{"Default","KOI8-U","CP1251","UTF-8","IBM855","MACCYRILLIC","ISO8859-5","CP1125", NULL},3,{
++ {"Off", NULL, {NULL}},
++ {"Russian", &autocharset_russian, {"CP1251","KOI8-R","UTF-8","IBM866"} },
++ {"Russian UpCase",&autocharset_russian_uc, {"CP1251","KOI8-R","UTF-8","IBM866"} }
+}},
+{NULL,NULL,{NULL},0}
+};
+
+const charset_list_t charset_list_default = { "Default", "KOI8-R", "CP1251", "CP866", "UTF-8", NULL };
+const char **charset_list=charset_list_default;
-+/*
-+#ifdef AUTO_ENCA_SUPPORT
-+const int autocharset_list_ni=4;
-+#else
-+const int autocharset_list_ni=3;
-+#endif
-+*/
++
+#define autocharset_list_ni_default 3
+struct autocharset_list_t autocharset_list_default[] = {
+ {"Off", NULL, {NULL}},
@@ -1730,11 +1755,6 @@ diff -dPNur xmms-1.2.8/libxmms/charset_config.h xmms-1.2.8-patched/libxmms/chars
+
+int autocharset_list_ni=autocharset_list_ni_default;
+struct autocharset_list_t *autocharset_list=autocharset_list_default;
-+/*
-+#ifdef AUTO_ENCA_SUPPORT
-+ ,{"Russian (LibEnca)",&autocharset_enca_russian,{"CP1251","KOI8-R","UTF-8"}}
-+#endif
-+*/
diff -dPNur xmms-1.2.8/libxmms/charset_defines.h xmms-1.2.8-patched/libxmms/charset_defines.h
--- xmms-1.2.8/libxmms/charset_defines.h 1970-01-01 01:00:00.000000000 +0100
+++ xmms-1.2.8-patched/libxmms/charset_defines.h 2003-10-24 03:04:12.000000000 +0200
@@ -1746,7 +1766,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset_defines.h xmms-1.2.8-patched/libxmms/char
+#define ENV_VARIABLE LC_CTYPE
diff -dPNur xmms-1.2.8/libxmms/charset.h xmms-1.2.8-patched/libxmms/charset.h
--- xmms-1.2.8/libxmms/charset.h 1970-01-01 01:00:00.000000000 +0100
-+++ xmms-1.2.8-patched/libxmms/charset.h 2003-10-24 01:35:54.000000000 +0200
++++ xmms-1.2.8-patched/libxmms/charset.h 2003-10-24 13:31:19.000000000 +0200
@@ -0,0 +1,80 @@
+#ifndef XMMS_CHARSET_H
+#define XMMS_CHARSET_H
@@ -1757,7 +1777,7 @@ diff -dPNur xmms-1.2.8/libxmms/charset.h xmms-1.2.8-patched/libxmms/charset.h
+int autocharset_russian_uc(char *buf,int len);
+
+#ifdef AUTO_ENCA_SUPPORT
-+int autocharset_enca_russian(char *buf, int len);
++static int autocharset_enca(char *buf, int len);
+#endif
+
+/*