diff options
| author | Mattias Andrée <m@maandree.se> | 2026-01-24 17:27:23 +0100 |
|---|---|---|
| committer | Mattias Andrée <m@maandree.se> | 2026-01-24 17:27:23 +0100 |
| commit | be3e7dec7e19a8ddc527a188306c097900a6da99 (patch) | |
| tree | 094d0c9bd936dc1c5853210f3ae94455b670748d /libcharconv.h | |
| parent | Make UTF-8 decoding function available to the entire library (diff) | |
| download | charconv-be3e7dec7e19a8ddc527a188306c097900a6da99.tar.gz charconv-be3e7dec7e19a8ddc527a188306c097900a6da99.tar.bz2 charconv-be3e7dec7e19a8ddc527a188306c097900a6da99.tar.xz | |
Add bracketed
Signed-off-by: Mattias Andrée <m@maandree.se>
Diffstat (limited to 'libcharconv.h')
| -rw-r--r-- | libcharconv.h | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/libcharconv.h b/libcharconv.h index 8e3c4bc..76bdfd7 100644 --- a/libcharconv.h +++ b/libcharconv.h @@ -901,4 +901,36 @@ enum libcharconv_result libcharconv_buhid(const char *s, size_t slen, size_t *n, enum libcharconv_result libcharconv_replacement(const char *s, size_t slen, size_t *n, uint_least32_t *cp, size_t *ncp); +/** + * Convert alphanumerics to bracketed form + * + * @param s Text to convert + * @param slen The number of bytes available in `s` + * @param n Output parameter for the number of consumed bytes + * @param cp Output buffer for the codepoints + * @param ncp Input parameter for the number of codepoints that + * fit in `cp`, and output parameter for the number + * of output codepoints (if it exceeds the original + * value of `ncp`, a larger buffer is needed) + * @return LIBCHARCONV_NO_CONVERT: + * `*n` is the number of bytes from the beginning + * of `s` that cannot be converted + * LIBCHARCONV_CONVERTED: + * `*n` is the number of bytes from the beginning + * of `s` that was converted to a codepoint which + * is stored in `*cp` + * LIBCHARCONV_INDETERMINATE: + * If all text has been input, no more can be + * converted, otherwise more of the text most + * be made available before the function can + * determine whether the beginning of `s` can be + * converted or what it should be converted to + * LIBCHARCONV_CONVERT_IF_END: + * As LIBCHARCONV_CONVERTED the entire text has + * been input, as LIBCHARCONV_INDETERMINATE + * otherwise + */ +enum libcharconv_result libcharconv_bracketed(const char *s, size_t slen, size_t *n, uint_least32_t *cp, size_t *ncp); + + #endif |
