[Xquartz-changes] [211] AppleSGLX/trunk/tests/glxpixmap

source_changes at macosforge.org source_changes at macosforge.org
Fri Feb 20 14:32:03 PST 2009


Revision: 211
          http://trac.macosforge.org/projects/xquartz/changeset/211
Author:   gstaplin at apple.com
Date:     2009-02-20 14:32:03 -0800 (Fri, 20 Feb 2009)
Log Message:
-----------
Add a test for the GLXPixmap code that destroys an invalid GLXPixmap id.

It doesn't pass at the moment.

I think I will fix it in the future by making apple_glx_pixmap_destroy
return a bool and using the XError pattern based on that.

Modified Paths:
--------------
    AppleSGLX/trunk/tests/glxpixmap/glxpixmap.mk

Added Paths:
-----------
    AppleSGLX/trunk/tests/glxpixmap/glxpixmap_destroy_invalid.c

Modified: AppleSGLX/trunk/tests/glxpixmap/glxpixmap.mk
===================================================================
--- AppleSGLX/trunk/tests/glxpixmap/glxpixmap.mk	2009-02-20 22:27:37 UTC (rev 210)
+++ AppleSGLX/trunk/tests/glxpixmap/glxpixmap.mk	2009-02-20 22:32:03 UTC (rev 211)
@@ -4,3 +4,5 @@
 $(TEST_BUILD_DIR)/glxpixmap_create_destroy: tests/glxpixmap/glxpixmap_create_destroy.c $(LIBGL)
 	$(CC) tests/glxpixmap/glxpixmap_create_destroy.c -Iinclude -I/usr/X11/include -o $(TEST_BUILD_DIR)/glxpixmap_create_destroy $(LINK_TEST)
 
+$(TEST_BUILD_DIR)/glxpixmap_destroy_invalid: tests/glxpixmap/glxpixmap_destroy_invalid.c $(LIBGL)
+	$(CC) tests/glxpixmap/glxpixmap_destroy_invalid.c -Iinclude -I/usr/X11/include -o $(TEST_BUILD_DIR)/glxpixmap_destroy_invalid $(LINK_TEST)

Added: AppleSGLX/trunk/tests/glxpixmap/glxpixmap_destroy_invalid.c
===================================================================
--- AppleSGLX/trunk/tests/glxpixmap/glxpixmap_destroy_invalid.c	                        (rev 0)
+++ AppleSGLX/trunk/tests/glxpixmap/glxpixmap_destroy_invalid.c	2009-02-20 22:32:03 UTC (rev 211)
@@ -0,0 +1,111 @@
+
+
+/*
+ * A demonstration of using the GLXPixmap functions.  This program is in
+ * the public domain.
+ *
+ * Brian Paul
+ */
+
+
+#include <GL/gl.h>
+#include <GL/glx.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+
+static GLXContext ctx;
+static XVisualInfo *visinfo;
+static GC gc;
+
+
+
+static Window make_rgb_window( Display *dpy,
+				  unsigned int width, unsigned int height )
+{
+   const int sbAttrib[] = { GLX_RGBA,
+                            GLX_RED_SIZE, 1,
+                            GLX_GREEN_SIZE, 1,
+                            GLX_BLUE_SIZE, 1,
+                            None };
+   const int dbAttrib[] = { GLX_RGBA,
+                            GLX_RED_SIZE, 1,
+                            GLX_GREEN_SIZE, 1,
+                            GLX_BLUE_SIZE, 1,
+                            GLX_DOUBLEBUFFER,
+                            None };
+   int scrnum;
+   XSetWindowAttributes attr;
+   unsigned long mask;
+   Window root;
+   Window win;
+
+   scrnum = DefaultScreen( dpy );
+   root = RootWindow( dpy, scrnum );
+
+   visinfo = glXChooseVisual( dpy, scrnum, (int *) sbAttrib );
+   if (!visinfo) {
+      visinfo = glXChooseVisual( dpy, scrnum, (int *) dbAttrib );
+      if (!visinfo) {
+         printf("Error: couldn't get an RGB visual\n");
+         exit(1);
+      }
+   }
+
+   /* window attributes */
+   attr.background_pixel = 0;
+   attr.border_pixel = 0;
+   /* TODO: share root colormap if possible */
+   attr.colormap = XCreateColormap( dpy, root, visinfo->visual, AllocNone);
+   attr.event_mask = StructureNotifyMask | ExposureMask;
+   mask = CWBackPixel | CWBorderPixel | CWColormap | CWEventMask;
+
+   win = XCreateWindow( dpy, root, 0, 0, width, height,
+		        0, visinfo->depth, InputOutput,
+		        visinfo->visual, mask, &attr );
+
+   /* make an X GC so we can do XCopyArea later */
+   gc = XCreateGC( dpy, win, 0, NULL );
+
+   /* need indirect context */
+   ctx = glXCreateContext( dpy, visinfo, NULL, False );
+   if (!ctx) {
+      printf("Error: glXCreateContext failed\n");
+      exit(-1);
+   }
+
+   printf("Direct rendering: %s\n", glXIsDirect(dpy, ctx) ? "Yes" : "No");
+
+   return win;
+}
+
+int main( int argc, char *argv[] )
+{
+   Display *dpy;
+   Window win;
+   Pixmap pm;
+   GLXPixmap glxpm;
+   int eventbase, errorbase;
+
+   dpy = XOpenDisplay(NULL);
+
+   if(NULL == dpy) {
+       fprintf(stderr, "error: opening display\n");
+       return EXIT_FAILURE;
+   }
+
+   if(!glXQueryExtension(dpy, &eventbase, &errorbase)) {
+       fprintf(stderr, "GLX is not available!\n");
+       return EXIT_FAILURE;
+   }
+   
+
+   win = make_rgb_window( dpy, 300, 300 );
+
+   fprintf(stderr, "This test should produce a GLXBadPixmap error.\n");
+
+   glXDestroyPixmap(dpy, /*intentional*/ win);
+
+   return 0;
+}
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.macosforge.org/pipermail/xquartz-changes/attachments/20090220/ad184370/attachment.html>


More information about the Xquartz-changes mailing list