Commit 47a3439e authored by Anton Khirnov's avatar Anton Khirnov Committed by Michael Niedermayer

ffmpeg: save two levels of indentation in flush_encoders()

By replacing
if (foo)
    <do stuff>

with
if (!foo)
    continue;
<do stuff>
parent a16f1afb
...@@ -1450,84 +1450,82 @@ static void flush_encoders(int ist_index, OutputStream *ost_table, int nb_ostrea ...@@ -1450,84 +1450,82 @@ static void flush_encoders(int ist_index, OutputStream *ost_table, int nb_ostrea
int i, ret; int i, ret;
for (i = 0; i < nb_ostreams; i++) { for (i = 0; i < nb_ostreams; i++) {
OutputStream *ost = &ost_table[i]; OutputStream *ost = &ost_table[i];
AVCodecContext *enc = ost->st->codec;
AVFormatContext *os = output_files[ost->file_index].ctx;
if (ost->source_index == ist_index) { if (ost->source_index != ist_index || !ost->encoding_needed)
AVCodecContext *enc = ost->st->codec; continue;
AVFormatContext *os = output_files[ost->file_index].ctx;
if(ost->st->codec->codec_type == AVMEDIA_TYPE_AUDIO && enc->frame_size <=1)
continue;
if(ost->st->codec->codec_type == AVMEDIA_TYPE_VIDEO && (os->oformat->flags & AVFMT_RAWPICTURE))
continue;
if (ost->encoding_needed) { if (ost->st->codec->codec_type == AVMEDIA_TYPE_AUDIO && enc->frame_size <=1)
for(;;) { continue;
AVPacket pkt; if (ost->st->codec->codec_type == AVMEDIA_TYPE_VIDEO && (os->oformat->flags & AVFMT_RAWPICTURE))
int fifo_bytes; continue;
av_init_packet(&pkt);
pkt.stream_index= ost->index;
switch (ost->st->codec->codec_type) { for(;;) {
case AVMEDIA_TYPE_AUDIO: AVPacket pkt;
fifo_bytes = av_fifo_size(ost->fifo); int fifo_bytes;
ret = 0; av_init_packet(&pkt);
/* encode any samples remaining in fifo */ pkt.stream_index= ost->index;
if (fifo_bytes > 0) {
int osize = av_get_bytes_per_sample(enc->sample_fmt);
int fs_tmp = enc->frame_size;
av_fifo_generic_read(ost->fifo, audio_buf, fifo_bytes, NULL);
if (enc->codec->capabilities & CODEC_CAP_SMALL_LAST_FRAME) {
enc->frame_size = fifo_bytes / (osize * enc->channels);
} else { /* pad */
int frame_bytes = enc->frame_size*osize*enc->channels;
if (allocated_audio_buf_size < frame_bytes)
exit_program(1);
generate_silence(audio_buf+fifo_bytes, enc->sample_fmt, frame_bytes - fifo_bytes);
}
ret = avcodec_encode_audio(enc, bit_buffer, bit_buffer_size, (short *)audio_buf); switch (ost->st->codec->codec_type) {
pkt.duration = av_rescale((int64_t)enc->frame_size*ost->st->time_base.den, case AVMEDIA_TYPE_AUDIO:
ost->st->time_base.num, enc->sample_rate); fifo_bytes = av_fifo_size(ost->fifo);
enc->frame_size = fs_tmp; ret = 0;
} /* encode any samples remaining in fifo */
if (ret <= 0) { if (fifo_bytes > 0) {
ret = avcodec_encode_audio(enc, bit_buffer, bit_buffer_size, NULL); int osize = av_get_bytes_per_sample(enc->sample_fmt);
} int fs_tmp = enc->frame_size;
if (ret < 0) {
fprintf(stderr, "Audio encoding failed\n"); av_fifo_generic_read(ost->fifo, audio_buf, fifo_bytes, NULL);
exit_program(1); if (enc->codec->capabilities & CODEC_CAP_SMALL_LAST_FRAME) {
} enc->frame_size = fifo_bytes / (osize * enc->channels);
audio_size += ret; } else { /* pad */
pkt.flags |= AV_PKT_FLAG_KEY; int frame_bytes = enc->frame_size*osize*enc->channels;
break; if (allocated_audio_buf_size < frame_bytes)
case AVMEDIA_TYPE_VIDEO:
ret = avcodec_encode_video(enc, bit_buffer, bit_buffer_size, NULL);
if (ret < 0) {
fprintf(stderr, "Video encoding failed\n");
exit_program(1); exit_program(1);
} generate_silence(audio_buf+fifo_bytes, enc->sample_fmt, frame_bytes - fifo_bytes);
video_size += ret;
if(enc->coded_frame && enc->coded_frame->key_frame)
pkt.flags |= AV_PKT_FLAG_KEY;
if (ost->logfile && enc->stats_out) {
fprintf(ost->logfile, "%s", enc->stats_out);
}
break;
default:
ret=-1;
} }
if (ret <= 0) ret = avcodec_encode_audio(enc, bit_buffer, bit_buffer_size, (short *)audio_buf);
break; pkt.duration = av_rescale((int64_t)enc->frame_size*ost->st->time_base.den,
pkt.data = bit_buffer; ost->st->time_base.num, enc->sample_rate);
pkt.size = ret; enc->frame_size = fs_tmp;
if (enc->coded_frame && enc->coded_frame->pts != AV_NOPTS_VALUE) }
pkt.pts= av_rescale_q(enc->coded_frame->pts, enc->time_base, ost->st->time_base); if (ret <= 0) {
write_frame(os, &pkt, ost->st->codec, ost->bitstream_filters); ret = avcodec_encode_audio(enc, bit_buffer, bit_buffer_size, NULL);
}
if (ret < 0) {
fprintf(stderr, "Audio encoding failed\n");
exit_program(1);
}
audio_size += ret;
pkt.flags |= AV_PKT_FLAG_KEY;
break;
case AVMEDIA_TYPE_VIDEO:
ret = avcodec_encode_video(enc, bit_buffer, bit_buffer_size, NULL);
if (ret < 0) {
fprintf(stderr, "Video encoding failed\n");
exit_program(1);
} }
video_size += ret;
if(enc->coded_frame && enc->coded_frame->key_frame)
pkt.flags |= AV_PKT_FLAG_KEY;
if (ost->logfile && enc->stats_out) {
fprintf(ost->logfile, "%s", enc->stats_out);
}
break;
default:
ret=-1;
} }
if (ret <= 0)
break;
pkt.data = bit_buffer;
pkt.size = ret;
if (enc->coded_frame && enc->coded_frame->pts != AV_NOPTS_VALUE)
pkt.pts= av_rescale_q(enc->coded_frame->pts, enc->time_base, ost->st->time_base);
write_frame(os, &pkt, ost->st->codec, ost->bitstream_filters);
} }
} }
} }
......
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