* clutter/cogl/gl/cogl.c (error_string):
* clutter/cogl/gles/cogl.c (error_string): Rename to _cogl_error_string and remove the static scoping so that it can be called in cogl-texture etc. * clutter/cogl/gl/cogl-texture.c (cogl_texture_new_from_foreign): * clutter/cogl/gles/cogl-texture.c (cogl_texture_new_from_foreign): GE(*) can't be used to wrap around calls that use the return value. * clutter/cogl/gl/cogl-texture.c (_cogl_texture_quad_sw) (_cogl_texture_quad_hw, cogl_texture_polygon): Remove GE(*) wrapper around calls in the middle of a glBegin/glEnd pair which otherwise always generate an error because glGetError can only be called outside of the pair. * clutter/cogl/gl/cogl-internal.h: Include stdio.h when definig COGL_DEBUG and declare a prototype for _cogl_error_string. * clutter/cogl/gles/cogl-internal.h: Match GE(*) macro to GL version.
This commit is contained in:
parent
091c79b9ae
commit
eccd9399e5
6 changed files with 57 additions and 42 deletions
|
@ -29,18 +29,26 @@
|
|||
#define COGL_DEBUG 0
|
||||
|
||||
#if COGL_DEBUG
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
const char *_cogl_error_string(GLenum errorCode);
|
||||
|
||||
#define GE(x...) G_STMT_START { \
|
||||
GLenum err; \
|
||||
(x); \
|
||||
while ((err = glGetError()) != GL_NO_ERROR) { \
|
||||
fprintf(stderr, "glError: %s caught at %s:%u\n", \
|
||||
(char *)error_string(err), \
|
||||
__FILE__, __LINE__); \
|
||||
(char *)_cogl_error_string(err), \
|
||||
__FILE__, __LINE__); \
|
||||
} \
|
||||
} G_STMT_END
|
||||
#else
|
||||
|
||||
#else /* COGL_DEBUG */
|
||||
|
||||
#define GE(x) (x);
|
||||
#endif
|
||||
|
||||
#endif /* COGL_DEBUG */
|
||||
|
||||
#define COGL_ENABLE_BLEND (1<<1)
|
||||
#define COGL_ENABLE_TEXTURE_2D (1<<2)
|
||||
|
|
|
@ -1235,7 +1235,7 @@ cogl_texture_new_from_foreign (GLuint gl_handle,
|
|||
return COGL_INVALID_HANDLE;
|
||||
|
||||
/* Make sure it is a valid GL texture object */
|
||||
gl_istexture = GE( glIsTexture (gl_handle) );
|
||||
gl_istexture = glIsTexture (gl_handle);
|
||||
if (gl_istexture == GL_FALSE)
|
||||
return COGL_INVALID_HANDLE;
|
||||
|
||||
|
@ -1863,21 +1863,21 @@ _cogl_texture_quad_sw (CoglTexture *tex,
|
|||
#define CFX_F CLUTTER_FIXED_TO_FLOAT
|
||||
|
||||
/* Draw textured quad */
|
||||
GE( glBegin (GL_QUADS) );
|
||||
glBegin (GL_QUADS);
|
||||
|
||||
GE( glTexCoord2f (CFX_F(slice_tx1), CFX_F(slice_ty1)) );
|
||||
GE( glVertex2f (CFX_F(slice_qx1), CFX_F(slice_qy1)) );
|
||||
glTexCoord2f (CFX_F(slice_tx1), CFX_F(slice_ty1));
|
||||
glVertex2f (CFX_F(slice_qx1), CFX_F(slice_qy1));
|
||||
|
||||
GE( glTexCoord2f (CFX_F(slice_tx2), CFX_F(slice_ty1)) );
|
||||
GE( glVertex2f (CFX_F(slice_qx2), CFX_F(slice_qy1)) );
|
||||
glTexCoord2f (CFX_F(slice_tx2), CFX_F(slice_ty1));
|
||||
glVertex2f (CFX_F(slice_qx2), CFX_F(slice_qy1));
|
||||
|
||||
GE( glTexCoord2f (CFX_F(slice_tx2), CFX_F(slice_ty2)) );
|
||||
GE( glVertex2f (CFX_F(slice_qx2), CFX_F(slice_qy2)) );
|
||||
glTexCoord2f (CFX_F(slice_tx2), CFX_F(slice_ty2));
|
||||
glVertex2f (CFX_F(slice_qx2), CFX_F(slice_qy2));
|
||||
|
||||
GE( glTexCoord2f (CFX_F(slice_tx1), CFX_F(slice_ty2)) );
|
||||
GE( glVertex2f (CFX_F(slice_qx1), CFX_F(slice_qy2)) );
|
||||
glTexCoord2f (CFX_F(slice_tx1), CFX_F(slice_ty2));
|
||||
glVertex2f (CFX_F(slice_qx1), CFX_F(slice_qy2));
|
||||
|
||||
glEnd ();
|
||||
GE( glEnd () );
|
||||
|
||||
#undef CFX_F
|
||||
}
|
||||
|
@ -1946,21 +1946,21 @@ _cogl_texture_quad_hw (CoglTexture *tex,
|
|||
#define CFX_F(x) CLUTTER_FIXED_TO_FLOAT(x)
|
||||
|
||||
/* Draw textured quad */
|
||||
GE( glBegin (GL_QUADS) );
|
||||
glBegin (GL_QUADS);
|
||||
|
||||
GE( glTexCoord2f (CFX_F(tx1), CFX_F(ty1)) );
|
||||
GE( glVertex2f (CFX_F(x1), CFX_F(y1)) );
|
||||
glTexCoord2f (CFX_F(tx1), CFX_F(ty1));
|
||||
glVertex2f (CFX_F(x1), CFX_F(y1));
|
||||
|
||||
GE( glTexCoord2f (CFX_F(tx2), CFX_F(ty1)) );
|
||||
GE( glVertex2f (CFX_F(x2), CFX_F(y1)) );
|
||||
glTexCoord2f (CFX_F(tx2), CFX_F(ty1));
|
||||
glVertex2f (CFX_F(x2), CFX_F(y1));
|
||||
|
||||
GE( glTexCoord2f (CFX_F(tx2), CFX_F(ty2)) );
|
||||
GE( glVertex2f (CFX_F(x2), CFX_F(y2)) );
|
||||
glTexCoord2f (CFX_F(tx2), CFX_F(ty2));
|
||||
glVertex2f (CFX_F(x2), CFX_F(y2));
|
||||
|
||||
GE( glTexCoord2f (CFX_F(tx1), CFX_F(ty2)) );
|
||||
GE( glVertex2f (CFX_F(x1), CFX_F(y2)) );
|
||||
glTexCoord2f (CFX_F(tx1), CFX_F(ty2));
|
||||
glVertex2f (CFX_F(x1), CFX_F(y2));
|
||||
|
||||
glEnd ();
|
||||
GE( glEnd () );
|
||||
|
||||
#undef CFX_F
|
||||
}
|
||||
|
@ -2122,7 +2122,7 @@ cogl_texture_polygon (CoglHandle handle,
|
|||
|
||||
GE( glBindTexture (tex->gl_target, gl_handle) );
|
||||
|
||||
GE( glBegin (GL_TRIANGLE_FAN) );
|
||||
glBegin (GL_TRIANGLE_FAN);
|
||||
|
||||
for (vnum = 0; vnum < n_vertices; vnum++)
|
||||
{
|
||||
|
@ -2146,11 +2146,11 @@ cogl_texture_polygon (CoglHandle handle,
|
|||
ty *= y_span->size;
|
||||
}
|
||||
|
||||
GE( glTexCoord2f (tx, ty) );
|
||||
glTexCoord2f (tx, ty);
|
||||
|
||||
GE( glVertex3f (CLUTTER_FIXED_TO_FLOAT (vertices[vnum].x),
|
||||
CLUTTER_FIXED_TO_FLOAT (vertices[vnum].y),
|
||||
CLUTTER_FIXED_TO_FLOAT (vertices[vnum].z)) );
|
||||
glVertex3f (CLUTTER_FIXED_TO_FLOAT (vertices[vnum].x),
|
||||
CLUTTER_FIXED_TO_FLOAT (vertices[vnum].y),
|
||||
CLUTTER_FIXED_TO_FLOAT (vertices[vnum].z));
|
||||
}
|
||||
|
||||
GE( glEnd () );
|
||||
|
|
|
@ -66,8 +66,8 @@ static const struct token_string Errors[] = {
|
|||
{ ~0, NULL }
|
||||
};
|
||||
|
||||
static const char*
|
||||
error_string(GLenum errorCode)
|
||||
const char*
|
||||
_cogl_error_string(GLenum errorCode)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; Errors[i].String; i++) {
|
||||
|
|
|
@ -29,19 +29,26 @@
|
|||
#define COGL_DEBUG 0
|
||||
|
||||
#if COGL_DEBUG
|
||||
#define GE(x...) { \
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
const char *_cogl_error_string(GLenum errorCode);
|
||||
|
||||
#define GE(x...) G_STMT_START { \
|
||||
GLenum err; \
|
||||
(x); \
|
||||
fprintf(stderr, "%s\n", #x); \
|
||||
while ((err = glGetError()) != GL_NO_ERROR) { \
|
||||
fprintf(stderr, "glError: %s caught at %s:%u\n", \
|
||||
(char *)error_string(err), \
|
||||
__FILE__, __LINE__); \
|
||||
(char *)_cogl_error_string(err), \
|
||||
__FILE__, __LINE__); \
|
||||
} \
|
||||
}
|
||||
#else
|
||||
} G_STMT_END
|
||||
|
||||
#else /* COGL_DEBUG */
|
||||
|
||||
#define GE(x) (x);
|
||||
#endif
|
||||
|
||||
#endif /* COGL_DEBUG */
|
||||
|
||||
#define COGL_ENABLE_BLEND (1<<1)
|
||||
#define COGL_ENABLE_TEXTURE_2D (1<<2)
|
||||
|
|
|
@ -1248,7 +1248,7 @@ cogl_texture_new_from_foreign (GLuint gl_handle,
|
|||
return COGL_INVALID_HANDLE;
|
||||
|
||||
/* Make sure it is a valid GL texture object */
|
||||
gl_istexture = GE( glIsTexture (gl_handle) );
|
||||
gl_istexture = glIsTexture (gl_handle);
|
||||
if (gl_istexture == GL_FALSE)
|
||||
return COGL_INVALID_HANDLE;
|
||||
|
||||
|
|
|
@ -59,8 +59,8 @@ static const struct token_string Errors[] = {
|
|||
{ ~0, NULL }
|
||||
};
|
||||
|
||||
static const char*
|
||||
error_string(GLenum errorCode)
|
||||
const char*
|
||||
_cogl_error_string(GLenum errorCode)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; Errors[i].String; i++) {
|
||||
|
|
Loading…
Reference in a new issue