[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