1
Fork 0
mirror of git://git.sv.gnu.org/emacs.git synced 2025-12-27 15:52:00 -08:00

(sub_char_table_set_range): Optimized for the case

DEPTH == 3.  Add workaround code for a GCC optimization bug.
This commit is contained in:
Kenichi Handa 2002-03-05 00:08:31 +00:00
parent 885317d817
commit 22d49f94bd

View file

@ -377,7 +377,7 @@ sub_char_table_set_range (table, depth, min_char, from, to, val)
{
int max_char = min_char + chartab_chars[depth] - 1;
if (from <= min_char && to >= max_char)
if (depth == 3 || from <= min_char && to >= max_char)
*table = val;
else
{
@ -390,12 +390,12 @@ sub_char_table_set_range (table, depth, min_char, from, to, val)
from = min_char;
if (to > max_char)
to = max_char;
i = CHARTAB_IDX (from, depth, min_char);
j = CHARTAB_IDX (to, depth, min_char);
for (i = CHARTAB_IDX (from, depth, min_char); i <= j; i++)
min_char += chartab_chars[depth] * i;
for (; i <= j; i++, min_char += chartab_chars[depth])
sub_char_table_set_range (XSUB_CHAR_TABLE (*table)->contents + i,
depth,
min_char + chartab_chars[depth] * i,
from, to, val);
depth, min_char, from, to, val);
}
}