summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--ext/libmms/gstmms.c24
2 files changed, 28 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 65eac224..7b3fe970 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2006-01-25 Edgard Lima <edgard.lima@indt.org.br>
+
+ * ext/libmms/gstmms.c: (gst_mms_finalize), (gst_mms_set_property),
+ (gst_mms_get_property), (gst_mms_src_query), (gst_mms_class_init):
+ Finalize method has been created and others small changes.
+
2006-01-24 Tim-Philipp Müller <tim at centricular dot net>
* ext/musepack/gstmusepackdec.c: (gst_musepackdec_base_init),
diff --git a/ext/libmms/gstmms.c b/ext/libmms/gstmms.c
index 13a0b01b..5985ea40 100644
--- a/ext/libmms/gstmms.c
+++ b/ext/libmms/gstmms.c
@@ -54,6 +54,7 @@ static GstStaticPadTemplate src_factory = GST_STATIC_PAD_TEMPLATE ("src",
static void gst_mms_class_init (GstMMSClass * klass);
static void gst_mms_base_init (gpointer g_class);
static void gst_mms_init (GstMMS * mmssrc, GstMMSClass * g_class);
+static void gst_mms_finalize (GObject * gobject);
static void gst_mms_uri_handler_init (gpointer g_iface, gpointer iface_data);
@@ -119,6 +120,7 @@ gst_mms_class_init (GstMMSClass * klass)
gobject_class->set_property = gst_mms_set_property;
gobject_class->get_property = gst_mms_get_property;
+ gobject_class->finalize = gst_mms_finalize;
g_object_class_install_property (gobject_class, ARG_LOCATION,
g_param_spec_string ("location", "location",
@@ -156,6 +158,20 @@ gst_mms_init (GstMMS * mmssrc, GstMMSClass * g_class)
mmssrc->blocksize = 2048;
}
+static void
+gst_mms_finalize (GObject * gobject)
+{
+ GstMMS *mmssrc = GST_MMS (gobject);
+
+ gst_mms_stop (mmssrc);
+
+ if (mmssrc->uri_name) {
+ g_free (mmssrc->uri_name);
+ mmssrc->uri_name = NULL;
+ }
+
+}
+
/*
* location querying and so on.
*/
@@ -236,7 +252,6 @@ gst_mms_create (GstPushSrc * psrc, GstBuffer ** buf)
gint64 query_res;
GstQuery *query;
- *buf = NULL;
mmssrc = GST_MMS (psrc);
*buf = gst_buffer_new_and_alloc (mmssrc->blocksize);
@@ -360,6 +375,10 @@ gst_mms_set_property (GObject * object, guint prop_id,
switch (prop_id) {
case ARG_LOCATION:
+ if (mmssrc->uri_name) {
+ g_free (mmssrc->uri_name);
+ mmssrc->uri_name = NULL;
+ }
mmssrc->uri_name = g_value_dup_string (value);
break;
case ARG_BLOCKSIZE:
@@ -381,7 +400,8 @@ gst_mms_get_property (GObject * object, guint prop_id,
switch (prop_id) {
case ARG_LOCATION:
- g_value_set_string (value, mmssrc->uri_name);
+ if (mmssrc->uri_name)
+ g_value_set_string (value, mmssrc->uri_name);
break;
case ARG_BLOCKSIZE:
g_value_set_int (value, mmssrc->blocksize);