]> git.sesse.net Git - ffmpeg/commitdiff
avprobe: print information from the codec descriptor
authorAnton Khirnov <anton@khirnov.net>
Thu, 21 Jan 2016 15:40:59 +0000 (16:40 +0100)
committerAnton Khirnov <anton@khirnov.net>
Fri, 26 Feb 2016 08:14:49 +0000 (09:14 +0100)
avprobe is not doing any decoding, so this is more correct than printing
information from a random codec implementation.

avprobe.c

index 3dd41bbb8120beda2d4a0d427af1cdda5c210563..1fdcd017cff88be2babc18e65587143d9d25e94f 100644 (file)
--- a/avprobe.c
+++ b/avprobe.c
@@ -600,7 +600,7 @@ static void show_stream(AVFormatContext *fmt_ctx, int stream_idx)
 {
     AVStream *stream = fmt_ctx->streams[stream_idx];
     AVCodecContext *dec_ctx;
-    const AVCodec *dec;
+    const AVCodecDescriptor *codec_desc;
     const char *profile;
     char val_str[128];
     AVRational display_aspect_ratio, *sar = NULL;
@@ -611,9 +611,10 @@ static void show_stream(AVFormatContext *fmt_ctx, int stream_idx)
     probe_int("index", stream->index);
 
     dec_ctx = stream->codec;
-    if ((dec = dec_ctx->codec)) {
-        probe_str("codec_name", dec->name);
-        probe_str("codec_long_name", dec->long_name);
+    codec_desc = avcodec_descriptor_get(dec_ctx->codec_id);
+    if (codec_desc) {
+        probe_str("codec_name", codec_desc->name);
+        probe_str("codec_long_name", codec_desc->long_name);
     } else {
         probe_str("codec_name", "unknown");
     }
@@ -630,7 +631,8 @@ static void show_stream(AVFormatContext *fmt_ctx, int stream_idx)
                                       dec_ctx->codec_tag));
 
     /* print profile, if there is one */
-    if (dec && (profile = av_get_profile_name(dec, dec_ctx->profile)))
+    profile = avcodec_profile_name(dec_ctx->codec_id, dec_ctx->profile);
+    if (profile)
         probe_str("profile", profile);
 
     switch (dec_ctx->codec_type) {