From 21872e78b819c18f9e1a906fb19db1c2e0e221b8 Mon Sep 17 00:00:00 2001 From: Thiago Santos Date: Thu, 17 Jan 2013 13:48:13 -0300 Subject: [PATCH] mssdemux: fix issue on fragment timestamping parsing Use guint64 as the fragments can start at very high numbers, specially on live streams --- ext/smoothstreaming/gstmssmanifest.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/ext/smoothstreaming/gstmssmanifest.c b/ext/smoothstreaming/gstmssmanifest.c index 0659164564..0b822133fd 100644 --- a/ext/smoothstreaming/gstmssmanifest.c +++ b/ext/smoothstreaming/gstmssmanifest.c @@ -132,7 +132,7 @@ _gst_mss_stream_init (GstMssStream * stream, xmlNodePtr node) xmlNodePtr iter; GstMssStreamFragment *previous_fragment = NULL; guint fragment_number = 0; - guint fragment_time_accum = 0; + guint64 fragment_time_accum = 0; GError *gerror = NULL; stream->xmlnode = node; @@ -153,16 +153,19 @@ _gst_mss_stream_init (GstMssStream * stream, xmlNodePtr node) /* use the node's seq number or use the previous + 1 */ if (seqnum_str) { - fragment->number = atoi (seqnum_str); + fragment->number = g_ascii_strtoull (seqnum_str, NULL, 10); g_free (seqnum_str); + fragment_number = fragment->number; } else { fragment->number = fragment_number; } fragment_number = fragment->number + 1; if (time_str) { - fragment->time = atoi (time_str); + fragment->time = g_ascii_strtoull (time_str, NULL, 10); + g_free (time_str); + fragment_time_accum = fragment->time; } else { fragment->time = fragment_time_accum; } @@ -172,7 +175,7 @@ _gst_mss_stream_init (GstMssStream * stream, xmlNodePtr node) previous_fragment->duration = fragment->time - previous_fragment->time; if (duration_str) { - fragment->duration = atoi (duration_str); + fragment->duration = g_ascii_strtoull (duration_str, NULL, 10); previous_fragment = NULL; fragment_time_accum += fragment->duration; -- 2.34.1