diff options
author | David Schleef <ds@schleef.org> | 2003-11-01 02:07:52 +0000 |
---|---|---|
committer | David Schleef <ds@schleef.org> | 2003-11-01 02:07:52 +0000 |
commit | 69277f05a703508a270048e6443afa37bdd67266 (patch) | |
tree | 7cc9b9f6d206a69e2964bd4cd3b30c38304d609b /gst/avi/gstavimux.c | |
parent | 36884b6d7f4dc9fa9bae8f9a8184a72b997a693e (diff) |
Merge plugins. Update to new plugin init code
Original commit message from CVS:
Merge plugins. Update to new plugin init code
Diffstat (limited to 'gst/avi/gstavimux.c')
-rw-r--r-- | gst/avi/gstavimux.c | 65 |
1 files changed, 23 insertions, 42 deletions
diff --git a/gst/avi/gstavimux.c b/gst/avi/gstavimux.c index a6e5d075..8c8a4eaf 100644 --- a/gst/avi/gstavimux.c +++ b/gst/avi/gstavimux.c @@ -44,19 +44,6 @@ #define LE_FROM_GUINT32 GUINT32_FROM_LE #endif -/* elementfactory information */ -static GstElementDetails -gst_avimux_details = -{ - "Avi multiplexer", - "Codec/Muxer", - "LGPL", - "Muxes audio and video into an avi stream", - VERSION, - "Ronald Bultje <rbultje@ronald.bitfreak.net>", - "(C) 2002", -}; - /* AviMux signals and args */ enum { /* FILL ME */ @@ -202,6 +189,7 @@ GST_PAD_TEMPLATE_FACTORY (audio_sink_factory, ) +static void gst_avimux_base_init (gpointer g_class); static void gst_avimux_class_init (GstAviMuxClass *klass); static void gst_avimux_init (GstAviMux *avimux); @@ -232,7 +220,7 @@ gst_avimux_get_type (void) if (!avimux_type) { static const GTypeInfo avimux_info = { sizeof(GstAviMuxClass), - NULL, + gst_avimux_base_init, NULL, (GClassInitFunc)gst_avimux_class_init, NULL, @@ -247,6 +235,27 @@ gst_avimux_get_type (void) } static void +gst_avimux_base_init (gpointer g_class) +{ + GstElementClass *element_class = GST_ELEMENT_CLASS (g_class); + static GstElementDetails gst_avimux_details = GST_ELEMENT_DETAILS ( + "Avi multiplexer", + "Codec/Muxer", + "Muxes audio and video into an avi stream", + "Ronald Bultje <rbultje@ronald.bitfreak.net>" + ); + + gst_element_class_add_pad_template (element_class, + GST_PAD_TEMPLATE_GET (src_factory)); + gst_element_class_add_pad_template (element_class, + GST_PAD_TEMPLATE_GET (audio_sink_factory)); + gst_element_class_add_pad_template (element_class, + GST_PAD_TEMPLATE_GET (video_sink_factory)); + + gst_element_class_set_details (element_class, &gst_avimux_details); +} + +static void gst_avimux_class_init (GstAviMuxClass *klass) { GObjectClass *gobject_class; @@ -1381,31 +1390,3 @@ gst_avimux_change_state (GstElement *element) return GST_STATE_SUCCESS; } -static gboolean -plugin_init (GModule *module, GstPlugin *plugin) -{ - GstElementFactory *factory; - - if (!gst_library_load("gstvideo")) - return FALSE; - - /* create an elementfactory for the avimux element */ - factory = gst_element_factory_new ("avimux", GST_TYPE_AVIMUX, - &gst_avimux_details); - g_return_val_if_fail (factory != NULL, FALSE); - - gst_element_factory_add_pad_template (factory, GST_PAD_TEMPLATE_GET (src_factory)); - gst_element_factory_add_pad_template (factory, GST_PAD_TEMPLATE_GET (audio_sink_factory)); - gst_element_factory_add_pad_template (factory, GST_PAD_TEMPLATE_GET (video_sink_factory)); - - gst_plugin_add_feature (plugin, GST_PLUGIN_FEATURE (factory)); - - return TRUE; -} - -GstPluginDesc plugin_desc = { - GST_VERSION_MAJOR, - GST_VERSION_MINOR, - "avimux", - plugin_init -}; |