]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
Do not loose the '\n'.
authormichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Fri, 26 Sep 2008 03:24:05 +0000 (03:24 +0000)
committermichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Fri, 26 Sep 2008 03:24:05 +0000 (03:24 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@15424 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

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++;
-        *p++ = 0;
+        p++;
     }
 
     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;
-    uint8_t *p;
+    uint8_t *p, *end;
 
     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);