annotate BUGS @ 4388:1524d3237820 SDL-1.2

Fixed bug #896 John Popplewell 2009-12-08 23:05:50 PST Originally reported by AKFoerster on the mailing list. Error decoding UTF8 Russian text to UTF-16LE on Windows, but specifically on platforms without iconv support (the default on Windows). Valid UTF8 characters are flagged as being overlong and then substituted by the UNKNOWN_UNICODE character. After studying the testiconv.c example program, reading the RFCs and putting some printf statements in SDL_iconv.c the problem is in a test for 'Maximum overlong sequences', specifically 4.2.1, which is carried out by the following code: } else if ( p[0] >= 0xC0 ) { if ( (p[0] & 0xE0) != 0xC0 ) { /* Skip illegal sequences return SDL_ICONV_EILSEQ; */ ch = UNKNOWN_UNICODE; } else { if ( (p[0] & 0xCE) == 0xC0 ) { <<<<<<<< here overlong = SDL_TRUE; } ch = (Uint32)(p[0] & 0x1F); left = 1; } } else { Here is the 2-byte encoding of a character in range 00000080 - 000007FF 110xxxxx 10xxxxxx The line in question is supposed to be checking for an overlong sequence which would be less than 11000001 10111111 which should be represented as a single byte. BUT, the mask value (0xCE) is wrong, it isn't checking the top-most bit: 11000001 value 11001110 mask (incorrect) ^ and should be (0xDE): 11000001 value 11011110 mask (correct) making the above code: } else if ( p[0] >= 0xC0 ) { if ( (p[0] & 0xE0) != 0xC0 ) { /* Skip illegal sequences return SDL_ICONV_EILSEQ; */ ch = UNKNOWN_UNICODE; } else { if ( (p[0] & 0xDE) == 0xC0 ) { <<<<<<<< here overlong = SDL_TRUE; } ch = (Uint32)(p[0] & 0x1F); left = 1; } } else { I can supply a test program and/or a patch if required, best regards, John Popplewell
author Sam Lantinga <slouken@libsdl.org>
date Fri, 11 Dec 2009 08:00:57 +0000
parents 89b0f3d12fe2
children
rev   line source
0
74212992fb08 Initial revision
Sam Lantinga <slouken@lokigames.com>
parents:
diff changeset
1
3915
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
2 Bugs are now managed in the SDL bug tracker, here:
0
74212992fb08 Initial revision
Sam Lantinga <slouken@lokigames.com>
parents:
diff changeset
3
3915
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
4 http://bugzilla.libsdl.org/
0
74212992fb08 Initial revision
Sam Lantinga <slouken@lokigames.com>
parents:
diff changeset
5
3915
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
6 You may report bugs there, and search to see if a given issue has already
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
7 been reported, discussed, and maybe even fixed.
0
74212992fb08 Initial revision
Sam Lantinga <slouken@lokigames.com>
parents:
diff changeset
8
74212992fb08 Initial revision
Sam Lantinga <slouken@lokigames.com>
parents:
diff changeset
9
27
a7e598a8d8be The keyboard modifiers are not set to the correct state on X11 startup.
Sam Lantinga <slouken@lokigames.com>
parents: 21
diff changeset
10
3915
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
11 You may also find help at the SDL mailing list. Subscription information:
0
74212992fb08 Initial revision
Sam Lantinga <slouken@lokigames.com>
parents:
diff changeset
12
3915
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
13 http://lists.libsdl.org/listinfo.cgi/sdl-libsdl.org
250
74a8f672f2f8 Added support for building SDL for EPOC/SymbianOS 6.0 (thanks Hannu!)
Sam Lantinga <slouken@libsdl.org>
parents: 172
diff changeset
14
3915
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
15 Bug reports are welcome here, but we really appreciate if you use Bugzilla, as
89b0f3d12fe2 Removed the contents of the BUGS file, as most (all?) of the issues were
Ryan C. Gordon <icculus@icculus.org>
parents: 3888
diff changeset
16 bugs discussed on the mailing list may be forgotten or missed.
0
74212992fb08 Initial revision
Sam Lantinga <slouken@lokigames.com>
parents:
diff changeset
17
27
a7e598a8d8be The keyboard modifiers are not set to the correct state on X11 startup.
Sam Lantinga <slouken@lokigames.com>
parents: 21
diff changeset
18