mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 10:25:33 +00:00
gst/playback/: Make sure the video frame buffer we return to apps via the "frame" property always has caps set on it....
Original commit message from CVS: * gst/playback/gstplaybasebin.c: * gst/playback/gstplaybin.c: (handoff): Make sure the video frame buffer we return to apps via the "frame" property always has caps set on it. Modify _gst_gvalue_set_object() macro to handle NULL objects gracefully too.
This commit is contained in:
parent
7906b3c945
commit
f2e9c13e3f
3 changed files with 35 additions and 9 deletions
|
@ -1,3 +1,12 @@
|
||||||
|
2005-12-15 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
|
* gst/playback/gstplaybasebin.c:
|
||||||
|
* gst/playback/gstplaybin.c: (handoff):
|
||||||
|
Make sure the video frame buffer we return to apps via the
|
||||||
|
"frame" property always has caps set on it. Modify
|
||||||
|
_gst_gvalue_set_object() macro to handle NULL objects
|
||||||
|
gracefully too.
|
||||||
|
|
||||||
2005-12-14 Stefan Kost <ensonic@users.sf.net>
|
2005-12-14 Stefan Kost <ensonic@users.sf.net>
|
||||||
|
|
||||||
* gst/audiotestsrc/gstaudiotestsrc.c:
|
* gst/audiotestsrc/gstaudiotestsrc.c:
|
||||||
|
|
|
@ -40,9 +40,13 @@ GST_DEBUG_CATEGORY_STATIC (gst_play_base_bin_debug);
|
||||||
|
|
||||||
#ifndef GST_HAVE_GLIB_2_8
|
#ifndef GST_HAVE_GLIB_2_8
|
||||||
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
||||||
gst_object_ref (obj); \
|
if (obj != NULL) { \
|
||||||
g_value_set_object (gvalue, obj); \
|
gst_object_ref (obj); \
|
||||||
g_object_unref (obj);
|
g_value_set_object (gvalue, obj); \
|
||||||
|
g_object_unref (obj); \
|
||||||
|
} else { \
|
||||||
|
g_value_set_object (gvalue, NULL); \
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
||||||
g_value_set_object (gvalue, obj);
|
g_value_set_object (gvalue, obj);
|
||||||
|
|
|
@ -41,9 +41,13 @@ GST_DEBUG_CATEGORY_STATIC (gst_play_bin_debug);
|
||||||
|
|
||||||
#ifndef GST_HAVE_GLIB_2_8
|
#ifndef GST_HAVE_GLIB_2_8
|
||||||
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
||||||
gst_object_ref (obj); \
|
if (obj != NULL) { \
|
||||||
g_value_set_object (gvalue, obj); \
|
gst_object_ref (obj); \
|
||||||
g_object_unref (obj);
|
g_value_set_object (gvalue, obj); \
|
||||||
|
g_object_unref (obj); \
|
||||||
|
} else { \
|
||||||
|
g_value_set_object (gvalue, NULL); \
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
#define _gst_gvalue_set_gstobject(gvalue,obj) \
|
||||||
g_value_set_object (gvalue, obj);
|
g_value_set_object (gvalue, obj);
|
||||||
|
@ -368,10 +372,19 @@ handoff (GstElement * identity, GstBuffer * frame, gpointer data)
|
||||||
{
|
{
|
||||||
GstPlayBin *play_bin = GST_PLAY_BIN (data);
|
GstPlayBin *play_bin = GST_PLAY_BIN (data);
|
||||||
|
|
||||||
if (play_bin->frame) {
|
gst_mini_object_replace ((GstMiniObject **) & play_bin->frame,
|
||||||
gst_buffer_unref (play_bin->frame);
|
GST_MINI_OBJECT_CAST (frame));
|
||||||
|
|
||||||
|
/* applications need to know the buffer caps,
|
||||||
|
* make sure they are always set on the frame */
|
||||||
|
if (GST_BUFFER_CAPS (play_bin->frame) == NULL) {
|
||||||
|
GstPad *pad;
|
||||||
|
|
||||||
|
if ((pad = gst_element_get_pad (identity, "sink"))) {
|
||||||
|
gst_buffer_set_caps (play_bin->frame, GST_PAD_CAPS (pad));
|
||||||
|
gst_object_unref (pad);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
play_bin->frame = gst_buffer_ref (frame);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* make the element (bin) that contains the elements needed to perform
|
/* make the element (bin) that contains the elements needed to perform
|
||||||
|
|
Loading…
Reference in a new issue