]> git.sesse.net Git - ffmpeg/commitdiff
Do not lose the '\n'.
authorMichael Niedermayer <michaelni@gmx.at>
Fri, 26 Sep 2008 03:24:05 +0000 (03:24 +0000)
committerMichael Niedermayer <michaelni@gmx.at>
Fri, 26 Sep 2008 03:24:05 +0000 (03:24 +0000)
Originally committed as revision 15424 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavformat/assdec.c

index fa0ab793e00547b7232a057362119eeab91ab075..c5d319dffc67e9d0bc8f305b41424fbc05039d9b 100644 (file)
@@ -140,7 +140,7 @@ static int read_header(AVFormatContext *s, AVFormatParameters *ap)
         ass->event[i]= p;
         while(*p && *p != '\n')
             p++;
         ass->event[i]= p;
         while(*p && *p != '\n')
             p++;
-        *p++ = 0;
+        p++;
     }
 
     qsort(ass->event, ass->event_count, sizeof(*ass->event), event_cmp);
     }
 
     qsort(ass->event, ass->event_count, sizeof(*ass->event), event_cmp);
@@ -156,14 +156,15 @@ fail:
 static int read_packet(AVFormatContext *s, AVPacket *pkt)
 {
     ASSContext *ass = s->priv_data;
 static int read_packet(AVFormatContext *s, AVPacket *pkt)
 {
     ASSContext *ass = s->priv_data;
-    uint8_t *p;
+    uint8_t *p, *end;
 
     if(ass->event_index >= ass->event_count)
         return AVERROR(EIO);
 
     p= ass->event[ ass->event_index ];
 
 
     if(ass->event_index >= ass->event_count)
         return AVERROR(EIO);
 
     p= ass->event[ ass->event_index ];
 
-    av_new_packet(pkt, strlen(p));
+    end= strchr(p, '\n');
+    av_new_packet(pkt, end ? end-p+1 : strlen(p));
     pkt->flags |= PKT_FLAG_KEY;
     pkt->pos= p - ass->event_buffer + s->streams[0]->codec->extradata_size;
     pkt->pts= pkt->dts= get_pts(p);
     pkt->flags |= PKT_FLAG_KEY;
     pkt->pos= p - ass->event_buffer + s->streams[0]->codec->extradata_size;
     pkt->pts= pkt->dts= get_pts(p);