mirror of
https://github.com/rkd77/elinks.git
synced 2024-12-04 14:46:47 -05:00
Bug 882: Replace C1 controls with spaces in UTF-8 to the terminal.
This commit is contained in:
parent
564a6b9602
commit
f4709c3794
@ -3,6 +3,10 @@
|
|||||||
|
|
||||||
typedef uint32_t unicode_val_T;
|
typedef uint32_t unicode_val_T;
|
||||||
|
|
||||||
|
/* U+0020 SPACE. Normally the same as ' ' or L' ' but perhaps ELinks
|
||||||
|
* shouldn't rely on that. */
|
||||||
|
#define UCS_SPACE ((unicode_val_T) 0x0020)
|
||||||
|
|
||||||
/* U+FFFD REPLACEMENT CHARACTER. Used when no Unicode mapping is
|
/* U+FFFD REPLACEMENT CHARACTER. Used when no Unicode mapping is
|
||||||
* known for a byte in a codepage, or when invalid UTF-8 is received
|
* known for a byte in a codepage, or when invalid UTF-8 is received
|
||||||
* from a terminal. After generating the character, ELinks then
|
* from a terminal. After generating the character, ELinks then
|
||||||
|
@ -542,13 +542,10 @@ add_char_data(struct string *screen, struct screen_driver *driver,
|
|||||||
* defined 0 1 enum border_char border unibyte
|
* defined 0 1 enum border_char border unibyte
|
||||||
* defined 1 0 UTF-32 UTF-8
|
* defined 1 0 UTF-32 UTF-8
|
||||||
* defined 1 1 enum border_char border unibyte
|
* defined 1 1 enum border_char border unibyte
|
||||||
|
*
|
||||||
|
* For "UTF-32" above, the data can also be UCS_NO_CHAR.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!isscreensafe(data)) {
|
|
||||||
add_char_to_string(screen, ' ');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (border && driver->frame && data >= 176 && data < 224)
|
if (border && driver->frame && data >= 176 && data < 224)
|
||||||
data = driver->frame[data - 176];
|
data = driver->frame[data - 176];
|
||||||
|
|
||||||
@ -556,18 +553,25 @@ add_char_data(struct string *screen, struct screen_driver *driver,
|
|||||||
#ifdef CONFIG_UTF8
|
#ifdef CONFIG_UTF8
|
||||||
if (border)
|
if (border)
|
||||||
add_char_to_string(screen, (unsigned char)data);
|
add_char_to_string(screen, (unsigned char)data);
|
||||||
else
|
else if (data != UCS_NO_CHAR) {
|
||||||
if (data != UCS_NO_CHAR)
|
if (!isscreensafe_ucs(data))
|
||||||
|
data = UCS_SPACE;
|
||||||
add_to_string(screen, encode_utf8(data));
|
add_to_string(screen, encode_utf8(data));
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
int charset = driver->charsets[!!border];
|
int charset = driver->charsets[!!border];
|
||||||
|
|
||||||
|
if (border || isscreensafe(data))
|
||||||
add_to_string(screen, cp2utf8(charset, data));
|
add_to_string(screen, cp2utf8(charset, data));
|
||||||
|
else /* UCS_SPACE <= 0x7F and so fits in one UTF-8 byte */
|
||||||
|
add_char_to_string(screen, UCS_SPACE);
|
||||||
#endif /* CONFIG_UTF8 */
|
#endif /* CONFIG_UTF8 */
|
||||||
return;
|
} else {
|
||||||
}
|
if (border || isscreensafe(data))
|
||||||
|
|
||||||
add_char_to_string(screen, (unsigned char)data);
|
add_char_to_string(screen, (unsigned char)data);
|
||||||
|
else
|
||||||
|
add_char_to_string(screen, ' ');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Time critical section. */
|
/* Time critical section. */
|
||||||
|
@ -114,6 +114,9 @@ int elinks_strlcasecmp(const unsigned char *s1, size_t n1,
|
|||||||
* non-ISO-8859 charsets. */
|
* non-ISO-8859 charsets. */
|
||||||
#define isscreensafe(c) ((c) >= ' ' && (c) != ASCII_DEL)
|
#define isscreensafe(c) ((c) >= ' ' && (c) != ASCII_DEL)
|
||||||
|
|
||||||
|
/* Like isscreensafe but takes Unicode values and so can check for C1. */
|
||||||
|
#define isscreensafe_ucs(c) (((c) >= 0x20 && (c) <= 0x7E) || (c) >= 0xA0)
|
||||||
|
|
||||||
|
|
||||||
/* String debugging using magic number, it may catch some errors. */
|
/* String debugging using magic number, it may catch some errors. */
|
||||||
#ifdef CONFIG_DEBUG
|
#ifdef CONFIG_DEBUG
|
||||||
|
@ -405,7 +405,7 @@ utf8:
|
|||||||
unicode_val_T data = pos->data;
|
unicode_val_T data = pos->data;
|
||||||
unsigned int frame = (pos->attr & SCREEN_ATTR_FRAME);
|
unsigned int frame = (pos->attr & SCREEN_ATTR_FRAME);
|
||||||
|
|
||||||
if (!isscreensafe(data)) {
|
if (!isscreensafe_ucs(data)) {
|
||||||
white++;
|
white++;
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user