[FFmpeg-cvslog] lavc: reimplement avcodec_get_name with descriptors.
    Nicolas George 
    git at videolan.org
       
    Tue Aug 14 11:57:13 CEST 2012
    
    
  
ffmpeg | branch: master | Nicolas George <nicolas.george at normalesup.org> | Mon Aug 13 11:27:20 2012 +0200| [9bb936a80e72ae3439ded56f08f3d558700537c2] | committer: Nicolas George
lavc: reimplement avcodec_get_name with descriptors.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=9bb936a80e72ae3439ded56f08f3d558700537c2
---
 libavcodec/Makefile       |    8 -----
 libavcodec/codec_names.sh |   84 ---------------------------------------------
 libavcodec/utils.c        |    9 +++--
 3 files changed, 4 insertions(+), 97 deletions(-)
diff --git a/libavcodec/Makefile b/libavcodec/Makefile
index 251a6b2..34e4cc3 100644
--- a/libavcodec/Makefile
+++ b/libavcodec/Makefile
@@ -785,7 +785,6 @@ OBJS-$(!CONFIG_SMALL)                  += inverse.o
 SKIPHEADERS                            += %_tablegen.h                  \
                                           %_tables.h                    \
                                           aac_tablegen_decl.h           \
-                                          codec_names.h                 \
                                           fft-internal.h                \
                                           old_codec_ids.h               \
                                           tableprint.h                  \
@@ -860,10 +859,3 @@ $(SUBDIR)motionpixels.o: $(SUBDIR)motionpixels_tables.h
 $(SUBDIR)pcm.o: $(SUBDIR)pcm_tables.h
 $(SUBDIR)qdm2.o: $(SUBDIR)qdm2_tables.h
 endif
-
-CODEC_NAMES_SH := $(SRC_PATH)/$(SUBDIR)codec_names.sh
-AVCODEC_H      := $(SRC_PATH)/$(SUBDIR)avcodec.h
-$(SUBDIR)codec_names.h: $(CODEC_NAMES_SH) config.h $(AVCODEC_H)
-	$(CC) $(CPPFLAGS) $(CFLAGS) -E $(AVCODEC_H) | \
-	$(CODEC_NAMES_SH) config.h $@
-$(SUBDIR)utils.o: $(SUBDIR)codec_names.h
diff --git a/libavcodec/codec_names.sh b/libavcodec/codec_names.sh
deleted file mode 100755
index 44ccb45..0000000
--- a/libavcodec/codec_names.sh
+++ /dev/null
@@ -1,84 +0,0 @@
-#!/bin/sh
-
-# Copyright (c) 2011 Nicolas George
-#
-# This file is part of FFmpeg.
-#
-# FFmpeg is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 2.1 of the License, or (at your option) any later version.
-#
-# FFmpeg is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser General Public
-# License along with FFmpeg; if not, write to the Free Software Foundation,
-# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
-
-set -e
-
-config="$1"
-out="$2"
-test -n "$out"
-
-outval=""
-
-add_line () {
-  outval="$outval$*
-"
-}
-
-parse_config_h () {
-  while read define var value; do
-    case "$define $var $value" in
-      "#define CONFIG_"*_*" 1") eval "$var=1";;
-    esac
-  done
-}
-
-define_codecid () {
-  id="$1"
-  n=${1#AV_CODEC_ID_}
-  add_line "case ${id}:"
-  eval "c=\${CONFIG_${n}_DECODER}:\${CONFIG_${n}_ENCODER}"
-  case "$c" in
-    1:*) s="decoder";;
-    *:1) s="encoder";;
-    *) s="";;
-  esac
-  case "$s" in
-    "") add_line "    return \"$n\";" ;;
-    *)
-      add_line "    { extern AVCodec ff_${n}_${s};"
-      add_line "      return ff_${n}_${s}.name; }"
-      ;;
-  esac
-}
-
-parse_enum_codecid () {
-  while read line; do
-    case "$line" in
-      "};") break;;
-      *AV_CODEC_ID_FIRST*=*) ;;
-      AV_CODEC_ID_*) define_codecid ${line%%[=,]*};;
-    esac
-  done
-}
-
-parse_avcodec_h () {
-  while read line; do
-    case "$line" in
-      "enum AVCodecID {") parse_enum_codecid; break;;
-    esac
-  done
-}
-
-parse_config_h  < "$config"
-parse_avcodec_h # use stdin
-sed -e '/case.*:/!y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/' \
-    -e 's/extern avcodec /extern AVCodec /' > "$out" <<EOF
-$outval
-EOF
diff --git a/libavcodec/utils.c b/libavcodec/utils.c
index 90df647..03caf1c 100644
--- a/libavcodec/utils.c
+++ b/libavcodec/utils.c
@@ -1847,14 +1847,13 @@ AVCodec *avcodec_find_decoder_by_name(const char *name)
 
 const char *avcodec_get_name(enum AVCodecID id)
 {
+    const AVCodecDescriptor *cd;
     AVCodec *codec;
 
-#if !CONFIG_SMALL
-    switch (id) {
-#include "libavcodec/codec_names.h"
-    }
+    cd = avcodec_descriptor_get(id);
+    if (cd)
+        return cd->name;
     av_log(NULL, AV_LOG_WARNING, "Codec 0x%x is not in the full list.\n", id);
-#endif
     codec = avcodec_find_decoder(id);
     if (codec)
         return codec->name;
    
    
More information about the ffmpeg-cvslog
mailing list