diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2022-02-14 05:45:13 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2022-02-14 05:45:13 -0800 |
commit | de0268077b27309540e2463242f12c5455e94b8e (patch) | |
tree | 7e6057c480d34becefd9f1c1c2bc3aa3319f6cec /regex.c | |
parent | 8da8ba5a1cc7adf3ad5a4576510aae5c31ae0a6e (diff) | |
download | txr-de0268077b27309540e2463242f12c5455e94b8e.tar.gz txr-de0268077b27309540e2463242f12c5455e94b8e.tar.bz2 txr-de0268077b27309540e2463242f12c5455e94b8e.zip |
Few adjustments to no-implicit-conversion patch.
* lib.h (c_u): New inline function: unsafe conversion to
ucnum, analogous to c_n for cnum.
* hash.c (equal_hash, hash_iter_init): Use UINT_PTR_MAX
instead of convert(ucnum, -1).
(eql_hash): mp_hash returns unsigned long, so
shouldn't require a cast to go to the uint_ptr_t.
The types are of the same size, or at worst it is a widening.
Also replace convert(ucnum, -1) by UINT_PTR_MAX here.
Combining the TAG_CHR and TAG_NUM cases, and using c_u,
which is more efficient since c_chr and c_num are non-inlined
functions which redundantly check type. We no longer
need a self variable in this function.
(eq_hash): Same TAG_CHR and TAG_NUM changes as eql_hash.
* regex.c (char_set_add): Reformat change to avoid line break
across assignment.
Diffstat (limited to 'regex.c')
-rw-r--r-- | regex.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -597,8 +597,8 @@ static void char_set_add(char_set_t *set, wchar_t ch) /* fallthrough */ case CHSET_SMALL: assert (ch < 256); - set->s.bitcell[CHAR_SET_INDEX(ch)] |= - convert(bitcell_t, 1) << CHAR_SET_BIT(ch); + set->s.bitcell[CHAR_SET_INDEX(ch)] |= (convert(bitcell_t, 1) + << CHAR_SET_BIT(ch)); break; case CHSET_LARGE: assert (ch < 0x10000); |