mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-04-03 06:13:08 +02:00
gdatetime: Factor out an undersized variable
For long input strings, it would have been possible for `i` to overflow. Avoid that problem by using the `tz_length` instead, so that we count up rather than down. This commit introduces no functional changes (outside of changing undefined behaviour), and can be verified using the identity `i === length - tz_length`. Signed-off-by: Philip Withnall <pwithnall@gnome.org>
This commit is contained in:
parent
3672764a17
commit
0ffdbebd9a
@ -1395,7 +1395,7 @@ static GTimeZone *
|
|||||||
parse_iso8601_timezone (const gchar *text, gsize length, size_t *tz_offset)
|
parse_iso8601_timezone (const gchar *text, gsize length, size_t *tz_offset)
|
||||||
{
|
{
|
||||||
size_t tz_length;
|
size_t tz_length;
|
||||||
gint i, offset_hours, offset_minutes;
|
gint offset_hours, offset_minutes;
|
||||||
gint offset_sign = 1;
|
gint offset_sign = 1;
|
||||||
GTimeZone *tz;
|
GTimeZone *tz;
|
||||||
const char *tz_start;
|
const char *tz_start;
|
||||||
@ -1408,16 +1408,15 @@ parse_iso8601_timezone (const gchar *text, gsize length, size_t *tz_offset)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Look for '+' or '-' of offset */
|
/* Look for '+' or '-' of offset */
|
||||||
for (i = length - 1; i >= 0; i--)
|
for (tz_length = 1; tz_length <= length; tz_length++)
|
||||||
if (text[i] == '+' || text[i] == '-')
|
if (text[length - tz_length] == '+' || text[length - tz_length] == '-')
|
||||||
{
|
{
|
||||||
offset_sign = text[i] == '-' ? -1 : 1;
|
offset_sign = text[length - tz_length] == '-' ? -1 : 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (i < 0)
|
if (tz_length > length)
|
||||||
return NULL;
|
return NULL;
|
||||||
tz_start = text + i;
|
tz_start = text + length - tz_length;
|
||||||
tz_length = length - i;
|
|
||||||
|
|
||||||
/* +hh:mm or -hh:mm */
|
/* +hh:mm or -hh:mm */
|
||||||
if (tz_length == 6 && tz_start[3] == ':')
|
if (tz_length == 6 && tz_start[3] == ':')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user