This is the mail archive of the
gdb@sources.redhat.com
mailing list for the GDB project.
charset.c problem with non-en_US locales
- From: Elena Zannoni <ezannoni at redhat dot com>
- To: gdb at sources dot redhat dot com, jimb at redhat dot com
- Date: Tue, 22 Apr 2003 16:04:03 -0400
- Subject: charset.c problem with non-en_US locales
I got a bug report against the gdb in RH Linux which I found
interesting, and since it occurs in FSF gdb as well...
Problem: If you set the locale to Turkish, gdb errors out, complaining
that it cannot find the ISO-8859-1 charset.
[ezannoni at localhost gdb]$ LC_ALL=tr_TR.UTF-8 ./gdb
GDB doesn't know of any character set named `ISO-8859-1'.
No display number 0.
Disabling display 0 to avoid infinite recursion.
[ezannoni at localhost gdb]$
[ezannoni at localhost gdb]$ LC_ALL=tr_TR.ISO-8859-9 ./gdb
GDB doesn't know of any character set named `ISO-8859-1'.
No display number 0.
Disabling display 0 to avoid infinite recursion.
[ezannoni at localhost gdb]$
The real problem is in the use of the tolower() function in charset.c
to do a case insensitive comparison between the two strings
"ISO-8859-1" and "iso-8859-1".
/* Character set names are always compared ignoring case. */
static int
strcmp_case_insensitive (const char *p, const char *q)
{
while (*p && *q && tolower (*p) == tolower (*q))
p++, q++;
return tolower (*p) - tolower (*q);
}
When the locale is set to Turkish (or any other non-Latin), the
tolower/toupper functions don't work as they would in English. The
lowercase version of 'I' is not 'i', for instance but some other
chracter ('i' w/o the dot). Indeed the man pages for tolower/toupper
warn about this. strcasecmp() also has the problem.
So, I think the whole case-insensitive approach for the names of the
charsets and the translation tables should probably be removed. What
was the reason behind it? Was it that the user could type upper/lower
case charset names at the command line? After all the official name is
'ISO' not 'iso'.
This patch works, but I am not confident that this it's enough.
elena
Index: charset.c
===================================================================
RCS file: /cvs/uberbaum/gdb/charset.c,v
retrieving revision 1.3
diff -u -p -r1.3 charset.c
--- charset.c 14 Jan 2003 00:49:03 -0000 1.3
+++ charset.c 22 Apr 2003 19:56:53 -0000
@@ -160,10 +160,13 @@ struct translation {
static int
strcmp_case_insensitive (const char *p, const char *q)
{
- while (*p && *q && tolower (*p) == tolower (*q))
+#if 0
+ while (*p && *q && tolower (*p) == tolower (*q))
p++, q++;
return tolower (*p) - tolower (*q);
+#endif
+ return strcmp (p, q);
}
@@ -1207,24 +1210,24 @@ _initialize_charset (void)
register_charset (simple_charset ("ascii", 1,
ascii_print_literally, 0,
ascii_to_control, 0));
- register_charset (iso_8859_family_charset ("iso-8859-1"));
+ register_charset (iso_8859_family_charset ("ISO-8859-1"));
register_charset (ebcdic_family_charset ("ebcdic-us"));
register_charset (ebcdic_family_charset ("ibm1047"));
register_iconv_charsets ();
{
struct { char *from; char *to; int *table; } tlist[] = {
- { "ascii", "iso-8859-1", ascii_to_iso_8859_1_table },
+ { "ascii", "ISO-8859-1", ascii_to_iso_8859_1_table },
{ "ascii", "ebcdic-us", ascii_to_ebcdic_us_table },
{ "ascii", "ibm1047", ascii_to_ibm1047_table },
- { "iso-8859-1", "ascii", iso_8859_1_to_ascii_table },
- { "iso-8859-1", "ebcdic-us", iso_8859_1_to_ebcdic_us_table },
- { "iso-8859-1", "ibm1047", iso_8859_1_to_ibm1047_table },
+ { "ISO-8859-1", "ascii", iso_8859_1_to_ascii_table },
+ { "ISO-8859-1", "ebcdic-us", iso_8859_1_to_ebcdic_us_table },
+ { "ISO-8859-1", "ibm1047", iso_8859_1_to_ibm1047_table },
{ "ebcdic-us", "ascii", ebcdic_us_to_ascii_table },
- { "ebcdic-us", "iso-8859-1", ebcdic_us_to_iso_8859_1_table },
+ { "ebcdic-us", "ISO-8859-1", ebcdic_us_to_iso_8859_1_table },
{ "ebcdic-us", "ibm1047", ebcdic_us_to_ibm1047_table },
{ "ibm1047", "ascii", ibm1047_to_ascii_table },
- { "ibm1047", "iso-8859-1", ibm1047_to_iso_8859_1_table },
+ { "ibm1047", "ISO-8859-1", ibm1047_to_iso_8859_1_table },
{ "ibm1047", "ebcdic-us", ibm1047_to_ebcdic_us_table }
};