|
@@ -2472,13 +2472,14 @@ extern SDL_DECLSPEC char * SDLCALL SDL_strpbrk(const char *str, const char *brea
|
|
|
/**
|
|
|
* The Unicode REPLACEMENT CHARACTER codepoint.
|
|
|
*
|
|
|
- * SDL_StepUTF8() reports this codepoint when it encounters a UTF-8 string
|
|
|
+ * SDL_StepUTF8() and SDL_StepBackUTF8() report this codepoint when they encounter a UTF-8 string
|
|
|
* with encoding errors.
|
|
|
*
|
|
|
* This tends to render as something like a question mark in most places.
|
|
|
*
|
|
|
* \since This macro is available since SDL 3.0.0.
|
|
|
*
|
|
|
+ * \sa SDL_StepBackUTF8
|
|
|
* \sa SDL_StepUTF8
|
|
|
*/
|
|
|
#define SDL_INVALID_UNICODE_CODEPOINT 0xFFFD
|
|
@@ -2528,6 +2529,35 @@ extern SDL_DECLSPEC char * SDLCALL SDL_strpbrk(const char *str, const char *brea
|
|
|
*/
|
|
|
extern SDL_DECLSPEC Uint32 SDLCALL SDL_StepUTF8(const char **pstr, size_t *pslen);
|
|
|
|
|
|
+/**
|
|
|
+ * Decode a UTF-8 string in reverse, one Unicode codepoint at a time.
|
|
|
+ *
|
|
|
+ * This will go to the start of the previous Unicode codepoint in the string, move `*pstr` to that location and return that codepoint.
|
|
|
+ *
|
|
|
+ * If the resulting codepoint is zero (already at the start of the string), it will not advance `*pstr` at all.
|
|
|
+ *
|
|
|
+ * Generally this function is called in a loop until it returns zero,
|
|
|
+ * adjusting its parameter each iteration.
|
|
|
+ *
|
|
|
+ * If an invalid UTF-8 sequence is encountered, this function returns
|
|
|
+ * SDL_INVALID_UNICODE_CODEPOINT.
|
|
|
+ *
|
|
|
+ * Several things can generate invalid UTF-8 sequences, including overlong
|
|
|
+ * encodings, the use of UTF-16 surrogate values, and truncated data. Please
|
|
|
+ * refer to
|
|
|
+ * [RFC3629](https://www.ietf.org/rfc/rfc3629.txt)
|
|
|
+ * for details.
|
|
|
+ *
|
|
|
+ * \param start a pointer to the beginning of the UTF-8 string.
|
|
|
+ * \param pstr a pointer to a UTF-8 string pointer to be read and adjusted.
|
|
|
+ * \returns the previous Unicode codepoint in the string.
|
|
|
+ *
|
|
|
+ * \threadsafety It is safe to call this function from any thread.
|
|
|
+ *
|
|
|
+ * \since This function is available since SDL 3.0.0.
|
|
|
+ */
|
|
|
+extern SDL_DECLSPEC Uint32 SDLCALL SDL_StepBackUTF8(const char *start, const char **pstr);
|
|
|
+
|
|
|
/**
|
|
|
* Convert a single Unicode codepoint to UTF-8.
|
|
|
*
|