mirror of
https://github.com/brl/mutter.git
synced 2025-01-05 09:12:14 +00:00
2007-05-01 Matthew Allum <mallum@openedhand.com>
* clutter/clutter-rectangle.c: Comment out color match check for now as appears to be causing borders to always get pained. * clutter/clutter-texture.h: Add some format defines (unused as yet) * clutter/cogl/gles/cogl.c: * clutter/egl/clutter-stage-egl.c: * configure.ac: Various OpenGL ES backend related fixes and tweaks.
This commit is contained in:
parent
e89cf12d18
commit
45c8796631
16
ChangeLog
16
ChangeLog
@ -1,3 +1,17 @@
|
|||||||
|
2007-05-01 Matthew Allum <mallum@openedhand.com>
|
||||||
|
|
||||||
|
* clutter/clutter-rectangle.c:
|
||||||
|
Comment out color match check for now as appears to be causing
|
||||||
|
borders to always get pained.
|
||||||
|
|
||||||
|
* clutter/clutter-texture.h:
|
||||||
|
Add some format defines (unused as yet)
|
||||||
|
|
||||||
|
* clutter/cogl/gles/cogl.c:
|
||||||
|
* clutter/egl/clutter-stage-egl.c:
|
||||||
|
* configure.ac:
|
||||||
|
Various OpenGL ES backend related fixes and tweaks.
|
||||||
|
|
||||||
2007-04-30 Tomas Frydrych <tf@openedhand.com>
|
2007-04-30 Tomas Frydrych <tf@openedhand.com>
|
||||||
|
|
||||||
* clutter/clutter-fixed.c (clutter_sini):
|
* clutter/clutter-fixed.c (clutter_sini):
|
||||||
@ -18,8 +32,6 @@
|
|||||||
Added --path commandline option to behave to choose different
|
Added --path commandline option to behave to choose different
|
||||||
path types (poly, ellipse, bspline) and dropped bspline example.
|
path types (poly, ellipse, bspline) and dropped bspline example.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
2007-04-28 Matthew Allum <mallum@openedhand.com>
|
2007-04-28 Matthew Allum <mallum@openedhand.com>
|
||||||
|
|
||||||
* clutter/Makefile.am:
|
* clutter/Makefile.am:
|
||||||
|
@ -384,10 +384,13 @@ clutter_rectangle_set_color (ClutterRectangle *rectangle,
|
|||||||
clutter_actor_set_opacity (CLUTTER_ACTOR (rectangle),
|
clutter_actor_set_opacity (CLUTTER_ACTOR (rectangle),
|
||||||
priv->color.alpha);
|
priv->color.alpha);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/* FIXME - appears to be causing border to always get drawn */
|
||||||
if (clutter_color_equal (&priv->color, &priv->border_color))
|
if (clutter_color_equal (&priv->color, &priv->border_color))
|
||||||
priv->has_border = FALSE;
|
priv->has_border = FALSE;
|
||||||
else
|
else
|
||||||
priv->has_border = TRUE;
|
priv->has_border = TRUE;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (rectangle)))
|
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (rectangle)))
|
||||||
clutter_actor_queue_redraw (CLUTTER_ACTOR (rectangle));
|
clutter_actor_queue_redraw (CLUTTER_ACTOR (rectangle));
|
||||||
|
@ -31,6 +31,13 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
#define CLUTTER_TEXTURE_FORMAT_RGB 1
|
||||||
|
#define CLUTTER_TEXTURE_FORMAT_RGBA 2
|
||||||
|
#define CLUTTER_TEXTURE_FORMAT_BGR 3
|
||||||
|
#define CLUTTER_TEXTURE_FORMAT_BGRA 4
|
||||||
|
#define CLUTTER_TEXTURE_FORMAT_YUV 5
|
||||||
|
#define CLUTTER_TEXTURE_FORMAT_YUV2 6
|
||||||
|
|
||||||
#define CLUTTER_TYPE_TEXTURE (clutter_texture_get_type ())
|
#define CLUTTER_TYPE_TEXTURE (clutter_texture_get_type ())
|
||||||
#define CLUTTER_TEXTURE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_TEXTURE, ClutterTexture))
|
#define CLUTTER_TEXTURE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), CLUTTER_TYPE_TEXTURE, ClutterTexture))
|
||||||
#define CLUTTER_TEXTURE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), CLUTTER_TYPE_TEXTURE, ClutterTextureClass))
|
#define CLUTTER_TEXTURE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), CLUTTER_TYPE_TEXTURE, ClutterTextureClass))
|
||||||
|
@ -37,6 +37,8 @@
|
|||||||
|
|
||||||
static gulong __enable_flags = 0;
|
static gulong __enable_flags = 0;
|
||||||
|
|
||||||
|
#define COGL_DEBUG 1
|
||||||
|
|
||||||
#if COGL_DEBUG
|
#if COGL_DEBUG
|
||||||
struct token_string
|
struct token_string
|
||||||
{
|
{
|
||||||
@ -74,6 +76,7 @@ error_string(GLenum errorCode)
|
|||||||
#define GE(x...) { \
|
#define GE(x...) { \
|
||||||
GLenum err; \
|
GLenum err; \
|
||||||
(x); \
|
(x); \
|
||||||
|
fprintf(stderr, "%s\n", #x); \
|
||||||
while ((err = glGetError()) != GL_NO_ERROR) { \
|
while ((err = glGetError()) != GL_NO_ERROR) { \
|
||||||
fprintf(stderr, "glError: %s caught at %s:%u\n", \
|
fprintf(stderr, "glError: %s caught at %s:%u\n", \
|
||||||
(char *)error_string(err), \
|
(char *)error_string(err), \
|
||||||
@ -99,6 +102,10 @@ cogl_check_extension (const gchar *name, const gchar *ext)
|
|||||||
void
|
void
|
||||||
cogl_paint_init (ClutterColor *color)
|
cogl_paint_init (ClutterColor *color)
|
||||||
{
|
{
|
||||||
|
#if COGL_DEBUG
|
||||||
|
fprintf(stderr, "\n ============== Paint Start ================ \n");
|
||||||
|
#endif
|
||||||
|
|
||||||
glClearColorx ((color->red << 16) / 0xff,
|
glClearColorx ((color->red << 16) / 0xff,
|
||||||
(color->green << 16) / 0xff,
|
(color->green << 16) / 0xff,
|
||||||
(color->blue << 16) / 0xff,
|
(color->blue << 16) / 0xff,
|
||||||
@ -117,13 +124,13 @@ cogl_paint_init (ClutterColor *color)
|
|||||||
void
|
void
|
||||||
cogl_push_matrix (void)
|
cogl_push_matrix (void)
|
||||||
{
|
{
|
||||||
glPushMatrix();
|
GE( glPushMatrix() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
cogl_pop_matrix (void)
|
cogl_pop_matrix (void)
|
||||||
{
|
{
|
||||||
glPopMatrix();
|
GE( glPopMatrix() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -174,26 +181,26 @@ cogl_enable (gulong flags)
|
|||||||
{
|
{
|
||||||
if (!(__enable_flags & CGL_ENABLE_BLEND))
|
if (!(__enable_flags & CGL_ENABLE_BLEND))
|
||||||
{
|
{
|
||||||
glEnable (GL_BLEND);
|
GE( glEnable (GL_BLEND) );
|
||||||
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
GE( glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA) );
|
||||||
}
|
}
|
||||||
__enable_flags |= CGL_ENABLE_BLEND;
|
__enable_flags |= CGL_ENABLE_BLEND;
|
||||||
}
|
}
|
||||||
else if (__enable_flags & CGL_ENABLE_BLEND)
|
else if (__enable_flags & CGL_ENABLE_BLEND)
|
||||||
{
|
{
|
||||||
glDisable (GL_BLEND);
|
GE( glDisable (GL_BLEND) );
|
||||||
__enable_flags &= ~CGL_ENABLE_BLEND;
|
__enable_flags &= ~CGL_ENABLE_BLEND;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags & CGL_ENABLE_TEXTURE_2D)
|
if (flags & CGL_ENABLE_TEXTURE_2D)
|
||||||
{
|
{
|
||||||
if (!(__enable_flags & CGL_ENABLE_TEXTURE_2D))
|
if (!(__enable_flags & CGL_ENABLE_TEXTURE_2D))
|
||||||
glEnable (GL_TEXTURE_2D);
|
GE( glEnable (GL_TEXTURE_2D) );
|
||||||
__enable_flags |= CGL_ENABLE_TEXTURE_2D;
|
__enable_flags |= CGL_ENABLE_TEXTURE_2D;
|
||||||
}
|
}
|
||||||
else if (__enable_flags & CGL_ENABLE_TEXTURE_2D)
|
else if (__enable_flags & CGL_ENABLE_TEXTURE_2D)
|
||||||
{
|
{
|
||||||
glDisable (GL_TEXTURE_2D);
|
GE( glDisable (GL_TEXTURE_2D) );
|
||||||
__enable_flags &= ~CGL_ENABLE_TEXTURE_2D;
|
__enable_flags &= ~CGL_ENABLE_TEXTURE_2D;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -229,13 +236,10 @@ cogl_enable (gulong flags)
|
|||||||
void
|
void
|
||||||
cogl_color (ClutterColor *color)
|
cogl_color (ClutterColor *color)
|
||||||
{
|
{
|
||||||
#define FIX(x) CFX_DIV(CLUTTER_INT_TO_FIXED(x), CFX_255)
|
GE( glColor4x ((color->red << 16) / 0xff,
|
||||||
|
(color->green << 16) / 0xff,
|
||||||
GE( glColor4x (FIX(color->red),
|
(color->blue << 16) / 0xff,
|
||||||
FIX(color->green),
|
(color->alpha << 16) / 0xff) );
|
||||||
FIX(color->blue),
|
|
||||||
FIX(color->alpha)) );
|
|
||||||
#undef FIX
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
@ -271,13 +275,15 @@ cogl_texture_quad (gint x1,
|
|||||||
ClutterFixed tx2,
|
ClutterFixed tx2,
|
||||||
ClutterFixed ty2)
|
ClutterFixed ty2)
|
||||||
{
|
{
|
||||||
|
#define FIX CLUTTER_INT_TO_FIXED
|
||||||
|
|
||||||
GLfixed quadVerts[] = {
|
GLfixed quadVerts[] = {
|
||||||
x1, y1, 0,
|
FIX(x1), FIX(y1), 0,
|
||||||
x2, y1, 0,
|
FIX(x2), FIX(y1), 0,
|
||||||
x2, y2, 0,
|
FIX(x2), FIX(y2), 0,
|
||||||
x2, y2, 0,
|
FIX(x2), FIX(y2), 0,
|
||||||
x1, y2, 0,
|
FIX(x1), FIX(y2), 0,
|
||||||
x1, y1, 0
|
FIX(x1), FIX(y1), 0
|
||||||
};
|
};
|
||||||
|
|
||||||
GLfixed quadTex[] = {
|
GLfixed quadTex[] = {
|
||||||
@ -289,15 +295,15 @@ cogl_texture_quad (gint x1,
|
|||||||
tx1, ty1
|
tx1, ty1
|
||||||
};
|
};
|
||||||
|
|
||||||
glEnableClientState(GL_VERTEX_ARRAY);
|
#undef FIX
|
||||||
glEnableClientState(GL_TEXTURE_COORD_ARRAY);
|
|
||||||
glVertexPointer(3, GL_FIXED, 0, quadVerts);
|
|
||||||
glTexCoordPointer(2, GL_FIXED, 0, quadTex);
|
|
||||||
|
|
||||||
glDrawArrays(GL_TRIANGLES, 0, 6);
|
GE( glEnableClientState(GL_VERTEX_ARRAY) );
|
||||||
|
GE( glEnableClientState(GL_TEXTURE_COORD_ARRAY) );
|
||||||
glDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
GE( glVertexPointer(3, GL_FIXED, 0, quadVerts) );
|
||||||
glDisableClientState(GL_VERTEX_ARRAY);
|
GE( glTexCoordPointer(2, GL_FIXED, 0, quadTex) );
|
||||||
|
GE( glDrawArrays(GL_TRIANGLES, 0, 6) );
|
||||||
|
GE( glDisableClientState(GL_TEXTURE_COORD_ARRAY) );
|
||||||
|
GE( glDisableClientState(GL_VERTEX_ARRAY) );
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -393,15 +399,15 @@ cogl_rectangle (gint x, gint y, guint width, guint height)
|
|||||||
|
|
||||||
GLfixed rect_verts[] = {
|
GLfixed rect_verts[] = {
|
||||||
FIX(x), FIX(y),
|
FIX(x), FIX(y),
|
||||||
FIX(x + width), FIX(y),
|
FIX((x + width)), FIX(y),
|
||||||
FIX(x), FIX(y + height),
|
FIX(x), FIX((y + height)),
|
||||||
FIX(x + width), FIX(y + height),
|
FIX((x + width)), FIX((y + height)),
|
||||||
};
|
};
|
||||||
|
|
||||||
#undef FIX
|
#undef FIX
|
||||||
|
|
||||||
GE( glVertexPointer(2, GL_FIXED, 0, rect_verts) );
|
|
||||||
GE( glEnableClientState(GL_VERTEX_ARRAY) );
|
GE( glEnableClientState(GL_VERTEX_ARRAY) );
|
||||||
|
GE( glVertexPointer(2, GL_FIXED, 0, rect_verts) );
|
||||||
GE( glDrawArrays(GL_TRIANGLE_STRIP, 0, 4) );
|
GE( glDrawArrays(GL_TRIANGLE_STRIP, 0, 4) );
|
||||||
GE( glDisableClientState(GL_VERTEX_ARRAY) );
|
GE( glDisableClientState(GL_VERTEX_ARRAY) );
|
||||||
}
|
}
|
||||||
@ -426,6 +432,8 @@ cogl_alpha_func (COGLenum func,
|
|||||||
GE( glAlphaFunc (func, CLUTTER_FIXED_TO_FLOAT(ref)) );
|
GE( glAlphaFunc (func, CLUTTER_FIXED_TO_FLOAT(ref)) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fixed point implementation of the perspective function
|
* Fixed point implementation of the perspective function
|
||||||
*/
|
*/
|
||||||
@ -470,6 +478,52 @@ cogl_perspective (ClutterAngle fovy,
|
|||||||
#undef M
|
#undef M
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
void
|
||||||
|
cogl_perspective (ClutterAngle fovy,
|
||||||
|
ClutterFixed aspect,
|
||||||
|
ClutterFixed zNear,
|
||||||
|
ClutterFixed zFar)
|
||||||
|
{
|
||||||
|
ClutterFixed xmax, ymax;
|
||||||
|
ClutterFixed x, y, c, d;
|
||||||
|
|
||||||
|
GLfloat m[16];
|
||||||
|
|
||||||
|
memset (&m[0], 0, sizeof (m));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Based on the original algorithm in perspective():
|
||||||
|
*
|
||||||
|
* 1) xmin = -xmax => xmax + xmin == 0 && xmax - xmin == 2 * xmax
|
||||||
|
* same true for y, hence: a == 0 && b == 0;
|
||||||
|
*
|
||||||
|
* 2) When working with small numbers, we can are loosing significant
|
||||||
|
* precision, hence we use clutter_qmulx() here, not the fast macro.
|
||||||
|
*/
|
||||||
|
ymax = clutter_qmulx (zNear, clutter_tani (fovy >> 1));
|
||||||
|
xmax = clutter_qmulx (ymax, aspect);
|
||||||
|
|
||||||
|
x = CFX_DIV (zNear, xmax);
|
||||||
|
y = CFX_DIV (zNear, ymax);
|
||||||
|
c = CFX_DIV (-(zFar + zNear), ( zFar - zNear));
|
||||||
|
d = CFX_DIV (-(clutter_qmulx (2*zFar, zNear)), (zFar - zNear));
|
||||||
|
|
||||||
|
#define M(row,col) m[col*4+row]
|
||||||
|
M(0,0) = CLUTTER_FIXED_TO_FLOAT (x);
|
||||||
|
M(1,1) = CLUTTER_FIXED_TO_FLOAT (y);
|
||||||
|
M(2,2) = CLUTTER_FIXED_TO_FLOAT (c);
|
||||||
|
M(2,3) = CLUTTER_FIXED_TO_FLOAT (d);
|
||||||
|
M(3,2) = -1.0F;
|
||||||
|
|
||||||
|
GE( glMultMatrixf (m) );
|
||||||
|
|
||||||
|
#undef M
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void
|
void
|
||||||
cogl_setup_viewport (guint width,
|
cogl_setup_viewport (guint width,
|
||||||
guint height,
|
guint height,
|
||||||
@ -480,9 +534,19 @@ cogl_setup_viewport (guint width,
|
|||||||
{
|
{
|
||||||
GE( glViewport (0, 0, width, height) );
|
GE( glViewport (0, 0, width, height) );
|
||||||
|
|
||||||
|
#define NEG(x) (1 + ~(x))
|
||||||
|
|
||||||
GE( glMatrixMode (GL_PROJECTION) );
|
GE( glMatrixMode (GL_PROJECTION) );
|
||||||
GE( glLoadIdentity () );
|
GE( glLoadIdentity () );
|
||||||
|
|
||||||
|
/*
|
||||||
|
glOrthox (0,
|
||||||
|
width << 16,
|
||||||
|
0,
|
||||||
|
height << 16,
|
||||||
|
-1 << 16, 1 << 16);
|
||||||
|
*/
|
||||||
|
|
||||||
cogl_perspective (fovy, aspect, z_near, z_far);
|
cogl_perspective (fovy, aspect, z_near, z_far);
|
||||||
|
|
||||||
GE( glMatrixMode (GL_MODELVIEW) );
|
GE( glMatrixMode (GL_MODELVIEW) );
|
||||||
@ -491,13 +555,35 @@ cogl_setup_viewport (guint width,
|
|||||||
/* camera distance from screen, 0.5 * tan (FOV) */
|
/* camera distance from screen, 0.5 * tan (FOV) */
|
||||||
#define DEFAULT_Z_CAMERA 0.866025404f
|
#define DEFAULT_Z_CAMERA 0.866025404f
|
||||||
|
|
||||||
GE( glTranslatex (-CFX_HALF,
|
|
||||||
-CFX_HALF,
|
GE( glTranslatex (-1 << 15,
|
||||||
-CLUTTER_FLOAT_TO_FIXED(DEFAULT_Z_CAMERA)) );
|
-1 << 15,
|
||||||
|
NEG(CLUTTER_FLOAT_TO_FIXED(DEFAULT_Z_CAMERA))) );
|
||||||
|
|
||||||
|
GE( glScalex ( CFX_ONE / width,
|
||||||
|
NEG(CFX_ONE) / height,
|
||||||
|
CFX_ONE / width));
|
||||||
|
|
||||||
|
GE( glTranslatex (0, NEG(CFX_ONE) * height, 0) );
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
GE( glTranslatex (NEG(CFX_HALF),
|
||||||
|
NEG(CFX_HALF),
|
||||||
|
NEG(CLUTTER_FLOAT_TO_FIXED(DEFAULT_Z_CAMERA))) );
|
||||||
|
|
||||||
GE( glScalex ( CFX_DIV(CFX_ONE, CLUTTER_INT_TO_FIXED(width)),
|
GE( glScalex ( CFX_DIV(CFX_ONE, CLUTTER_INT_TO_FIXED(width)),
|
||||||
-CFX_DIV(CFX_ONE, CLUTTER_INT_TO_FIXED(height)),
|
NEG(CFX_DIV(CFX_ONE, CLUTTER_INT_TO_FIXED(height))),
|
||||||
CFX_DIV(CFX_ONE, CLUTTER_INT_TO_FIXED(width))) );
|
CFX_DIV(CFX_ONE, CLUTTER_INT_TO_FIXED(width))) );
|
||||||
|
|
||||||
GE( glTranslatex (0, -CFX_DIV(CFX_ONE, CLUTTER_INT_TO_FIXED(height)), 0) );
|
GE( glTranslatex (0, NEG(CFX_MUL(CFX_ONE, CLUTTER_INT_TO_FIXED(height))), 0) );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
GE( glTranslatef (-0.5f, -0.5f, -DEFAULT_Z_CAMERA) );
|
||||||
|
GE( glScalef ( 1.0f / width,
|
||||||
|
-1.0f / height,
|
||||||
|
1.0f / width) );
|
||||||
|
GE( glTranslatef (0.0f, -1.0 * height, 0.0f) );
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -213,7 +213,7 @@ clutter_stage_egl_paint (ClutterActor *self)
|
|||||||
*/
|
*/
|
||||||
if (stage_egl->xwin)
|
if (stage_egl->xwin)
|
||||||
{
|
{
|
||||||
clutter_feature_wait_for_vblank ();
|
/* clutter_feature_wait_for_vblank (); */
|
||||||
eglSwapBuffers ((EGLDisplay)stage_egl->xdpy, stage_egl->egl_surface);
|
eglSwapBuffers ((EGLDisplay)stage_egl->xdpy, stage_egl->egl_surface);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -575,11 +575,9 @@ draw_begin (PangoRenderer *renderer_)
|
|||||||
GL_ONE , GL_ONE_MINUS_SRC_ALPHA);
|
GL_ONE , GL_ONE_MINUS_SRC_ALPHA);
|
||||||
|
|
||||||
glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
glBlendFunc (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
||||||
|
|
||||||
glEnable (GL_ALPHA_TEST);
|
glEnable (GL_ALPHA_TEST);
|
||||||
glAlphaFunc (GL_GREATER, 0.01f);
|
glAlphaFunc (GL_GREATER, 0.01f);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -140,6 +140,10 @@ case $clutterbackend in
|
|||||||
|
|
||||||
EGL_LIBS="$EGL_LIBS $X11_LIBS"
|
EGL_LIBS="$EGL_LIBS $X11_LIBS"
|
||||||
EGL_CFLAGS="$EGL_CFLAGS $X11_CFLAGS"
|
EGL_CFLAGS="$EGL_CFLAGS $X11_CFLAGS"
|
||||||
|
|
||||||
|
# Hack for building against dgles
|
||||||
|
# EGL_CFLAGS="-I/usr/local/include -I/usr/local/include/GLES $X11_CFLAGS"
|
||||||
|
# EGL_LIBS="-L/usr/local/lib -lGLES_CM -legl -lSDL $X11_LIBS"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
*) AC_MSG_ERROR([Invalid backend for Clutter: use glx or egl])
|
*) AC_MSG_ERROR([Invalid backend for Clutter: use glx or egl])
|
||||||
|
Loading…
Reference in New Issue
Block a user