Commit f82368b3 authored by bellard's avatar bellard

make av_read_frame() return buffered frames at EOF


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@2616 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 080b6b47
...@@ -658,7 +658,7 @@ static void av_destruct_packet_nofree(AVPacket *pkt) ...@@ -658,7 +658,7 @@ static void av_destruct_packet_nofree(AVPacket *pkt)
static int av_read_frame_internal(AVFormatContext *s, AVPacket *pkt) static int av_read_frame_internal(AVFormatContext *s, AVPacket *pkt)
{ {
AVStream *st; AVStream *st;
int len, ret; int len, ret, i;
for(;;) { for(;;) {
/* select current input stream component */ /* select current input stream component */
...@@ -690,6 +690,7 @@ static int av_read_frame_internal(AVFormatContext *s, AVPacket *pkt) ...@@ -690,6 +690,7 @@ static int av_read_frame_internal(AVFormatContext *s, AVPacket *pkt)
/* return packet if any */ /* return packet if any */
if (pkt->size) { if (pkt->size) {
got_packet:
pkt->duration = 0; pkt->duration = 0;
pkt->stream_index = st->index; pkt->stream_index = st->index;
pkt->pts = st->cur_frame_pts; pkt->pts = st->cur_frame_pts;
...@@ -707,8 +708,23 @@ static int av_read_frame_internal(AVFormatContext *s, AVPacket *pkt) ...@@ -707,8 +708,23 @@ static int av_read_frame_internal(AVFormatContext *s, AVPacket *pkt)
} else { } else {
/* read next packet */ /* read next packet */
ret = av_read_packet(s, &s->cur_pkt); ret = av_read_packet(s, &s->cur_pkt);
if (ret < 0) if (ret < 0) {
if (ret == -EAGAIN)
return ret; return ret;
/* return the last frames, if any */
for(i = 0; i < s->nb_streams; i++) {
st = s->streams[i];
if (st->parser) {
av_parser_parse(st->parser, &st->codec,
&pkt->data, &pkt->size,
NULL, 0);
if (pkt->size)
goto got_packet;
}
}
/* no more packets: really terminates parsing */
return ret;
}
/* convert the packet time stamp units and handle wrapping */ /* convert the packet time stamp units and handle wrapping */
s->cur_pkt.pts = convert_timestamp_units(s, s->cur_pkt.pts = convert_timestamp_units(s,
...@@ -2052,8 +2068,12 @@ void av_pkt_dump(FILE *f, AVPacket *pkt, int dump_payload) ...@@ -2052,8 +2068,12 @@ void av_pkt_dump(FILE *f, AVPacket *pkt, int dump_payload)
fprintf(f, "stream #%d:\n", pkt->stream_index); fprintf(f, "stream #%d:\n", pkt->stream_index);
fprintf(f, " keyframe=%d\n", ((pkt->flags & PKT_FLAG_KEY) != 0)); fprintf(f, " keyframe=%d\n", ((pkt->flags & PKT_FLAG_KEY) != 0));
fprintf(f, " duration=%0.3f\n", (double)pkt->duration / AV_TIME_BASE); fprintf(f, " duration=%0.3f\n", (double)pkt->duration / AV_TIME_BASE);
/* DTS is _always_ valid */ /* DTS is _always_ valid after av_read_frame() */
fprintf(f, " dts=%0.3f\n", (double)pkt->dts / AV_TIME_BASE); fprintf(f, " dts=");
if (pkt->dts == AV_NOPTS_VALUE)
fprintf(f, "N/A");
else
fprintf(f, "%0.3f", (double)pkt->dts / AV_TIME_BASE);
/* PTS may be not known if B frames are present */ /* PTS may be not known if B frames are present */
fprintf(f, " pts="); fprintf(f, " pts=");
if (pkt->pts == AV_NOPTS_VALUE) if (pkt->pts == AV_NOPTS_VALUE)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment