[rhythmbox/gstreamer-0.11: 5/12] fmradio: convert source element to GStreamer 0.11
- From: Jonathan Matthew <jmatthew src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [rhythmbox/gstreamer-0.11: 5/12] fmradio: convert source element to GStreamer 0.11
- Date: Mon, 27 Feb 2012 13:37:23 +0000 (UTC)
commit ef9316e3fabd6a74647ceda72a4836ca49b8887e
Author: Jonathan Matthew <jonathan d14n org>
Date: Mon Feb 27 23:02:25 2012 +1000
fmradio: convert source element to GStreamer 0.11
plugins/fmradio/rb-fm-radio-gst-src.c | 85 +++++++++++++--------------------
1 files changed, 34 insertions(+), 51 deletions(-)
---
diff --git a/plugins/fmradio/rb-fm-radio-gst-src.c b/plugins/fmradio/rb-fm-radio-gst-src.c
index f51b517..09d709c 100644
--- a/plugins/fmradio/rb-fm-radio-gst-src.c
+++ b/plugins/fmradio/rb-fm-radio-gst-src.c
@@ -61,43 +61,18 @@ static GstStaticPadTemplate srctemplate = GST_STATIC_PAD_TEMPLATE ("src",
GST_PAD_ALWAYS,
GST_STATIC_CAPS_ANY);
-static GstElementDetails rb_fm_radio_src_details =
-GST_ELEMENT_DETAILS ("RB Silence Source",
- "Source/File",
- "Outputs buffers of silence",
- "James Henstridge <james jamesh id au>");
-
GType rb_fm_radio_src_get_type (void);
static void rb_fm_radio_src_uri_handler_init (gpointer g_iface,
gpointer iface_data);
-static void
-_do_init (GType fmradio_src_type)
-{
- static const GInterfaceInfo urihandler_info = {
- rb_fm_radio_src_uri_handler_init,
- NULL,
- NULL
- };
-
- g_type_add_interface_static (fmradio_src_type, GST_TYPE_URI_HANDLER,
- &urihandler_info);
-}
-
-GST_BOILERPLATE_FULL (RBFMRadioSrc, rb_fm_radio_src,
- GstBin, GST_TYPE_BIN, _do_init);
-
-static void
-rb_fm_radio_src_base_init (gpointer g_class)
-{
- GstElementClass *element_class = GST_ELEMENT_CLASS (g_class);
- gst_element_class_add_pad_template (element_class,
- gst_static_pad_template_get (&srctemplate));
- gst_element_class_set_details (element_class, &rb_fm_radio_src_details);
-}
+G_DEFINE_TYPE_WITH_CODE (RBFMRadioSrc,
+ rb_fm_radio_src,
+ GST_TYPE_BIN,
+ G_IMPLEMENT_INTERFACE (GST_TYPE_URI_HANDLER,
+ rb_fm_radio_src_uri_handler_init));
static void
-rb_fm_radio_src_init (RBFMRadioSrc *src, RBFMRadioSrcClass *klass)
+rb_fm_radio_src_init (RBFMRadioSrc *src)
{
GstPad *pad;
@@ -130,43 +105,52 @@ rb_fm_radio_src_finalize (GObject *object)
if (src->audiotestsrc)
gst_object_unref (src->audiotestsrc);
- G_OBJECT_CLASS (parent_class)->finalize (object);
+ G_OBJECT_CLASS (rb_fm_radio_src_parent_class)->finalize (object);
}
static void
rb_fm_radio_src_class_init (RBFMRadioSrcClass *klass)
{
GObjectClass *object_class;
+ GstElementClass *element_class;
object_class = G_OBJECT_CLASS (klass);
object_class->finalize = rb_fm_radio_src_finalize;
+
+ element_class = GST_ELEMENT_CLASS (klass);
+ gst_element_class_add_pad_template (element_class,
+ gst_static_pad_template_get (&srctemplate));
+ gst_element_class_set_details_simple (element_class,
+ "RB Silence Source",
+ "Source/File",
+ "Outputs buffers of silence",
+ "James Henstridge <james jamesh id au>");
}
/* URI handler interface */
static guint
-rb_fm_radio_src_uri_get_type (void)
+rb_fm_radio_src_uri_get_type (GType type)
{
return GST_URI_SRC;
}
-static gchar **
-rb_fm_radio_src_uri_get_protocols (void)
+static const gchar *const *
+rb_fm_radio_src_uri_get_protocols (GType type)
{
- static gchar *protocols[] = {"xrbsilence", NULL};
+ static const gchar *protocols[] = {"xrbsilence", NULL};
return protocols;
}
-static const gchar *
+static gchar *
rb_fm_radio_src_uri_get_uri (GstURIHandler *handler)
{
- return "xrbsilence:///";
+ return g_strdup ("xrbsilence:///");
}
static gboolean
-rb_fm_radio_src_uri_set_uri (GstURIHandler *handler,
- const gchar *uri)
+rb_fm_radio_src_uri_set_uri (GstURIHandler *handler, const gchar *uri, GError **error)
{
if (g_str_has_prefix (uri, "xrbsilence://") == FALSE)
return FALSE;
@@ -175,8 +159,7 @@ rb_fm_radio_src_uri_set_uri (GstURIHandler *handler,
}
static void
-rb_fm_radio_src_uri_handler_init (gpointer g_iface,
- gpointer iface_data)
+rb_fm_radio_src_uri_handler_init (gpointer g_iface, gpointer iface_data)
{
GstURIHandlerInterface *iface = (GstURIHandlerInterface *) g_iface;
@@ -193,12 +176,12 @@ plugin_init (GstPlugin *plugin)
return ret;
}
-GST_PLUGIN_DEFINE_STATIC (GST_VERSION_MAJOR,
- GST_VERSION_MINOR,
- "rbsilencesrc",
- "element to output silence",
- plugin_init,
- VERSION,
- "GPL",
- PACKAGE,
- "");
+GST_PLUGIN_DEFINE (GST_VERSION_MAJOR,
+ GST_VERSION_MINOR,
+ "rbsilencesrc",
+ "element to output silence",
+ plugin_init,
+ VERSION,
+ "GPL",
+ PACKAGE,
+ "");
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]