aboutsummaryrefslogtreecommitdiffstats
path: root/libcharconv_ocr.c
diff options
context:
space:
mode:
Diffstat (limited to 'libcharconv_ocr.c')
-rw-r--r--libcharconv_ocr.c27
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;