diff options
Diffstat (limited to 'libcharconv_chess_white.c')
| -rw-r--r-- | libcharconv_chess_white.c | 25 |
1 files changed, 5 insertions, 20 deletions
diff --git a/libcharconv_chess_white.c b/libcharconv_chess_white.c index 1c72e26..f6233a1 100644 --- a/libcharconv_chess_white.c +++ b/libcharconv_chess_white.c @@ -7,26 +7,11 @@ libcharconv_chess_white(const char *s, size_t slen, size_t *n, uint_least32_t *c { uint_least32_t c; *n = 0; - for (; slen--; s++) { - switch (*s) { - case 'k': c = UINT32_C(0x2654); goto conv; - case 'q': c = UINT32_C(0x2655); goto conv; - case 'r': c = UINT32_C(0x2656); goto conv; - case 'b': c = UINT32_C(0x2657); goto conv; - case 'n': c = UINT32_C(0x2658); goto conv; - case 'p': c = UINT32_C(0x2659); goto conv; - case 'e': c = UINT32_C(0x1FA48); goto conv; - case 'K': c = UINT32_C(0x265A); goto conv; - case 'Q': c = UINT32_C(0x265B); goto conv; - case 'R': c = UINT32_C(0x265C); goto conv; - case 'B': c = UINT32_C(0x265D); goto conv; - case 'N': c = UINT32_C(0x265E); goto conv; - case 'P': c = UINT32_C(0x265F); goto conv; - case 'E': c = UINT32_C(0x1FA49); goto conv; - default: - *n += 1u; - break; - } + for (; slen--; s++, ++*n) { + PLAIN_SELECT("kqrbnp", 0x2654); + PLAIN_SELECT("KQRBNP", 0x265A); + PLAIN_SINGLE('e', 0x1FA48); + PLAIN_SINGLE('E', 0x1FA49); } no_conv: return LIBCHARCONV_NO_CONVERT; |
