diff --git a/ChangeLog b/ChangeLog
index befe3cf8ad..b451477af1 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2005-05-19  David Schleef  <ds@schleef.org>
+
+	* gst/gstminiobject.c: (gst_value_set_mini_object),
+	(gst_value_take_mini_object), (gst_value_get_mini_object):
+	* gst/gstminiobject.h: Add GValue set/get functions.
+
 2005-05-19  Wim Taymans  <wim@fluendo.com>
 
 	* gst/gstbuffer.c: (gst_buffer_init), (gst_subbuffer_get_type),
diff --git a/gst/gstminiobject.c b/gst/gstminiobject.c
index 23cf591fb9..4dd8b2535f 100644
--- a/gst/gstminiobject.c
+++ b/gst/gstminiobject.c
@@ -270,6 +270,35 @@ gst_value_mini_object_lcopy (const GValue * value, guint n_collect_values,
   return NULL;
 }
 
+void
+gst_value_set_mini_object (GValue * value, GstMiniObject * mini_object)
+{
+  g_return_if_fail (GST_VALUE_HOLDS_MINI_OBJECT (value));
+  g_return_if_fail (mini_object == NULL || GST_IS_MINI_OBJECT (mini_object));
+
+  gst_mini_object_replace ((GstMiniObject **) & value->data[0].v_pointer,
+      mini_object);
+}
+
+void
+gst_value_take_mini_object (GValue * value, GstMiniObject * mini_object)
+{
+  g_return_if_fail (GST_VALUE_HOLDS_MINI_OBJECT (value));
+  g_return_if_fail (mini_object == NULL || GST_IS_MINI_OBJECT (mini_object));
+
+  gst_mini_object_replace ((GstMiniObject **) & value->data[0].v_pointer,
+      mini_object);
+  gst_mini_object_unref (mini_object);
+}
+
+GstMiniObject *
+gst_value_get_mini_object (const GValue * value)
+{
+  g_return_val_if_fail (GST_VALUE_HOLDS_MINI_OBJECT (value), NULL);
+
+  return value->data[0].v_pointer;
+}
+
 /* param spec */
 
 static GType gst_param_spec_mini_object_get_type (void);
diff --git a/gst/gstminiobject.h b/gst/gstminiobject.h
index c055c402fe..27766b0c25 100644
--- a/gst/gstminiobject.h
+++ b/gst/gstminiobject.h
@@ -46,6 +46,8 @@ typedef void (*GstMiniObjectFinalizeFunction) (GstMiniObject *);
 #define GST_MINI_OBJECT_FLAG_SET(obj,flag)           (GST_MINI_OBJECT_FLAGS (obj) |= (flag))
 #define GST_MINI_OBJECT_FLAG_UNSET(obj,flag)         (GST_MINI_OBJECT_FLAGS (obj) &= ~(flag))
 
+#define GST_VALUE_HOLDS_MINI_OBJECT(value)  (G_VALUE_HOLDS(value, GST_TYPE_MINI_OBJECT))
+
 typedef enum
 {
   GST_MINI_OBJECT_FLAG_READONLY = (1<<0),
@@ -86,6 +88,11 @@ void gst_mini_object_replace (GstMiniObject **olddata, GstMiniObject *newdata);
 GParamSpec * gst_param_spec_mini_object (const char *name, const char *nick,
     const char *blurb, GType object_type, GParamFlags flags);
 
+void gst_value_set_mini_object (GValue *value, GstMiniObject *mini_object);
+void gst_value_take_mini_object (GValue *value, GstMiniObject *mini_object);
+GstMiniObject * gst_value_get_mini_object (const GValue *value);
+
+
 G_END_DECLS
 
 #endif