diff options
Diffstat (limited to '')
| -rw-r--r-- | libcharconv_ocr.c | 27 |
1 files changed, 4 insertions, 23 deletions
diff --git a/libcharconv_ocr.c b/libcharconv_ocr.c index a849952..673ba2a 100644 --- a/libcharconv_ocr.c +++ b/libcharconv_ocr.c @@ -7,29 +7,10 @@ libcharconv_ocr(const char *s, size_t slen, size_t *n, uint_least32_t *cp, size_ { uint_least32_t c; *n = 0; - for (; slen--; s++) { - switch (*s) { - case 's': - case 'S': c = UINT32_C(0x2440); goto conv; - case 'h': - case 'd': c = UINT32_C(0x2441); goto conv; - case 'Y': c = UINT32_C(0x2442); goto conv; - case 'A': c = UINT32_C(0x2443); goto conv; - case 'I': c = UINT32_C(0x2444); goto conv; - case 'x': - case 'X': c = UINT32_C(0x2445); goto conv; - case '\\': c = UINT32_C(0x244A); goto conv; - case 'c': - case 'C': c = UINT32_C(0x2446); goto conv; - case '/': c = UINT32_C(0x2447); goto conv; - case 'p': - case 'P': c = UINT32_C(0x2448); goto conv; - case '_': c = UINT32_C(0x2449); goto conv; - case 'E': c = UINT32_C(0x2BFF); goto conv; - default: - *n += 1u; - break; - } + for (; slen--; s++, ++*n) { + PLAIN_SELECT("SdYAIX\\C/P_", 0x2440); + PLAIN_SELECT("shYAIx\\c/p_", 0x2440); + PLAIN_SINGLE('E', 0x2BFF); } no_conv: return LIBCHARCONV_NO_CONVERT; |
