summaryrefslogtreecommitdiffstats
path: root/sys/osxvideo/osxvideosink.m
diff options
context:
space:
mode:
authorEdward Hervey <bilboed@bilboed.com>2007-02-27 11:30:19 +0000
committerEdward Hervey <bilboed@bilboed.com>2007-02-27 11:30:19 +0000
commitbd7b6fc51c1ba10d77780cc5084d830448592b0e (patch)
tree006a2950d3df631a42481fdcb911d7e8b54d6837 /sys/osxvideo/osxvideosink.m
parent5fd12e6daebda436c405f9c7d3cb7561b492e9ab (diff)
downloadgst-plugins-bad-bd7b6fc51c1ba10d77780cc5084d830448592b0e.tar.gz
gst-plugins-bad-bd7b6fc51c1ba10d77780cc5084d830448592b0e.tar.bz2
gst-plugins-bad-bd7b6fc51c1ba10d77780cc5084d830448592b0e.zip
sys/osxvideo/: Disable the cocoa event loop since it's a huge memory leak. Should only matter if the sink isn't used ...
Original commit message from CVS: * sys/osxvideo/cocoawindow.h: * sys/osxvideo/cocoawindow.m: * sys/osxvideo/osxvideosink.h: * sys/osxvideo/osxvideosink.m: Disable the cocoa event loop since it's a huge memory leak. Should only matter if the sink isn't used within an NSApp (which has already got a coca event loop). Remove all unused code.
Diffstat (limited to 'sys/osxvideo/osxvideosink.m')
-rw-r--r--sys/osxvideo/osxvideosink.m18
1 files changed, 2 insertions, 16 deletions
diff --git a/sys/osxvideo/osxvideosink.m b/sys/osxvideo/osxvideosink.m
index f3f09975..43b514fc 100644
--- a/sys/osxvideo/osxvideosink.m
+++ b/sys/osxvideo/osxvideosink.m
@@ -60,6 +60,7 @@ enum
static GstVideoSinkClass *parent_class = NULL;
/* cocoa event loop - needed if not run in own app */
+/* FIXME : currently disabled since a huge memory leak happens if it is run. */
gpointer
cocoa_event_loop (GstOSXVideoSink * vsink)
{
@@ -108,7 +109,7 @@ gst_osx_video_sink_osxwindow_new (GstOSXVideoSink * osxvideosink, gint width,
[pool release];
/* Start Cocoa event loop */
- g_thread_create ((GThreadFunc) cocoa_event_loop, osxvideosink, FALSE, NULL);
+// g_thread_create ((GThreadFunc) cocoa_event_loop, osxvideosink, FALSE, NULL);
} else {
/* Needs to be embedded */
@@ -147,7 +148,6 @@ gst_osx_video_sink_osxwindow_resize (GstOSXVideoSink * osxvideosink,
g_return_if_fail (osxwindow != NULL);
g_return_if_fail (GST_IS_OSX_VIDEO_SINK (osxvideosink));
- //SizeWindow (osxwindow->win, width, height, 1);
osxwindow->width = width;
osxwindow->height = height;
@@ -342,18 +342,6 @@ gst_osx_video_sink_get_property (GObject * object, guint prop_id,
}
static void
-gst_osx_video_sink_dispose (GObject * object)
-{
- GstOSXVideoSink *osxvideosink;
-
- osxvideosink = GST_OSX_VIDEO_SINK (object);
-
- g_mutex_free (osxvideosink->pool_lock);
-
- G_OBJECT_CLASS (parent_class)->dispose (object);
-}
-
-static void
gst_osx_video_sink_init (GstOSXVideoSink * osxvideosink)
{
@@ -396,11 +384,9 @@ gst_osx_video_sink_class_init (GstOSXVideoSinkClass * klass)
parent_class = g_type_class_ref (GST_TYPE_VIDEO_SINK);
- gobject_class->dispose = gst_osx_video_sink_dispose;
gobject_class->set_property = gst_osx_video_sink_set_property;
gobject_class->get_property = gst_osx_video_sink_get_property;
- //gstbasesink_class->get_times = gst_osx_video_sink_get_times;
gstbasesink_class->set_caps = gst_osx_video_sink_setcaps;
gstbasesink_class->preroll = gst_osx_video_sink_show_frame;
gstbasesink_class->render = gst_osx_video_sink_show_frame;