cogl-pipeline: Fix comparing the texture data state for NULL textures
When comparing the texture data for a pipeline layer it tries to get the GL texture handle out of the texture object. However it's valid for a layer to have a NULL texture object but in that case the code would just crash. This patch fixes it to compare the texture types when the texture object is NULL. Reviewed-by: Robert Bragg <robert@linux.intel.com>
This commit is contained in:
parent
b96e6900f5
commit
d2a35a1e22
@ -877,12 +877,25 @@ _cogl_pipeline_layer_texture_data_equal (CoglPipelineLayer *authority0,
|
|||||||
CoglPipelineLayer *authority1,
|
CoglPipelineLayer *authority1,
|
||||||
CoglPipelineEvalFlags flags)
|
CoglPipelineEvalFlags flags)
|
||||||
{
|
{
|
||||||
GLuint gl_handle0, gl_handle1;
|
if (authority0->texture == NULL)
|
||||||
|
{
|
||||||
|
if (authority1->texture == NULL)
|
||||||
|
return (_cogl_pipeline_layer_get_texture_type (authority0) ==
|
||||||
|
_cogl_pipeline_layer_get_texture_type (authority1));
|
||||||
|
else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
else if (authority1->texture == NULL)
|
||||||
|
return FALSE;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GLuint gl_handle0, gl_handle1;
|
||||||
|
|
||||||
cogl_texture_get_gl_texture (authority0->texture, &gl_handle0, NULL);
|
cogl_texture_get_gl_texture (authority0->texture, &gl_handle0, NULL);
|
||||||
cogl_texture_get_gl_texture (authority1->texture, &gl_handle1, NULL);
|
cogl_texture_get_gl_texture (authority1->texture, &gl_handle1, NULL);
|
||||||
|
|
||||||
return gl_handle0 == gl_handle1;
|
return gl_handle0 == gl_handle1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
|
Loading…
x
Reference in New Issue
Block a user