Commit 3d66717f authored by Anton Khirnov's avatar Anton Khirnov

examples/decode_audio: use the new audio decoding API

parent 0946c754
...@@ -40,24 +40,30 @@ ...@@ -40,24 +40,30 @@
static void decode(AVCodecContext *dec_ctx, AVPacket *pkt, AVFrame *frame, static void decode(AVCodecContext *dec_ctx, AVPacket *pkt, AVFrame *frame,
FILE *outfile) FILE *outfile)
{ {
int len, got_frame; int ret, data_size;
while (pkt->size > 0) { /* send the packet with the compressed data to the decoder */
len = avcodec_decode_audio4(dec_ctx, frame, &got_frame, pkt); ret = avcodec_send_packet(dec_ctx, pkt);
if (len < 0) { if (ret < 0) {
fprintf(stderr, "Error while decoding\n"); fprintf(stderr, "Error submitting the packet to the decoder\n");
exit(1);
}
/* read all the output frames (in general there may be any number of them */
while (ret >= 0) {
ret = avcodec_receive_frame(dec_ctx, frame);
if (ret == AVERROR(EAGAIN) || ret == AVERROR_EOF)
return;
else if (ret < 0) {
fprintf(stderr, "Error during decoding\n");
exit(1); exit(1);
} }
if (got_frame) {
/* if a frame has been decoded, output it */ data_size = av_samples_get_buffer_size(NULL, dec_ctx->channels,
int data_size = av_samples_get_buffer_size(NULL, dec_ctx->channels,
frame->nb_samples, frame->nb_samples,
dec_ctx->sample_fmt, 1); dec_ctx->sample_fmt, 1);
fwrite(frame->data[0], 1, data_size, outfile); fwrite(frame->data[0], 1, data_size, outfile);
} }
pkt->size -= len;
pkt->data += len;
}
} }
int main(int argc, char **argv) int main(int argc, char **argv)
......
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