X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=test%2Fglx-link-call.c;h=46cb563ce47ad681d40eb2d26da0e34186ad0d84;hb=6014e77b9f7cf0570fe799fde240970a7cafb7ce;hp=0c5047eb7edc1ebd7789f45bbba401a8cc099824;hpb=18a600531c73bfd36f9d8d0814ee6d22d1456d67;p=fips diff --git a/test/glx-link-call.c b/test/glx-link-call.c index 0c5047e..46cb563 100644 --- a/test/glx-link-call.c +++ b/test/glx-link-call.c @@ -30,112 +30,30 @@ #include #include -#include "util.h" +#include "util-x11.h" -static void -set_2d_projection (int width, int height) -{ - glMatrixMode (GL_PROJECTION); - glLoadIdentity (); - glOrtho (0, width, height, 0, 0, 1); - glMatrixMode (GL_MODELVIEW); -} - -static void -paint_rgb_using_clear (double r, double g, double b) -{ - glClearColor(r, g, b, 1.0); - glClear(GL_COLOR_BUFFER_BIT); -} - -static void -draw (Display *dpy, Window window, int width, int height) -{ - int i; - int visual_attr[] = { - GLX_RGBA, - GLX_RED_SIZE, 8, - GLX_GREEN_SIZE, 8, - GLX_BLUE_SIZE, 8, - GLX_ALPHA_SIZE, 8, - GLX_DOUBLEBUFFER, - GLX_DEPTH_SIZE, 24, - GLX_STENCIL_SIZE, 8, - GLX_X_VISUAL_TYPE, GLX_DIRECT_COLOR, - None - }; - - /* Window and context setup. */ - XVisualInfo *visual_info = glXChooseVisual(dpy, 0, visual_attr); - GLXContext ctx = glXCreateContext(dpy, visual_info, NULL, True); - glXMakeCurrent(dpy, window, ctx); - - glViewport(0, 0, width, height); - - set_2d_projection (width, height); - -/* Simply count through some colors, frame by frame. */ -#define RGB(frame) (((frame+1)/4) % 2), (((frame+1)/2) % 2), ((frame+1) % 2) - - int frame = 0; - for (i = 0; i < 2; i++) { - /* Frame: Draw a solid (magenta) frame */ - paint_rgb_using_clear (RGB(frame)); - glXSwapBuffers (dpy, window); - frame++; - - /* Frame: Draw a solid (yellow) frame */ - paint_rgb_using_clear (RGB(frame)); - glXSwapBuffers (dpy, window); - frame++; - - /* Frame: Draw a solid (cyan) frame */ - paint_rgb_using_clear (RGB(frame)); - glXSwapBuffers (dpy, window); - frame++; - } - - /* Cleanup */ - glXDestroyContext (dpy, ctx); -} - -static void -handle_events(Display *dpy, Window window) -{ - XEvent xev; - int width = 0; - int height = 0; - - XNextEvent (dpy, &xev); - - while (1) { - XNextEvent (dpy, &xev); - switch (xev.type) { - case ConfigureNotify: - width = xev.xconfigure.width; - height = xev.xconfigure.height; - break; - case Expose: - if (xev.xexpose.count == 0) { - draw (dpy, window, width, height); - return; - } - break; - } - } -} +#define HANDLE_EVENTS_GL_PREFIX +#include "handle-events.c" int main (void) { Display *dpy; Window window; + GLXContext ctx; + XVisualInfo *visual_info; + + dpy = util_x11_init_display (); + + create_context (dpy, &ctx, &visual_info); + + window = util_x11_init_window (dpy, visual_info); - util_init_display_window (&dpy, &window); + handle_events (dpy, ctx, window); - handle_events (dpy, window); + util_x11_fini_window (dpy, window); - util_fini_display_window (dpy, window); + util_x11_fini_display (dpy); return 0; }