From: Stefan Kangas Date: Wed, 21 Jul 2021 12:01:57 +0000 (+0200) Subject: Factor out char_table_ref_simple for readability X-Git-Tag: emacs-28.0.90~1769 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=cb9d82a17c78085692cdb55c31b38f00e8e6919b;p=emacs.git Factor out char_table_ref_simple for readability * src/chartab.c (char_table_ref_simple): New function... (sub_char_table_ref_and_range, char_table_ref_and_range): ...factored out from here. (bug#45550). --- diff --git a/src/chartab.c b/src/chartab.c index 331e8595ebe..6f0bc28f31b 100644 --- a/src/chartab.c +++ b/src/chartab.c @@ -62,6 +62,9 @@ typedef Lisp_Object (*uniprop_encoder_t) (Lisp_Object, Lisp_Object); static Lisp_Object uniprop_table_uncompress (Lisp_Object, int); static uniprop_decoder_t uniprop_get_decoder (Lisp_Object); +static Lisp_Object +sub_char_table_ref_and_range (Lisp_Object, int, int *, int *, + Lisp_Object, bool); /* 1 iff TABLE is a uniprop table. */ #define UNIPROP_TABLE_P(TABLE) \ @@ -247,6 +250,23 @@ char_table_ref (Lisp_Object table, int c) return val; } +static inline Lisp_Object +char_table_ref_simple (Lisp_Object table, int idx, int c, int *from, int *to, + Lisp_Object defalt, bool is_uniprop, bool is_subtable) +{ + Lisp_Object val = is_subtable ? + XSUB_CHAR_TABLE (table)->contents[idx]: + XCHAR_TABLE (table)->contents[idx]; + if (is_uniprop && UNIPROP_COMPRESSED_FORM_P (val)) + val = uniprop_table_uncompress (table, idx); + if (SUB_CHAR_TABLE_P (val)) + val = sub_char_table_ref_and_range (val, c, from, to, + defalt, is_uniprop); + else if (NILP (val)) + val = defalt; + return val; +} + static Lisp_Object sub_char_table_ref_and_range (Lisp_Object table, int c, int *from, int *to, Lisp_Object defalt, bool is_uniprop) @@ -254,31 +274,18 @@ sub_char_table_ref_and_range (Lisp_Object table, int c, int *from, int *to, struct Lisp_Sub_Char_Table *tbl = XSUB_CHAR_TABLE (table); int depth = tbl->depth, min_char = tbl->min_char; int chartab_idx = CHARTAB_IDX (c, depth, min_char), idx; - Lisp_Object val; - - val = tbl->contents[chartab_idx]; - if (is_uniprop && UNIPROP_COMPRESSED_FORM_P (val)) - val = uniprop_table_uncompress (table, chartab_idx); - if (SUB_CHAR_TABLE_P (val)) - val = sub_char_table_ref_and_range (val, c, from, to, defalt, is_uniprop); - else if (NILP (val)) - val = defalt; + Lisp_Object val + = char_table_ref_simple (table, chartab_idx, c, from, to, + defalt, is_uniprop, true); idx = chartab_idx; while (idx > 0 && *from < min_char + idx * chartab_chars[depth]) { - Lisp_Object this_val; - c = min_char + idx * chartab_chars[depth] - 1; idx--; - this_val = tbl->contents[idx]; - if (is_uniprop && UNIPROP_COMPRESSED_FORM_P (this_val)) - this_val = uniprop_table_uncompress (table, idx); - if (SUB_CHAR_TABLE_P (this_val)) - this_val = sub_char_table_ref_and_range (this_val, c, from, to, defalt, - is_uniprop); - else if (NILP (this_val)) - this_val = defalt; + Lisp_Object this_val + = char_table_ref_simple (table, idx, c, from, to, + defalt, is_uniprop, true); if (! EQ (this_val, val)) { @@ -290,17 +297,11 @@ sub_char_table_ref_and_range (Lisp_Object table, int c, int *from, int *to, < chartab_chars[depth - 1]) && (c += min_char) <= *to) { - Lisp_Object this_val; - chartab_idx++; - this_val = tbl->contents[chartab_idx]; - if (is_uniprop && UNIPROP_COMPRESSED_FORM_P (this_val)) - this_val = uniprop_table_uncompress (table, chartab_idx); - if (SUB_CHAR_TABLE_P (this_val)) - this_val = sub_char_table_ref_and_range (this_val, c, from, to, defalt, - is_uniprop); - else if (NILP (this_val)) - this_val = defalt; + Lisp_Object this_val + = char_table_ref_simple (table, chartab_idx, c, from, to, + defalt, is_uniprop, true); + if (! EQ (this_val, val)) { *to = c - 1; @@ -321,37 +322,26 @@ Lisp_Object char_table_ref_and_range (Lisp_Object table, int c, int *from, int *to) { struct Lisp_Char_Table *tbl = XCHAR_TABLE (table); - int chartab_idx = CHARTAB_IDX (c, 0, 0), idx; - Lisp_Object val; + int chartab_idx = CHARTAB_IDX (c, 0, 0); bool is_uniprop = UNIPROP_TABLE_P (table); - val = tbl->contents[chartab_idx]; if (*from < 0) *from = 0; if (*to < 0) *to = MAX_CHAR; - if (is_uniprop && UNIPROP_COMPRESSED_FORM_P (val)) - val = uniprop_table_uncompress (table, chartab_idx); - if (SUB_CHAR_TABLE_P (val)) - val = sub_char_table_ref_and_range (val, c, from, to, tbl->defalt, - is_uniprop); - else if (NILP (val)) - val = tbl->defalt; - idx = chartab_idx; + + Lisp_Object val + = char_table_ref_simple (table, chartab_idx, c, from, to, + tbl->defalt, is_uniprop, false); + + int idx = chartab_idx; while (*from < idx * chartab_chars[0]) { - Lisp_Object this_val; - c = idx * chartab_chars[0] - 1; idx--; - this_val = tbl->contents[idx]; - if (is_uniprop && UNIPROP_COMPRESSED_FORM_P (this_val)) - this_val = uniprop_table_uncompress (table, idx); - if (SUB_CHAR_TABLE_P (this_val)) - this_val = sub_char_table_ref_and_range (this_val, c, from, to, - tbl->defalt, is_uniprop); - else if (NILP (this_val)) - this_val = tbl->defalt; + Lisp_Object this_val + = char_table_ref_simple (table, idx, c, from, to, + tbl->defalt, is_uniprop, false); if (! EQ (this_val, val)) { @@ -361,18 +351,12 @@ char_table_ref_and_range (Lisp_Object table, int c, int *from, int *to) } while (*to >= (chartab_idx + 1) * chartab_chars[0]) { - Lisp_Object this_val; - chartab_idx++; c = chartab_idx * chartab_chars[0]; - this_val = tbl->contents[chartab_idx]; - if (is_uniprop && UNIPROP_COMPRESSED_FORM_P (this_val)) - this_val = uniprop_table_uncompress (table, chartab_idx); - if (SUB_CHAR_TABLE_P (this_val)) - this_val = sub_char_table_ref_and_range (this_val, c, from, to, - tbl->defalt, is_uniprop); - else if (NILP (this_val)) - this_val = tbl->defalt; + Lisp_Object this_val + = char_table_ref_simple (table, chartab_idx, c, from, to, + tbl->defalt, is_uniprop, false); + if (! EQ (this_val, val)) { *to = c - 1;