diff options
author | Jean-Francois Mauguit <jfmauguit@mac.com> | 2024-09-24 09:03:25 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-24 09:03:25 -0400 |
commit | bab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/replicant/nu/utf.h | |
parent | 4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff) | |
parent | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff) | |
download | winamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz |
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/replicant/nu/utf.h')
-rw-r--r-- | Src/replicant/nu/utf.h | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/Src/replicant/nu/utf.h b/Src/replicant/nu/utf.h new file mode 100644 index 00000000..cc1437e1 --- /dev/null +++ b/Src/replicant/nu/utf.h @@ -0,0 +1,26 @@ +#pragma once +#include "foundation/types.h" + +#ifdef __cplusplus +extern "C" { +#endif + + /* to utf8 */ + size_t utf16LE_to_utf8(const uint16_t *src, size_t source_len, char *dst, size_t out_len); + size_t utf16BE_to_utf8(const uint16_t *src, size_t source_len, char *dst, size_t out_len); + size_t ISO_8859_1_to_utf8(const char *src, size_t source_len, char *dst, size_t out_len); + size_t ASCII_to_utf8(const char *src, size_t source_len, char *dst, size_t out_len); + size_t ucs4_to_utf8(const uint32_t *src, size_t source_len, char *dst, size_t out_len); + + /* from utf8 */ + size_t utf8_to_utf16LE(const char *src, size_t source_len, uint16_t *dst, size_t out_len); + size_t utf8_to_ISO_8859_1(const char *src, size_t source_len, char *dst, size_t out_len); + size_t utf8_to_utf16BE(const char *src, size_t source_len, uint16_t *dst, size_t out_len); + size_t utf8_to_ASCII(const char *src, size_t source_len, char *dst, size_t out_len); + size_t utf8_to_ucs4(const char *src, size_t source_len, uint32_t *dst, size_t out_len); + + /* returns the number of bytes required to make the specified number of codepoints exactly fit */ + size_t utf8_strnlen(const char *src, size_t source_len, size_t codepoints); +#ifdef __cplusplus +} +#endif |