[Xquartz-changes] [315] AppleSGLX/trunk
source_changes at macosforge.org
source_changes at macosforge.org
Wed Mar 18 18:27:49 PDT 2009
Revision: 315
http://trac.macosforge.org/projects/xquartz/changeset/315
Author: jeremyhu at freedesktop.org
Date: 2009-03-18 18:27:49 -0700 (Wed, 18 Mar 2009)
Log Message:
-----------
Better API compatability with OpenGL.framework's gl.h
Modified Paths:
--------------
AppleSGLX/trunk/gen_gl_h.sh
AppleSGLX/trunk/include/GL/gl.h.footer
Modified: AppleSGLX/trunk/gen_gl_h.sh
===================================================================
--- AppleSGLX/trunk/gen_gl_h.sh 2009-03-18 07:30:54 UTC (rev 314)
+++ AppleSGLX/trunk/gen_gl_h.sh 2009-03-19 01:27:49 UTC (rev 315)
@@ -2,6 +2,14 @@
{
cat include/GL/gl.h.header
- grep gl.*ProcPtr /System/Library/Frameworks/OpenGL.framework/Headers/gl{,ext}.h | sed 's:^.*\(gl.*Ptr\).*$:\1:' | sort -u | perl -ne 'chomp($_); $s = "PFN".uc($_); $s =~ s/PROCPTR/PROC/; print "#define ".$_." ".$s."\n"'
+ if grep -q GL_GLEXT_PROTOTYPES /System/Library/Frameworks/OpenGL.framework/Headers/gl.h ; then
+ grep gl.*ProcPtr /System/Library/Frameworks/OpenGL.framework/Headers/gl{,ext}.h | sed 's:^.*\(gl.*Ptr\).*$:\1:' | sort -u | perl -ne 'chomp($_); $s = "PFN".uc($_); $s =~ s/PROCPTR/PROC/; print "#define ".$_." ".$s."\n"'
+ else
+ {
+ echo "#define GL_GLEXT_FUNCTION_POINTERS 1"
+ grep gl.*ProcPtr /System/Library/Frameworks/OpenGL.framework/Headers/gl{,ext}.h | sed 's:^.*\(gl.*Ptr\).*$:\1:' | sort -u | perl -ne 'chomp($_); $s = "PFN".uc($_); $s =~ s/PROCPTR/PROC/; print "#define ".$_." ".$s."\n"'
+ echo '#include "/System/Library/Frameworks/OpenGL.framework/Headers/gl.h"'
+ } | gcc -E - | grep typedef.*PFN
+ fi
cat include/GL/gl.h.footer
} > include/GL/gl.h
Modified: AppleSGLX/trunk/include/GL/gl.h.footer
===================================================================
--- AppleSGLX/trunk/include/GL/gl.h.footer 2009-03-18 07:30:54 UTC (rev 314)
+++ AppleSGLX/trunk/include/GL/gl.h.footer 2009-03-19 01:27:49 UTC (rev 315)
@@ -1,29 +1,48 @@
-/* We want to use OpelGL.framework's headers to get both prototypes and
- * function pointers (like Mesa's API)
+/* On SL, we want to use OpelGL.framework's headers to get both prototypes and
+ * function pointers (like Mesa's API), but on Leo and before, OpenGL.framework
+ * can't give us both.
*/
-#ifndef GL_GLEXT_FUNCTION_POINTERS
-#define GL_GLEXT_FUNCTION_POINTERS 1
+#ifdef GL_GLEXT_FUNCTION_POINTERS
+#define _GL_GLEXT_FUNCTION_POINTERS GL_GLEXT_FUNCTION_POINTERS
+#undef GL_GLEXT_FUNCTION_POINTERS
#endif
-#ifndef GL_GLEXT_PROTOTYPES
-#define GL_GLEXT_PROTOTYPES 0
+#ifdef GL_GLEXT_PROTOTYPES
+#define _GL_GLEXT_PROTOTYPES GL_GLEXT_PROTOTYPES
+#else
+#define GL_GLEXT_PROTOTYPES 1
#endif
/* Our glext.h is based on a version from the registry that is newer. */
-#ifndef GL_GLEXT_LEGACY
-#define GL_GLEXT_LEGACY 0
+#ifdef GL_GLEXT_LEGACY
+#define _GL_GLEXT_LEGACY GL_GLEXT_LEGACY
+#else
+#define GL_GLEXT_LEGACY 1
#endif
#include "/System/Library/Frameworks/OpenGL.framework/Headers/gl.h"
-/* Unset GL_GLEXT_PROTOTYPES for glext.h if the user didn't want those */
-#if GL_GLEXT_PROTOTYPES == 0
+/* Restore our GLEXT-fu */
+#ifdef _GL_GLEXT_FUNCTION_POINTERS
+#define GL_GLEXT_FUNCTION_POINTERS _GL_GLEXT_FUNCTION_POINTERS
+#else
+#undef GL_GLEXT_FUNCTION_POINTERS
+#endif
+
+#ifdef _GL_GLEXT_PROTOTYPES
+#define GL_GLEXT_PROTOTYPES _GL_GLEXT_PROTOTYPES
+#else
#undef GL_GLEXT_PROTOTYPES
#endif
-#if GL_GLEXT_LEGACY == 0
+#ifdef _GL_GLEXT_LEGACY
+#define GL_GLEXT_LEGACY _GL_GLEXT_LEGACY
+#else
#undef GL_GLEXT_LEGACY
+#endif
+
+#ifndef GL_GLEXT_LEGACY
#include <GL/glext.h>
#endif
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.macosforge.org/pipermail/xquartz-changes/attachments/20090318/89f950d8/attachment.html>
More information about the Xquartz-changes
mailing list