diff options
| author | Mattias Andrée <m@maandree.se> | 2026-01-24 14:39:44 +0100 |
|---|---|---|
| committer | Mattias Andrée <m@maandree.se> | 2026-01-24 14:39:44 +0100 |
| commit | d554a18e5f981ae200f7f8a3e46d5da93190e897 (patch) | |
| tree | 99907dc58e28160b3814a901656f2d915b32e229 /libcharconv_latin.c | |
| parent | First commit (diff) | |
| download | charconv-d554a18e5f981ae200f7f8a3e46d5da93190e897.tar.gz charconv-d554a18e5f981ae200f7f8a3e46d5da93190e897.tar.bz2 charconv-d554a18e5f981ae200f7f8a3e46d5da93190e897.tar.xz | |
Add replacement
Signed-off-by: Mattias Andrée <m@maandree.se>
Diffstat (limited to 'libcharconv_latin.c')
| -rw-r--r-- | libcharconv_latin.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/libcharconv_latin.c b/libcharconv_latin.c index d682b17..be0b53c 100644 --- a/libcharconv_latin.c +++ b/libcharconv_latin.c @@ -367,6 +367,16 @@ libcharconv_latin(const char *s, size_t slen, size_t *n, uint_least32_t *cp, siz } goto conv2_prechecked; + /* replacement */ + case UINT32_C(0xFFFC): + c1 = 'o'; + c2 = 'b'; + c3 = 'j'; + goto conv3; + case UINT32_C(0xFFFD): + c = (uint_least32_t)'?'; + goto conv; + default: no_match: *n += clen; @@ -398,6 +408,10 @@ conv2_prechecked: *ncp = 2u; return ret; +conv3: + if (*n) + goto no_conv; + *n += clen; conv3_prechecked: if (*ncp >= 1u) cp[0] = (uint_least32_t)c1; |
