From 5a633f82dbbce067c56fba0ee372fd341b76368d Mon Sep 17 00:00:00 2001 From: Benjamin Otte Date: Tue, 27 Oct 2009 21:07:13 +0100 Subject: [PATCH] Clarify documentation about g_convert() nul-terminated returns THere is effectively no nul-termination for multibyte characters. --- glib/gconvert.c | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/glib/gconvert.c b/glib/gconvert.c index 7a20cb56a..f2141a35d 100644 --- a/glib/gconvert.c +++ b/glib/gconvert.c @@ -566,8 +566,16 @@ close_converter (GIConv cd) * . * * Return value: If the conversion was successful, a newly allocated - * nul-terminated string, which must be freed with - * g_free(). Otherwise %NULL and @error will be set. + * nul-terminated + * + * Nul-terminated return values from conversion functions + * are terminated by a single 0 byte only. This means that + * for multibyte character sets like UTF-16, they must be + * treated as not nul-terminated. + * + * + * string, which must be freed with g_free(). Otherwise %NULL + * and @error will be set. **/ gchar* g_convert_with_iconv (const gchar *str, @@ -719,8 +727,9 @@ g_convert_with_iconv (const gchar *str, * conversions. * * Return value: If the conversion was successful, a newly allocated - * nul-terminated string, which must be freed with - * g_free(). Otherwise %NULL and @error will be set. + * nul-terminated string, + * which must be freed with g_free(). Otherwise %NULL and + * @error will be set. **/ gchar* g_convert (const gchar *str, @@ -794,8 +803,9 @@ g_convert (const gchar *str, * conversions. * * Return value: If the conversion was successful, a newly allocated - * nul-terminated string, which must be freed with - * g_free(). Otherwise %NULL and @error will be set. + * nul-terminated string, + * which must be freed with g_free(). Otherwise %NULL and + * @error will be set. **/ gchar* g_convert_with_fallback (const gchar *str,