aboutsummaryrefslogtreecommitdiffstats
path: root/libcharconv_ocr.c
diff options
context:
space:
mode:
authorMattias Andrée <m@maandree.se>2026-01-28 22:03:48 +0100
committerMattias Andrée <m@maandree.se>2026-01-28 22:03:48 +0100
commit40bf70fb8f23e5ff7212b568c69e0725372e5b57 (patch)
tree0d4be706d0182ddeafd4eaafd073e12c2fa2a9e8 /libcharconv_ocr.c
parentMisc stuff (diff)
downloadcharconv-40bf70fb8f23e5ff7212b568c69e0725372e5b57.tar.gz
charconv-40bf70fb8f23e5ff7212b568c69e0725372e5b57.tar.bz2
charconv-40bf70fb8f23e5ff7212b568c69e0725372e5b57.tar.xz
Clean up
Signed-off-by: Mattias Andrée <m@maandree.se>
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;