mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
Bug 381: New macro is_cp_ptr_utf8(cp_ptr).
This does not significantly change the generated code but should make the next commit more readable.
This commit is contained in:
parent
e1fee49fb7
commit
0e88f8ba28
@ -142,6 +142,7 @@ static const unicode_val_T strange_chars[32] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
#define SYSTEM_CHARSET_FLAG 128
|
#define SYSTEM_CHARSET_FLAG 128
|
||||||
|
#define is_cp_ptr_utf8(cp_ptr) ((cp_ptr)->table == table_utf8)
|
||||||
|
|
||||||
unsigned char *
|
unsigned char *
|
||||||
u2cp_(unicode_val_T u, int to, int no_nbsp_hack)
|
u2cp_(unicode_val_T u, int to, int no_nbsp_hack)
|
||||||
@ -154,7 +155,7 @@ u2cp_(unicode_val_T u, int to, int no_nbsp_hack)
|
|||||||
to &= ~SYSTEM_CHARSET_FLAG;
|
to &= ~SYSTEM_CHARSET_FLAG;
|
||||||
|
|
||||||
#ifdef CONFIG_UTF8
|
#ifdef CONFIG_UTF8
|
||||||
if (codepages[to].table == table_utf8)
|
if (is_cp_ptr_utf8(&codepages[to]))
|
||||||
return encode_utf8(u);
|
return encode_utf8(u);
|
||||||
#endif /* CONFIG_UTF8 */
|
#endif /* CONFIG_UTF8 */
|
||||||
|
|
||||||
@ -651,7 +652,7 @@ cp2u(int from, unsigned char c)
|
|||||||
|
|
||||||
/* UTF-8 is a multibyte codepage and cannot be handled with
|
/* UTF-8 is a multibyte codepage and cannot be handled with
|
||||||
* this function. */
|
* this function. */
|
||||||
assert(codepages[from].table != table_utf8);
|
assert(!is_cp_ptr_utf8(&codepages[from]));
|
||||||
if_assert_failed return UCS_REPLACEMENT_CHARACTER;
|
if_assert_failed return UCS_REPLACEMENT_CHARACTER;
|
||||||
|
|
||||||
if (c < 0x80) return c;
|
if (c < 0x80) return c;
|
||||||
@ -664,7 +665,7 @@ cp2utf8(int from, int c)
|
|||||||
{
|
{
|
||||||
from &= ~SYSTEM_CHARSET_FLAG;
|
from &= ~SYSTEM_CHARSET_FLAG;
|
||||||
|
|
||||||
if (codepages[from].table == table_utf8 || c < 128)
|
if (is_cp_ptr_utf8(&codepages[from]) || c < 128)
|
||||||
return strings[c];
|
return strings[c];
|
||||||
|
|
||||||
return encode_utf8(cp2u_shared(&codepages[from], c));
|
return encode_utf8(cp2u_shared(&codepages[from], c));
|
||||||
@ -750,7 +751,7 @@ get_translation_table_to_utf8(int from)
|
|||||||
for (i = 0; i < 128; i++)
|
for (i = 0; i < 128; i++)
|
||||||
utf_table[i].u.str = strings[i];
|
utf_table[i].u.str = strings[i];
|
||||||
|
|
||||||
if (codepages[from].table == table_utf8) {
|
if (is_cp_ptr_utf8(&codepages[from])) {
|
||||||
for (i = 128; i < 256; i++)
|
for (i = 128; i < 256; i++)
|
||||||
utf_table[i].u.str = stracpy(strings[i]);
|
utf_table[i].u.str = stracpy(strings[i]);
|
||||||
return utf_table;
|
return utf_table;
|
||||||
@ -803,7 +804,7 @@ get_translation_table(int from, int to)
|
|||||||
}
|
}
|
||||||
if (/*from == to ||*/ from == -1 || to == -1)
|
if (/*from == to ||*/ from == -1 || to == -1)
|
||||||
return NULL;
|
return NULL;
|
||||||
if (codepages[to].table == table_utf8)
|
if (is_cp_ptr_utf8(&codepages[to]))
|
||||||
return get_translation_table_to_utf8(from);
|
return get_translation_table_to_utf8(from);
|
||||||
if (from == lfr && to == lto)
|
if (from == lfr && to == lto)
|
||||||
return table;
|
return table;
|
||||||
@ -811,7 +812,7 @@ get_translation_table(int from, int to)
|
|||||||
lto = to;
|
lto = to;
|
||||||
new_translation_table(table);
|
new_translation_table(table);
|
||||||
|
|
||||||
if (codepages[from].table == table_utf8) {
|
if (is_cp_ptr_utf8(&codepages[from])) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; codepages[to].table[i].c; i++)
|
for (i = 0; codepages[to].table[i].c; i++)
|
||||||
@ -910,7 +911,7 @@ get_entity_string(const unsigned char *str, const int strlen, int encoding)
|
|||||||
#ifdef CONFIG_UTF8
|
#ifdef CONFIG_UTF8
|
||||||
/* TODO: caching UTF-8 */
|
/* TODO: caching UTF-8 */
|
||||||
encoding &= ~SYSTEM_CHARSET_FLAG;
|
encoding &= ~SYSTEM_CHARSET_FLAG;
|
||||||
if (codepages[encoding].table == table_utf8)
|
if (is_cp_ptr_utf8(&codepages[encoding]))
|
||||||
goto skip;
|
goto skip;
|
||||||
#endif /* CONFIG_UTF8 */
|
#endif /* CONFIG_UTF8 */
|
||||||
|
|
||||||
@ -1022,7 +1023,7 @@ skip:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_UTF8
|
#ifdef CONFIG_UTF8
|
||||||
if (codepages[encoding].table == table_utf8) {
|
if (is_cp_ptr_utf8(&codepages[encoding])) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_UTF8 */
|
#endif /* CONFIG_UTF8 */
|
||||||
@ -1354,5 +1355,5 @@ int
|
|||||||
is_cp_utf8(int cp_index)
|
is_cp_utf8(int cp_index)
|
||||||
{
|
{
|
||||||
cp_index &= ~SYSTEM_CHARSET_FLAG;
|
cp_index &= ~SYSTEM_CHARSET_FLAG;
|
||||||
return codepages[cp_index].table == table_utf8;
|
return is_cp_ptr_utf8(&codepages[cp_index]);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user