audiosink, audiosrc: do the class_ref()s in the right class_init functions
authorTim-Philipp Müller <tim.muller@collabora.co.uk>
Tue, 16 Jun 2009 13:05:04 +0000 (14:05 +0100)
committerTim-Philipp Müller <tim.muller@collabora.co.uk>
Tue, 16 Jun 2009 13:14:26 +0000 (14:14 +0100)
Spotted by Philip Jägenstedt. Hopefully fixes #585970 for real.

gst-libs/gst/audio/gstaudiosink.c
gst-libs/gst/audio/gstaudiosrc.c

index 479267e..2d4bfe5 100644 (file)
@@ -191,10 +191,6 @@ gst_audioringbuffer_class_init (GstAudioRingBufferClass * klass)
   gstringbuffer_class->delay = GST_DEBUG_FUNCPTR (gst_audioringbuffer_delay);
   gstringbuffer_class->activate =
       GST_DEBUG_FUNCPTR (gst_audioringbuffer_activate);
-
-  /* ref class from a thread-safe context to work around missing bit of
-   * thread-safety in GObject */
-  g_type_class_ref (GST_TYPE_AUDIORING_BUFFER);
 }
 
 typedef guint (*WriteFunc) (GstAudioSink * sink, gpointer data, guint length);
@@ -596,6 +592,8 @@ gst_audio_sink_class_init (GstAudioSinkClass * klass)
 
   gstbaseaudiosink_class->create_ringbuffer =
       GST_DEBUG_FUNCPTR (gst_audio_sink_create_ringbuffer);
+
+  g_type_class_ref (GST_TYPE_AUDIORING_BUFFER);
 }
 
 static void
index ff183b8..6026734 100644 (file)
@@ -183,10 +183,6 @@ gst_audioringbuffer_class_init (GstAudioRingBufferClass * klass)
   gstringbuffer_class->stop = GST_DEBUG_FUNCPTR (gst_audioringbuffer_stop);
 
   gstringbuffer_class->delay = GST_DEBUG_FUNCPTR (gst_audioringbuffer_delay);
-
-  /* ref class from a thread-safe context to work around missing bit of
-   * thread-safety in GObject */
-  g_type_class_ref (GST_TYPE_AUDIORING_BUFFER);
 }
 
 typedef guint (*ReadFunc) (GstAudioSrc * src, gpointer data, guint length);
@@ -510,6 +506,8 @@ gst_audio_src_class_init (GstAudioSrcClass * klass)
 
   gstbaseaudiosrc_class->create_ringbuffer =
       GST_DEBUG_FUNCPTR (gst_audio_src_create_ringbuffer);
+
+  g_type_class_ref (GST_TYPE_AUDIORING_BUFFER);
 }
 
 static void