examples/muxing: improve error messages.
Illustrate the use of return values, av_err2str and avcodec_get_name.
This commit is contained in:
parent
b99bef17b4
commit
e4f14c32b9
@ -63,7 +63,8 @@ static AVStream *add_stream(AVFormatContext *oc, AVCodec **codec,
|
|||||||
/* find the encoder */
|
/* find the encoder */
|
||||||
*codec = avcodec_find_encoder(codec_id);
|
*codec = avcodec_find_encoder(codec_id);
|
||||||
if (!(*codec)) {
|
if (!(*codec)) {
|
||||||
fprintf(stderr, "Could not find codec\n");
|
fprintf(stderr, "Could not find encoder for '%s'\n",
|
||||||
|
avcodec_get_name(codec_id));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,12 +134,14 @@ static int audio_input_frame_size;
|
|||||||
static void open_audio(AVFormatContext *oc, AVCodec *codec, AVStream *st)
|
static void open_audio(AVFormatContext *oc, AVCodec *codec, AVStream *st)
|
||||||
{
|
{
|
||||||
AVCodecContext *c;
|
AVCodecContext *c;
|
||||||
|
int ret;
|
||||||
|
|
||||||
c = st->codec;
|
c = st->codec;
|
||||||
|
|
||||||
/* open it */
|
/* open it */
|
||||||
if (avcodec_open2(c, codec, NULL) < 0) {
|
ret = avcodec_open2(c, codec, NULL);
|
||||||
fprintf(stderr, "Could not open audio codec\n");
|
if (ret < 0) {
|
||||||
|
fprintf(stderr, "Could not open audio codec: %s\n", av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -198,7 +201,7 @@ static void write_audio_frame(AVFormatContext *oc, AVStream *st)
|
|||||||
|
|
||||||
ret = avcodec_encode_audio2(c, &pkt, frame, &got_packet);
|
ret = avcodec_encode_audio2(c, &pkt, frame, &got_packet);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
fprintf(stderr, "Error encoding audio frame\n");
|
fprintf(stderr, "Error encoding audio frame: %s\n", av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -208,8 +211,10 @@ static void write_audio_frame(AVFormatContext *oc, AVStream *st)
|
|||||||
pkt.stream_index = st->index;
|
pkt.stream_index = st->index;
|
||||||
|
|
||||||
/* Write the compressed frame to the media file. */
|
/* Write the compressed frame to the media file. */
|
||||||
if (av_interleaved_write_frame(oc, &pkt) != 0) {
|
ret = av_interleaved_write_frame(oc, &pkt);
|
||||||
fprintf(stderr, "Error while writing audio frame\n");
|
if (ret != 0) {
|
||||||
|
fprintf(stderr, "Error while writing audio frame: %s\n",
|
||||||
|
av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
avcodec_free_frame(&frame);
|
avcodec_free_frame(&frame);
|
||||||
@ -235,8 +240,9 @@ static void open_video(AVFormatContext *oc, AVCodec *codec, AVStream *st)
|
|||||||
AVCodecContext *c = st->codec;
|
AVCodecContext *c = st->codec;
|
||||||
|
|
||||||
/* open the codec */
|
/* open the codec */
|
||||||
if (avcodec_open2(c, codec, NULL) < 0) {
|
ret = avcodec_open2(c, codec, NULL);
|
||||||
fprintf(stderr, "Could not open video codec\n");
|
if (ret < 0) {
|
||||||
|
fprintf(stderr, "Could not open video codec: %s\n", av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -250,7 +256,7 @@ static void open_video(AVFormatContext *oc, AVCodec *codec, AVStream *st)
|
|||||||
/* Allocate the encoded raw picture. */
|
/* Allocate the encoded raw picture. */
|
||||||
ret = avpicture_alloc(&dst_picture, c->pix_fmt, c->width, c->height);
|
ret = avpicture_alloc(&dst_picture, c->pix_fmt, c->width, c->height);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
fprintf(stderr, "Could not allocate picture\n");
|
fprintf(stderr, "Could not allocate picture: %s\n", av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -260,7 +266,8 @@ static void open_video(AVFormatContext *oc, AVCodec *codec, AVStream *st)
|
|||||||
if (c->pix_fmt != AV_PIX_FMT_YUV420P) {
|
if (c->pix_fmt != AV_PIX_FMT_YUV420P) {
|
||||||
ret = avpicture_alloc(&src_picture, AV_PIX_FMT_YUV420P, c->width, c->height);
|
ret = avpicture_alloc(&src_picture, AV_PIX_FMT_YUV420P, c->width, c->height);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
fprintf(stderr, "Could not allocate temporary picture\n");
|
fprintf(stderr, "Could not allocate temporary picture: %s\n",
|
||||||
|
av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -346,7 +353,7 @@ static void write_video_frame(AVFormatContext *oc, AVStream *st)
|
|||||||
|
|
||||||
ret = avcodec_encode_video2(c, &pkt, frame, &got_output);
|
ret = avcodec_encode_video2(c, &pkt, frame, &got_output);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
fprintf(stderr, "Error encoding video frame\n");
|
fprintf(stderr, "Error encoding video frame: %s\n", av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -364,7 +371,7 @@ static void write_video_frame(AVFormatContext *oc, AVStream *st)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
fprintf(stderr, "Error while writing video frame\n");
|
fprintf(stderr, "Error while writing video frame: %s\n", av_err2str(ret));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
frame_count++;
|
frame_count++;
|
||||||
@ -389,7 +396,7 @@ int main(int argc, char **argv)
|
|||||||
AVStream *audio_st, *video_st;
|
AVStream *audio_st, *video_st;
|
||||||
AVCodec *audio_codec, *video_codec;
|
AVCodec *audio_codec, *video_codec;
|
||||||
double audio_pts, video_pts;
|
double audio_pts, video_pts;
|
||||||
int i;
|
int ret, i;
|
||||||
|
|
||||||
/* Initialize libavcodec, and register all codecs and formats. */
|
/* Initialize libavcodec, and register all codecs and formats. */
|
||||||
av_register_all();
|
av_register_all();
|
||||||
@ -441,15 +448,19 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
/* open the output file, if needed */
|
/* open the output file, if needed */
|
||||||
if (!(fmt->flags & AVFMT_NOFILE)) {
|
if (!(fmt->flags & AVFMT_NOFILE)) {
|
||||||
if (avio_open(&oc->pb, filename, AVIO_FLAG_WRITE) < 0) {
|
ret = avio_open(&oc->pb, filename, AVIO_FLAG_WRITE);
|
||||||
fprintf(stderr, "Could not open '%s'\n", filename);
|
if (ret < 0) {
|
||||||
|
fprintf(stderr, "Could not open '%s': %s\n", filename,
|
||||||
|
av_err2str(ret));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Write the stream header, if any. */
|
/* Write the stream header, if any. */
|
||||||
if (avformat_write_header(oc, NULL) < 0) {
|
ret = avformat_write_header(oc, NULL);
|
||||||
fprintf(stderr, "Error occurred when opening output file\n");
|
if (ret < 0) {
|
||||||
|
fprintf(stderr, "Error occurred when opening output file: %s\n",
|
||||||
|
av_err2str(ret));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user