summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Nauwelaerts <mark.nauwelaerts@collabora.co.uk>2009-05-03 14:28:51 +0200
committerMark Nauwelaerts <mark.nauwelaerts@collabora.co.uk>2009-05-03 14:46:59 +0200
commitc63fd7a12382cbf278812a1fd720097215448c23 (patch)
tree49278c0eb4931ccd021b15d400ec481cf44840a6
parent9bbacae78f5750825bd79ec332c0ff0105552c0f (diff)
downloadgst-plugins-bad-c63fd7a12382cbf278812a1fd720097215448c23.tar.gz
gst-plugins-bad-c63fd7a12382cbf278812a1fd720097215448c23.tar.bz2
gst-plugins-bad-c63fd7a12382cbf278812a1fd720097215448c23.zip
mms: extend BaseSrc query handling rather than overriding
-rw-r--r--ext/libmms/gstmms.c38
1 files changed, 9 insertions, 29 deletions
diff --git a/ext/libmms/gstmms.c b/ext/libmms/gstmms.c
index dc004e81..33a1a7d2 100644
--- a/ext/libmms/gstmms.c
+++ b/ext/libmms/gstmms.c
@@ -60,8 +60,7 @@ static void gst_mms_set_property (GObject * object, guint prop_id,
static void gst_mms_get_property (GObject * object, guint prop_id,
GValue * value, GParamSpec * pspec);
-static const GstQueryType *gst_mms_get_query_types (GstPad * pad);
-static gboolean gst_mms_src_query (GstPad * pad, GstQuery * query);
+static gboolean gst_mms_query (GstBaseSrc * src, GstQuery * query);
static gboolean gst_mms_start (GstBaseSrc * bsrc);
static gboolean gst_mms_stop (GstBaseSrc * bsrc);
@@ -138,6 +137,7 @@ gst_mms_class_init (GstMMSClass * klass)
gstbasesrc_class->prepare_seek_segment =
GST_DEBUG_FUNCPTR (gst_mms_prepare_seek_segment);
gstbasesrc_class->do_seek = GST_DEBUG_FUNCPTR (gst_mms_do_seek);
+ gstbasesrc_class->query = GST_DEBUG_FUNCPTR (gst_mms_query);
}
/* initialize the new element
@@ -148,11 +148,6 @@ gst_mms_class_init (GstMMSClass * klass)
static void
gst_mms_init (GstMMS * mmssrc, GstMMSClass * g_class)
{
- gst_pad_set_query_function (GST_BASE_SRC (mmssrc)->srcpad,
- GST_DEBUG_FUNCPTR (gst_mms_src_query));
- gst_pad_set_query_type_function (GST_BASE_SRC (mmssrc)->srcpad,
- GST_DEBUG_FUNCPTR (gst_mms_get_query_types));
-
mmssrc->uri_name = NULL;
mmssrc->current_connection_uri_name = NULL;
mmssrc->connection = NULL;
@@ -186,27 +181,12 @@ gst_mms_finalize (GObject * gobject)
}
-/*
- * location querying and so on.
- */
-
-static const GstQueryType *
-gst_mms_get_query_types (GstPad * pad)
-{
- static const GstQueryType types[] = {
- GST_QUERY_POSITION,
- GST_QUERY_DURATION,
- 0
- };
-
- return types;
-}
-
+/* FIXME operating in TIME rather than BYTES could remove this altogether
+ * and be more convenient elsewhere */
static gboolean
-gst_mms_src_query (GstPad * pad, GstQuery * query)
+gst_mms_query (GstBaseSrc * src, GstQuery * query)
{
-
- GstMMS *mmssrc = GST_MMS (gst_pad_get_parent (pad));
+ GstMMS *mmssrc = GST_MMS (src);
gboolean res = TRUE;
GstFormat format;
gint64 value;
@@ -241,13 +221,13 @@ gst_mms_src_query (GstPad * pad, GstQuery * query)
}
break;
default:
- res = FALSE;
+ /* chain to parent */
+ res =
+ GST_BASE_SRC_CLASS (parent_class)->query (GST_BASE_SRC (src), query);
break;
}
- gst_object_unref (mmssrc);
return res;
-
}