aboutsummaryrefslogtreecommitdiffstats
path: root/libcharconv_double_struck.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--libcharconv_double_struck.c45
1 files changed, 11 insertions, 34 deletions
diff --git a/libcharconv_double_struck.c b/libcharconv_double_struck.c
index ae64247..2a7fa4f 100644
--- a/libcharconv_double_struck.c
+++ b/libcharconv_double_struck.c
@@ -7,40 +7,17 @@ libcharconv_double_struck(const char *s, size_t slen, size_t *n, uint_least32_t
{
uint_least32_t c;
*n = 0;
- for (; slen--; s++) {
- if (*s == 'C') {
- c = (uint_least32_t)UINT32_C(0x2102);
- goto conv;
- } else if (*s == 'H') {
- c = (uint_least32_t)UINT32_C(0x210D);
- goto conv;
- } else if (*s == 'N') {
- c = (uint_least32_t)UINT32_C(0x2115);
- goto conv;
- } else if (*s == 'P') {
- c = (uint_least32_t)UINT32_C(0x2119);
- goto conv;
- } else if (*s == 'Q') {
- c = (uint_least32_t)UINT32_C(0x211A);
- goto conv;
- } else if (*s == 'R') {
- c = (uint_least32_t)UINT32_C(0x211D);
- goto conv;
- } else if (*s == 'Z') {
- c = (uint_least32_t)UINT32_C(0x2124);
- goto conv;
- } else if ('A' <= *s && *s <= 'Z') {
- c = (uint_least32_t)(UINT32_C(0x1D538) + (unsigned)(*s - 'A'));
- goto conv;
- } else if ('a' <= *s && *s <= 'z') {
- c = (uint_least32_t)(UINT32_C(0x1D552) + (unsigned)(*s - 'a'));
- goto conv;
- } else if ('0' <= *s && *s <= '9') {
- c = (uint_least32_t)(UINT32_C(0x1D7D8) + (unsigned)(*s - '0'));
- goto conv;
- } else {
- *n += 1u;
- }
+ for (; slen--; s++, ++*n) {
+ PLAIN_SINGLE('C', 0x2102);
+ PLAIN_SINGLE('H', 0x210D);
+ PLAIN_SINGLE('N', 0x2115);
+ PLAIN_SINGLE('P', 0x2119);
+ PLAIN_SINGLE('Q', 0x211A);
+ PLAIN_SINGLE('R', 0x211D);
+ PLAIN_SINGLE('Z', 0x2124);
+ PLAIN_RANGE('A', 'Z', 0x1D538);
+ PLAIN_RANGE('a', 'z', 0x1D552);
+ PLAIN_RANGE('0', '9', 0x1D7D8);
}
no_conv:
return LIBCHARCONV_NO_CONVERT;