mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-17 12:55:53 +00:00
docs: basic-tutorial-5: Don't unref floating reference
The `videosink` refernce in main() is a floating one, so it should not be unref'ed (the playbin practically takes ownership of it). This prevents a "gst_object_unref: assertion '((GObject *) object)->ref_count > 0' failed" at runtime. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6883>
This commit is contained in:
parent
85fa81c7c8
commit
2f03afd8ba
1 changed files with 8 additions and 4 deletions
|
@ -341,7 +341,7 @@ tutorial_main (int argc, char *argv[])
|
||||||
* GStreamer will render the video at and we can add to our UI.
|
* GStreamer will render the video at and we can add to our UI.
|
||||||
* Try to create the OpenGL version of the video sink, and fallback if that fails */
|
* Try to create the OpenGL version of the video sink, and fallback if that fails */
|
||||||
if (gtkglsink != NULL && videosink != NULL) {
|
if (gtkglsink != NULL && videosink != NULL) {
|
||||||
g_print ("Successfully created GTK GL Sink");
|
g_print ("Successfully created GTK GL Sink\n");
|
||||||
|
|
||||||
g_object_set (videosink, "sink", gtkglsink, NULL);
|
g_object_set (videosink, "sink", gtkglsink, NULL);
|
||||||
|
|
||||||
|
@ -349,6 +349,11 @@ tutorial_main (int argc, char *argv[])
|
||||||
* So we get it and use it later to add it to our gui. */
|
* So we get it and use it later to add it to our gui. */
|
||||||
g_object_get (gtkglsink, "widget", &data.sink_widget, NULL);
|
g_object_get (gtkglsink, "widget", &data.sink_widget, NULL);
|
||||||
} else {
|
} else {
|
||||||
|
if (gtkglsink != NULL)
|
||||||
|
gst_object_unref (gtkglsink);
|
||||||
|
if (videosink != NULL)
|
||||||
|
gst_object_unref (videosink);
|
||||||
|
|
||||||
g_printerr ("Could not create gtkglsink, falling back to gtksink.\n");
|
g_printerr ("Could not create gtkglsink, falling back to gtksink.\n");
|
||||||
|
|
||||||
videosink = gst_element_factory_make ("gtksink", "gtksink");
|
videosink = gst_element_factory_make ("gtksink", "gtksink");
|
||||||
|
@ -365,7 +370,8 @@ tutorial_main (int argc, char *argv[])
|
||||||
"https://gstreamer.freedesktop.org/data/media/sintel_trailer-480p.webm",
|
"https://gstreamer.freedesktop.org/data/media/sintel_trailer-480p.webm",
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
/* Set the video-sink */
|
/* Set the video-sink. The playbin assumes ownership of videosink, because
|
||||||
|
* that's still a floating reference. */
|
||||||
g_object_set (data.playbin, "video-sink", videosink, NULL);
|
g_object_set (data.playbin, "video-sink", videosink, NULL);
|
||||||
|
|
||||||
/* Connect to interesting signals in playbin */
|
/* Connect to interesting signals in playbin */
|
||||||
|
@ -396,7 +402,6 @@ tutorial_main (int argc, char *argv[])
|
||||||
if (ret == GST_STATE_CHANGE_FAILURE) {
|
if (ret == GST_STATE_CHANGE_FAILURE) {
|
||||||
g_printerr ("Unable to set the pipeline to the playing state.\n");
|
g_printerr ("Unable to set the pipeline to the playing state.\n");
|
||||||
gst_object_unref (data.playbin);
|
gst_object_unref (data.playbin);
|
||||||
gst_object_unref (videosink);
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -409,7 +414,6 @@ tutorial_main (int argc, char *argv[])
|
||||||
/* Free resources */
|
/* Free resources */
|
||||||
gst_element_set_state (data.playbin, GST_STATE_NULL);
|
gst_element_set_state (data.playbin, GST_STATE_NULL);
|
||||||
gst_object_unref (data.playbin);
|
gst_object_unref (data.playbin);
|
||||||
gst_object_unref (videosink);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue