]> git.sesse.net Git - ffmpeg/commitdiff
pcmdec: use unique classes for all pcm demuxers.
authorAnton Khirnov <anton@khirnov.net>
Wed, 14 Sep 2011 07:54:29 +0000 (09:54 +0200)
committerAnton Khirnov <anton@khirnov.net>
Sat, 17 Sep 2011 04:42:32 +0000 (06:42 +0200)
libavformat/pcmdec.c
libavformat/rawdec.c
libavformat/rawdec.h

index 343bbf0ae23e09867075cae9b7cb8daa14fbace1..90799dd664b461ee571a4363a5c044fe8f7873e1 100644 (file)
@@ -22,6 +22,8 @@
 #include "avformat.h"
 #include "rawdec.h"
 #include "pcm.h"
+#include "libavutil/log.h"
+#include "libavutil/opt.h"
 
 #define RAW_SAMPLES     1024
 
@@ -46,7 +48,19 @@ static int raw_read_packet(AVFormatContext *s, AVPacket *pkt)
     return ret;
 }
 
+static const AVOption pcm_options[] = {
+    { "sample_rate", "", offsetof(RawAudioDemuxerContext, sample_rate), FF_OPT_TYPE_INT, {.dbl = 0}, 0, INT_MAX, AV_OPT_FLAG_DECODING_PARAM },
+    { "channels",    "", offsetof(RawAudioDemuxerContext, channels),    FF_OPT_TYPE_INT, {.dbl = 0}, 0, INT_MAX, AV_OPT_FLAG_DECODING_PARAM },
+    { NULL },
+};
+
 #define PCMDEF(name, long_name, ext, codec) \
+static const AVClass name ## _demuxer_class = {\
+    .class_name = #name " demuxer",\
+    .item_name  = av_default_item_name,\
+    .option     = pcm_options,\
+    .version    = LIBAVUTIL_VERSION_INT,\
+};\
 AVInputFormat ff_pcm_ ## name ## _demuxer = {\
     #name,\
     NULL_IF_CONFIG_SMALL(long_name),\
@@ -59,7 +73,7 @@ AVInputFormat ff_pcm_ ## name ## _demuxer = {\
     .flags= AVFMT_GENERIC_INDEX,\
     .extensions = ext,\
     .value = codec,\
-    .priv_class = &ff_rawaudio_demuxer_class,\
+    .priv_class = &name ## _demuxer_class,\
 };
 
 PCMDEF(f64be, "PCM 64 bit floating-point big-endian format",
index f0d487bd6fe19abf89d4e680dfca10d382070d4f..0b9a0824ff0ff3d8ca06614d5a85b7849dfc37eb 100644 (file)
@@ -167,19 +167,6 @@ fail:
 
 /* Note: Do not forget to add new entries to the Makefile as well. */
 
-static const AVOption audio_options[] = {
-    { "sample_rate", "", offsetof(RawAudioDemuxerContext, sample_rate), FF_OPT_TYPE_INT, {.dbl = 0}, 0, INT_MAX, AV_OPT_FLAG_DECODING_PARAM },
-    { "channels",    "", offsetof(RawAudioDemuxerContext, channels),    FF_OPT_TYPE_INT, {.dbl = 0}, 0, INT_MAX, AV_OPT_FLAG_DECODING_PARAM },
-    { NULL },
-};
-
-const AVClass ff_rawaudio_demuxer_class = {
-    .class_name     = "rawaudio demuxer",
-    .item_name      = av_default_item_name,
-    .option         = audio_options,
-    .version        = LIBAVUTIL_VERSION_INT,
-};
-
 #define OFFSET(x) offsetof(FFRawVideoDemuxerContext, x)
 #define DEC AV_OPT_FLAG_DECODING_PARAM
 static const AVOption video_options[] = {
index 76e8053f6dc1b462a291a56d51be052b30da8b1f..73bfb4abc45fa1e985dd4f27430fe65b3fb9d975 100644 (file)
@@ -38,7 +38,6 @@ typedef struct FFRawVideoDemuxerContext {
     char *framerate;          /**< String describing framerate, set by a private option. */
 } FFRawVideoDemuxerContext;
 
-extern const AVClass ff_rawaudio_demuxer_class;
 extern const AVClass ff_rawvideo_demuxer_class;
 
 int ff_raw_read_header(AVFormatContext *s, AVFormatParameters *ap);