mssdemux: fix issue on fragment timestamping parsing
authorThiago Santos <thiago.sousa.santos@collabora.com>
Thu, 17 Jan 2013 16:48:13 +0000 (13:48 -0300)
committerThiago Santos <thiago.sousa.santos@collabora.com>
Wed, 8 May 2013 00:05:12 +0000 (21:05 -0300)
Use guint64 as the fragments can start at very high numbers,
specially on live streams

ext/smoothstreaming/gstmssmanifest.c

index 0659164564f74a6928e07586a2d9a9610b5e806d..0b822133fd59eeaffe2e822c32f9de069ea48847 100644 (file)
@@ -132,7 +132,7 @@ _gst_mss_stream_init (GstMssStream * stream, xmlNodePtr node)
   xmlNodePtr iter;
   GstMssStreamFragment *previous_fragment = NULL;
   guint fragment_number = 0;
   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;
   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) {
 
       /* 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);
         g_free (seqnum_str);
+        fragment_number = fragment->number;
       } else {
         fragment->number = fragment_number;
       }
       fragment_number = fragment->number + 1;
 
       if (time_str) {
       } 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);
         g_free (time_str);
+        fragment_time_accum = fragment->time;
       } else {
         fragment->time = fragment_time_accum;
       }
       } 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) {
         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;
 
         previous_fragment = NULL;
         fragment_time_accum += fragment->duration;