diff options
-rw-r--r-- | gst/wavenc/gstwavenc.c | 55 | ||||
-rw-r--r-- | gst/wavparse/gstwavparse.c | 55 |
2 files changed, 58 insertions, 52 deletions
diff --git a/gst/wavenc/gstwavenc.c b/gst/wavenc/gstwavenc.c index 742cafa1..3ae12e07 100644 --- a/gst/wavenc/gstwavenc.c +++ b/gst/wavenc/gstwavenc.c @@ -27,6 +27,7 @@ #include <gstwavenc.h> #include <riff.h> +static void gst_wavenc_base_init (gpointer g_class); static void gst_wavenc_class_init (GstWavEncClass *klass); static void gst_wavenc_init (GstWavEnc *wavenc); static void gst_wavenc_chain (GstPad *pad, GstData *_data); @@ -68,15 +69,12 @@ struct wave_header { struct chunk_struct data; }; -static GstElementDetails gst_wavenc_details = { +static GstElementDetails gst_wavenc_details = GST_ELEMENT_DETAILS ( "WAV encoder", "Codec/Audio/Encoder", - "LGPL", "Encode raw audio into WAV", - VERSION, - "Iain Holmes <iain@prettypeople.org>", - "(C) 2002", -}; + "Iain Holmes <iain@prettypeople.org>" +); static GstPadTemplate *srctemplate, *sinktemplate; @@ -128,7 +126,7 @@ gst_wavenc_get_type (void) if (type == 0) { static const GTypeInfo info = { sizeof (GstWavEncClass), - NULL, + gst_wavenc_base_init, NULL, (GClassInitFunc) gst_wavenc_class_init, NULL, @@ -186,6 +184,19 @@ set_property (GObject *object, } static void +gst_wavenc_base_init (gpointer g_class) +{ + GstElementClass *element_class = GST_ELEMENT_CLASS (g_class); + + gst_element_class_set_details (element_class, &gst_wavenc_details); + + srctemplate = src_factory (); + gst_element_class_add_pad_template (element_class, srctemplate); + + sinktemplate = sink_factory (); + gst_element_class_add_pad_template (element_class, sinktemplate); +} +static void gst_wavenc_class_init (GstWavEncClass *klass) { GstElementClass *element_class; @@ -642,29 +653,21 @@ gst_wavenc_chain (GstPad *pad, } static gboolean -plugin_init (GModule *module, - GstPlugin *plugin) +plugin_init (GstPlugin *plugin) { - GstElementFactory *factory; - - factory = gst_element_factory_new ("wavenc", GST_TYPE_WAVENC, - &gst_wavenc_details); - - srctemplate = src_factory (); - gst_element_factory_add_pad_template (factory, srctemplate); - - sinktemplate = sink_factory (); - gst_element_factory_add_pad_template (factory, sinktemplate); - - gst_plugin_add_feature (plugin, GST_PLUGIN_FEATURE (factory)); - - return TRUE; + return gst_element_register (plugin, "wavenc", GST_RANK_NONE, GST_TYPE_WAVENC); } -GstPluginDesc plugin_desc = { +GST_PLUGIN_DEFINE ( GST_VERSION_MAJOR, GST_VERSION_MINOR, "wavenc", - plugin_init -}; + "Encode raw audio into WAV", + plugin_init, + VERSION, + GST_LICENSE, + GST_COPYRIGHT, + GST_PACKAGE, + GST_ORIGIN +) diff --git a/gst/wavparse/gstwavparse.c b/gst/wavparse/gstwavparse.c index dee2d92c..02f0987c 100644 --- a/gst/wavparse/gstwavparse.c +++ b/gst/wavparse/gstwavparse.c @@ -26,6 +26,7 @@ #include <gstwavparse.h> +static void gst_wavparse_base_init (gpointer g_class); static void gst_wavparse_class_init (GstWavParseClass *klass); static void gst_wavparse_init (GstWavParse *wavparse); @@ -52,15 +53,12 @@ static gboolean gst_wavparse_srcpad_event (GstPad *pad, GstEvent *event); static void gst_wavparse_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec); /* elementfactory information */ -static GstElementDetails gst_wavparse_details = { +static GstElementDetails gst_wavparse_details = GST_ELEMENT_DETAILS ( ".wav parser", "Codec/Parser", - "LGPL", "Parse a .wav file into raw audio", - VERSION, - "Erik Walthinsen <omega@cse.ogi.edu>", - "(C) 1999", -}; + "Erik Walthinsen <omega@cse.ogi.edu>" +); GST_PAD_TEMPLATE_FACTORY (sink_template_factory, "wavparse_sink", @@ -138,7 +136,8 @@ gst_wavparse_get_type (void) if (!wavparse_type) { static const GTypeInfo wavparse_info = { - sizeof(GstWavParseClass), NULL, + sizeof(GstWavParseClass), + gst_wavparse_base_init, NULL, (GClassInitFunc) gst_wavparse_class_init, NULL, @@ -152,6 +151,18 @@ gst_wavparse_get_type (void) return wavparse_type; } + +static void +gst_wavparse_base_init (gpointer g_class) +{ + GstElementClass *element_class = GST_ELEMENT_CLASS (g_class); + + gst_element_class_set_details (element_class, &gst_wavparse_details); + + /* register src pads */ + gst_element_class_add_pad_template (element_class, GST_PAD_TEMPLATE_GET (sink_template_factory)); + gst_element_class_add_pad_template (element_class, GST_PAD_TEMPLATE_GET (src_template_factory)); +} static void gst_wavparse_class_init (GstWavParseClass *klass) { @@ -1100,32 +1111,24 @@ gst_wavparse_change_state (GstElement *element) } static gboolean -plugin_init (GModule *module, GstPlugin *plugin) +plugin_init (GstPlugin *plugin) { - GstElementFactory *factory; - if (!gst_library_load ("gstbytestream")) { return FALSE; } - /* create an elementfactory for the wavparse element */ - factory = gst_element_factory_new ("wavparse", GST_TYPE_WAVPARSE, - &gst_wavparse_details); - g_return_val_if_fail(factory != NULL, FALSE); - gst_element_factory_set_rank (factory, GST_ELEMENT_RANK_SECONDARY); - - /* register src pads */ - gst_element_factory_add_pad_template (factory, GST_PAD_TEMPLATE_GET (sink_template_factory)); - gst_element_factory_add_pad_template (factory, GST_PAD_TEMPLATE_GET (src_template_factory)); - - gst_plugin_add_feature (plugin, GST_PLUGIN_FEATURE (factory)); - - return TRUE; + return gst_element_register (plugin, "wavparse", GST_RANK_SECONDARY, GST_TYPE_WAVPARSE); } -GstPluginDesc plugin_desc = { +GST_PLUGIN_DEFINE ( GST_VERSION_MAJOR, GST_VERSION_MINOR, "wavparse", - plugin_init -}; + "Parse a .wav file into raw audio", + plugin_init, + VERSION, + GST_LICENSE, + GST_COPYRIGHT, + GST_PACKAGE, + GST_ORIGIN +) |