/* GStreamer * * unit testing helper lib * * Copyright (C) 2006 Andy Wingo * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ #include "gstbufferstraw.h" static GCond *cond = NULL; static GMutex *lock = NULL; static GstBuffer *buf = NULL; static gulong id; /* called for every buffer. Waits until the global "buf" variable is unset, * then sets it to the buffer received, and signals. */ static gboolean buffer_probe (GstPad * pad, GstBuffer * buffer, gpointer unused) { g_mutex_lock (lock); while (buf != NULL) g_cond_wait (cond, lock); /* increase the refcount because we store it globally for others to use */ buf = gst_buffer_ref (buffer); g_cond_signal (cond); g_mutex_unlock (lock); return TRUE; } void gst_buffer_straw_start_pipeline (GstElement * bin, GstPad * pad) { GstStateChangeReturn ret; id = gst_pad_add_buffer_probe (pad, G_CALLBACK (buffer_probe), NULL); cond = g_cond_new (); lock = g_mutex_new (); ret = gst_element_set_state (bin, GST_STATE_PLAYING); fail_if (ret == GST_STATE_CHANGE_FAILURE, "Could not start test pipeline"); if (ret == GST_STATE_CHANGE_ASYNC) { ret = gst_element_get_state (bin, NULL, NULL, GST_CLOCK_TIME_NONE); fail_if (ret != GST_STATE_CHANGE_SUCCESS, "Could not start test pipeline"); } } /* waits until the probe receives a buffer. will catch every buffer */ GstBuffer * gst_buffer_straw_get_buffer (GstElement * bin, GstPad * pad) { GstBuffer *ret; g_mutex_lock (lock); while (buf == NULL) g_cond_wait (cond, lock); ret = buf; buf = NULL; g_cond_signal (cond); g_mutex_unlock (lock); return ret; } void gst_buffer_straw_stop_pipeline (GstElement * bin, GstPad * pad) { GstStateChangeReturn ret; g_mutex_lock (lock); if (buf) gst_buffer_unref (buf); buf = NULL; gst_pad_remove_buffer_probe (pad, (guint) id); id = 0; g_cond_signal (cond); g_mutex_unlock (lock); ret = gst_element_set_state (bin, GST_STATE_NULL); fail_if (ret == GST_STATE_CHANGE_FAILURE, "Could not stop test pipeline"); if (ret == GST_STATE_CHANGE_ASYNC) { ret = gst_element_get_state (bin, NULL, NULL, GST_CLOCK_TIME_NONE); fail_if (ret != GST_STATE_CHANGE_SUCCESS, "Could not stop test pipeline"); } g_mutex_lock (lock); if (buf) gst_buffer_unref (buf); buf = NULL; g_mutex_unlock (lock); g_mutex_free (lock); g_cond_free (cond); lock = NULL; cond = NULL; }