diff options
author | Anton Khirnov <anton@khirnov.net> | 2011-11-21 14:39:22 +0100 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2011-11-21 18:12:38 +0100 |
commit | 9595234c941cb81ffc2858e3f5859f0b9fa58a39 (patch) | |
tree | 1b59d9f0c95e8d910065eb1dc9cb16b9a0d0da46 | |
parent | 45d4b66f6fa7115124ae0051dc24cda1017f95a0 (diff) | |
download | ffmpeg-9595234c941cb81ffc2858e3f5859f0b9fa58a39.tar.gz |
avconv: split subtitle transcoding out of output_packet().
-rw-r--r-- | avconv.c | 59 |
1 files changed, 34 insertions, 25 deletions
@@ -1811,16 +1811,41 @@ fail: return ret; } +static int transcode_subtitles(InputStream *ist, AVPacket *pkt, int *got_output) +{ + AVSubtitle subtitle; + int i, ret = avcodec_decode_subtitle2(ist->st->codec, + &subtitle, got_output, pkt); + if (ret < 0) + return ret; + if (!*got_output) + return 0; + + pkt->size = 0; + + rate_emu_sleep(ist); + + for (i = 0; i < nb_output_streams; i++) { + OutputStream *ost = &output_streams[i]; + + if (!check_output_constraints(ist, ost) || !ost->encoding_needed) + continue; + + do_subtitle_out(output_files[ost->file_index].ctx, ost, ist, &subtitle, pkt->pts); + } + + avsubtitle_free(&subtitle); + return 0; +} + /* pkt = NULL means EOF (needed to flush decoder buffers) */ static int output_packet(InputStream *ist, int ist_index, OutputStream *ost_table, int nb_ostreams, const AVPacket *pkt) { - AVFormatContext *os; OutputStream *ost; int ret = 0, i; int got_output; - AVSubtitle subtitle, *subtitle_to_free; int64_t pkt_pts = AV_NOPTS_VALUE; AVPacket avpkt; @@ -1867,22 +1892,17 @@ static int output_packet(InputStream *ist, int ist_index, if (!got_output) goto discard_packet; continue; + } else if (ist->st->codec->codec_type == AVMEDIA_TYPE_SUBTITLE) { + ret = transcode_subtitles(ist, &avpkt, &got_output); + if (ret < 0) + return ret; + if (!got_output) + goto discard_packet; + continue; } /* decode the packet if needed */ - subtitle_to_free = NULL; switch(ist->st->codec->codec_type) { - case AVMEDIA_TYPE_SUBTITLE: - ret = avcodec_decode_subtitle2(ist->st->codec, - &subtitle, &got_output, &avpkt); - if (ret < 0) - return ret; - if (!got_output) { - goto discard_packet; - } - subtitle_to_free = &subtitle; - avpkt.size = 0; - break; default: return -1; } @@ -1898,27 +1918,16 @@ static int output_packet(InputStream *ist, int ist_index, if (!check_output_constraints(ist, ost) || !ost->encoding_needed) continue; - os = output_files[ost->file_index].ctx; - /* set the input output pts pairs */ //ost->sync_ipts = (double)(ist->pts + input_files[ist->file_index].ts_offset - start_time)/ AV_TIME_BASE; av_assert0(ist->decoding_needed); switch(ost->st->codec->codec_type) { - case AVMEDIA_TYPE_SUBTITLE: - do_subtitle_out(os, ost, ist, &subtitle, - pkt->pts); - break; default: abort(); } } - /* XXX: allocate the subtitles in the codec ? */ - if (subtitle_to_free) { - avsubtitle_free(subtitle_to_free); - subtitle_to_free = NULL; - } if (ret < 0) return ret; } |