glimagesink: Check if context creation failed before trying to use it

Otherwise we will cause assertions everywhere by passing NULL to functions
and eventually crash when dereferencing a NULL pointer.

https://bugzilla.gnome.org/show_bug.cgi?id=730069
This commit is contained in:
Sebastian Dröge 2014-05-19 12:25:51 +02:00 committed by Tim-Philipp Müller
parent 9fd7e34fee
commit 8b7d8a95ea

View file

@ -388,6 +388,8 @@ _ensure_gl_setup (GstGLImageSink * gl_sink)
GstGLWindow *window;
gl_sink->context = gst_gl_context_new (gl_sink->display);
if (!gl_sink->context)
goto context_creation_error;
window = gst_gl_context_get_window (gl_sink->context);
@ -421,6 +423,13 @@ _ensure_gl_setup (GstGLImageSink * gl_sink)
return TRUE;
context_creation_error:
{
GST_ELEMENT_ERROR (gl_sink, RESOURCE, NOT_FOUND,
("Failed to create GL context"), (NULL));
return FALSE;
}
context_error:
{
GST_ELEMENT_ERROR (gl_sink, RESOURCE, NOT_FOUND, ("%s", error->message),