gdatetime: Port to use new g_time_zone_new_identifier() constructor

This allows slightly more reliable error checking on this code path.

Signed-off-by: Philip Withnall <pwithnall@endlessos.org>

Helps: #553
This commit is contained in:
Philip Withnall 2020-11-18 11:31:57 +00:00
parent 8105c36e84
commit f9d0135a90

View File

@ -1383,15 +1383,15 @@ parse_iso8601_timezone (const gchar *text, gsize length, gssize *tz_offset)
return NULL; return NULL;
*tz_offset = i; *tz_offset = i;
tz = g_time_zone_new (text + i); tz = g_time_zone_new_identifier (text + i);
/* Double-check that the GTimeZone matches our interpretation of the timezone. /* Double-check that the GTimeZone matches our interpretation of the timezone.
* This can fail because our interpretation is less strict than (for example) * This can fail because our interpretation is less strict than (for example)
* parse_time() in gtimezone.c, which restricts the range of the parsed * parse_time() in gtimezone.c, which restricts the range of the parsed
* integers. */ * integers. */
if (g_time_zone_get_offset (tz, 0) != offset_sign * (offset_hours * 3600 + offset_minutes * 60)) if (tz == NULL || g_time_zone_get_offset (tz, 0) != offset_sign * (offset_hours * 3600 + offset_minutes * 60))
{ {
g_time_zone_unref (tz); g_clear_pointer (&tz, g_time_zone_unref);
return NULL; return NULL;
} }