mirror of
https://github.com/brl/mutter.git
synced 2025-01-23 09:59:03 +00:00
Fix _cogl_texture_unsliced_quad when no texture coordinates are given
If no texture coordinates are given then texture_unsliced_quad tries to generate its own coordinates. However it also tries to read the texture coordinates to check if they are in [0.0,1.0] range so it will crash before it reaches that.
This commit is contained in:
parent
8dca5c73bc
commit
c18d945dc7
@ -2441,6 +2441,7 @@ _cogl_multitexture_unsliced_quad (float x_1,
|
||||
*/
|
||||
if ((tex->gl_target == GL_TEXTURE_RECTANGLE_ARB
|
||||
|| _cogl_texture_span_has_waste (tex, 0, 0))
|
||||
&& i < user_tex_coords_len / 4
|
||||
&& (in_tex_coords[0] < 0 || in_tex_coords[0] > 1.0
|
||||
|| in_tex_coords[1] < 0 || in_tex_coords[1] > 1.0
|
||||
|| in_tex_coords[2] < 0 || in_tex_coords[2] > 1.0
|
||||
@ -2497,6 +2498,8 @@ _cogl_multitexture_unsliced_quad (float x_1,
|
||||
else
|
||||
wrap_mode = GL_REPEAT;
|
||||
|
||||
memcpy (out_tex_coords, in_tex_coords, sizeof (GLfloat) * 4);
|
||||
|
||||
_cogl_texture_set_wrap_mode_parameter (tex, wrap_mode);
|
||||
}
|
||||
else
|
||||
@ -2514,13 +2517,13 @@ _cogl_multitexture_unsliced_quad (float x_1,
|
||||
y_span = &g_array_index (tex->slice_y_spans, CoglTexSliceSpan, 0);
|
||||
|
||||
out_tex_coords[0] =
|
||||
in_tex_coords[0] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[0] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[1] =
|
||||
in_tex_coords[1] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[1] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[2] =
|
||||
in_tex_coords[2] * (y_span->size - y_span->waste) / y_span->size;
|
||||
out_tex_coords[2] * (y_span->size - y_span->waste) / y_span->size;
|
||||
out_tex_coords[3] =
|
||||
in_tex_coords[3] * (y_span->size - y_span->waste) / y_span->size;
|
||||
out_tex_coords[3] * (y_span->size - y_span->waste) / y_span->size;
|
||||
|
||||
/* Denormalize texture coordinates for rectangle textures */
|
||||
if (tex->gl_target == GL_TEXTURE_RECTANGLE_ARB)
|
||||
|
@ -2556,6 +2556,7 @@ _cogl_multitexture_unsliced_quad (float x1,
|
||||
* case.
|
||||
*/
|
||||
if (_cogl_texture_span_has_waste (tex, 0, 0)
|
||||
&& i < user_tex_coords_len / 4
|
||||
&& (in_tex_coords[0] < 0 || in_tex_coords[0] > 1.0
|
||||
|| in_tex_coords[1] < 0 || in_tex_coords[1] > 1.0
|
||||
|| in_tex_coords[2] < 0 || in_tex_coords[2] > 1.0
|
||||
@ -2612,6 +2613,8 @@ _cogl_multitexture_unsliced_quad (float x1,
|
||||
else
|
||||
wrap_mode = GL_REPEAT;
|
||||
|
||||
memcpy (out_tex_coords, in_tex_coords, sizeof (GLfloat) * 4);
|
||||
|
||||
_cogl_texture_set_wrap_mode_parameter (tex, wrap_mode);
|
||||
}
|
||||
else
|
||||
@ -2629,13 +2632,13 @@ _cogl_multitexture_unsliced_quad (float x1,
|
||||
y_span = &g_array_index (tex->slice_y_spans, CoglTexSliceSpan, 0);
|
||||
|
||||
out_tex_coords[0] =
|
||||
in_tex_coords[0] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[0] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[1] =
|
||||
in_tex_coords[1] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[1] * (x_span->size - x_span->waste) / x_span->size;
|
||||
out_tex_coords[2] =
|
||||
in_tex_coords[2] * (y_span->size - y_span->waste) / y_span->size;
|
||||
out_tex_coords[2] * (y_span->size - y_span->waste) / y_span->size;
|
||||
out_tex_coords[3] =
|
||||
in_tex_coords[3] * (y_span->size - y_span->waste) / y_span->size;
|
||||
out_tex_coords[3] * (y_span->size - y_span->waste) / y_span->size;
|
||||
}
|
||||
|
||||
_cogl_journal_log_quad (x1,
|
||||
|
Loading…
x
Reference in New Issue
Block a user