Add note about g_utf8_offset_to_pointer() not checking string

boundaries.

* glib/gutf8.c (g_utf8_offset_to_pointer()): See summary.

svn path=/trunk/; revision=7861
This commit is contained in:
Mathias Hasselmann
2009-02-13 14:20:17 +00:00
parent 82e1d3e753
commit cf01757ba0
2 changed files with 21 additions and 5 deletions

View File

@@ -1,3 +1,10 @@
2009-02-13 Mathias Hasselmann <hasselmm@gnome.org>
Add note about g_utf8_offset_to_pointer() not checking string
boundaries.
* glib/gutf8.c (g_utf8_offset_to_pointer()): See summary.
2999-02-11 Matthias Clasen <mclasen@redhat.com> 2999-02-11 Matthias Clasen <mclasen@redhat.com>
Bug 523742 Use noinst for non-installable libraries Bug 523742 Use noinst for non-installable libraries

View File

@@ -279,20 +279,29 @@ g_utf8_get_char (const gchar *p)
* g_utf8_offset_to_pointer: * g_utf8_offset_to_pointer:
* @str: a UTF-8 encoded string * @str: a UTF-8 encoded string
* @offset: a character offset within @str * @offset: a character offset within @str
* *
* Converts from an integer character offset to a pointer to a position * Converts from an integer character offset to a pointer to a position
* within the string. * within the string.
* *
* Since 2.10, this function allows to pass a negative @offset to * Since 2.10, this function allows to pass a negative @offset to
* step backwards. It is usually worth stepping backwards from the end * step backwards. It is usually worth stepping backwards from the end
* instead of forwards if @offset is in the last fourth of the string, * instead of forwards if @offset is in the last fourth of the string,
* since moving forward is about 3 times faster than moving backward. * since moving forward is about 3 times faster than moving backward.
* *
* <note><para>
* This function doesn't abort when reaching the end of @str. Therefore
* you should be sure that @offset is within string boundaries before
* calling that function. Call g_utf8_strlen() when unsure.
*
* This limitation exists as this function is called frequently during
* text rendering and therefore has to be as fast as possible.
* </para></note>
*
* Return value: the resulting pointer * Return value: the resulting pointer
**/ **/
gchar * gchar *
g_utf8_offset_to_pointer (const gchar *str, g_utf8_offset_to_pointer (const gchar *str,
glong offset) glong offset)
{ {
const gchar *s = str; const gchar *s = str;