aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/com/sun/gluegen/runtime/opengl
diff options
context:
space:
mode:
authorSven Gothel <[email protected]>2008-07-04 23:09:45 +0000
committerSven Gothel <[email protected]>2008-07-04 23:09:45 +0000
commit204764628bbbd8228dcc2e735ac5ee6c21714295 (patch)
tree2a0d8a34b5719b77a7f25966261d5fd9dc4063ea /src/java/com/sun/gluegen/runtime/opengl
parentd850a0ee7939dcfa98202b9373435fca78e007de (diff)
GL Unification 2nd round.
Terminology: ARB Extensions: "GL2", "ARB", "OES", "OML" Vendor Extensions: "EXT", "NV", "ATI", "SGI", "SGIS", "SGIX", "HP", "IBM", "WIN" Pass-1 Unify ARB extensions with the same value Pass-2 Unify vendor extensions, if exist as an ARB extension with the same value. Pass-3 Emit Done: - Unification of GL enumerates - Unification of GL functions - dynamic extension lookup - .. TODO: - Break down GL.java: GL + GL2ES1ES2 (for future GL3, etc) - Add a GL2 small implementation, to only support the GL2ES2 subset, 'GL2SubES2' .. +++ - Fixed X11 build breakage of 'jawt' linkage. - Fixed NEWT native code mouse- and keyevent id's, missed sync while moving them from the bitfield notation. git-svn-id: file:///usr/local/projects/SUN/JOGL/git-svn/../svn-server-sync/gluegen/branches/JOGL_2_SANDBOX@93 a78bb65f-1512-4460-ba86-f6dc96a7bf27
Diffstat (limited to 'src/java/com/sun/gluegen/runtime/opengl')
-rw-r--r--src/java/com/sun/gluegen/runtime/opengl/GLProcAddressHelper.java112
-rw-r--r--src/java/com/sun/gluegen/runtime/opengl/GLUnifiedName.java222
2 files changed, 334 insertions, 0 deletions
diff --git a/src/java/com/sun/gluegen/runtime/opengl/GLProcAddressHelper.java b/src/java/com/sun/gluegen/runtime/opengl/GLProcAddressHelper.java
new file mode 100644
index 0000000..f8858d2
--- /dev/null
+++ b/src/java/com/sun/gluegen/runtime/opengl/GLProcAddressHelper.java
@@ -0,0 +1,112 @@
+/*
+ * Copyright (c) 2003-2005 Sun Microsystems, Inc. All Rights Reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * - Redistribution of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * - Redistribution in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * Neither the name of Sun Microsystems, Inc. or the names of
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * This software is provided "AS IS," without a warranty of any kind. ALL
+ * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES,
+ * INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A
+ * PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN
+ * MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE FOR
+ * ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
+ * DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR
+ * ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR
+ * DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE
+ * DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY,
+ * ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF
+ * SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
+ *
+ * You acknowledge that this software is not designed or intended for use
+ * in the design, construction, operation or maintenance of any nuclear
+ * facility.
+ */
+
+package com.sun.gluegen.runtime.opengl;
+
+import com.sun.gluegen.runtime.*;
+
+import java.security.*;
+
+// Debugging only
+import java.io.PrintStream;
+
+/** Helper class containing constants and methods to assist with the
+ manipulation of auto-generated ProcAddressTables. */
+
+public class GLProcAddressHelper extends ProcAddressHelper {
+
+ public static void resetProcAddressTable(Object table,
+ DynamicLookupHelper lookup) throws RuntimeException {
+ Class tableClass = table.getClass();
+ java.lang.reflect.Field[] fields = tableClass.getFields();
+ PrintStream dout = getDebugOutStream();
+
+ if (DEBUG) {
+ dout.println("ProcAddressHelper.resetProcAddressTable(" + table.getClass().getName() + ")");
+ }
+ for (int i = 0; i < fields.length; ++i) {
+ String addressFieldName = fields[i].getName();
+ if (!addressFieldName.startsWith(ProcAddressHelper.PROCADDRESS_VAR_PREFIX)) {
+ // not a proc address variable
+ continue;
+ }
+ int startOfMethodName = ProcAddressHelper.PROCADDRESS_VAR_PREFIX.length();
+ String funcNameBase = addressFieldName.substring(startOfMethodName);
+ java.lang.reflect.Field addressField;
+ try {
+ addressField = fields[i];
+ assert(addressField.getType() == Long.TYPE);
+ } catch (Exception e) {
+ throw new RuntimeException("Can not get proper proc address field for method \"" +
+ funcNameBase + "\": Couldn't get field \"" + addressFieldName +
+ "\" in class " + tableClass.getName(), e);
+ }
+ long newProcAddress = 0;
+ int funcNamePermNum = GLUnifiedName.getNamePermutationNumber(funcNameBase);
+ for(int j = 0; 0==newProcAddress && j < funcNamePermNum; j++) {
+ String funcName = GLUnifiedName.getNamePermutation(funcNameBase, j);
+ try {
+ if (DEBUG) {
+ dout.println(" try function lookup: " + funcName + " / " + funcNameBase);
+ }
+ newProcAddress = lookup.dynamicLookupFunction(funcName);
+ } catch (Exception e) {
+ if (DEBUG) {
+ dout.println(e);
+ e.printStackTrace();
+ }
+ }
+ }
+ try {
+ // set the current value of the proc address variable in the table object
+ addressField.setLong(table, newProcAddress);
+ if (DEBUG) {
+ dout.println(" " + addressField.getName() + " = 0x" + Long.toHexString(newProcAddress));
+ }
+ } catch (Exception e) {
+ throw new RuntimeException("Can not set proc address field for method \"" +
+ funcNameBase + "\": Couldn't set field \"" + addressFieldName +
+ "\" in class " + tableClass.getName(), e);
+ }
+ }
+ if (DEBUG) {
+ dout.flush();
+ if (DEBUG_PREFIX != null) {
+ dout.close();
+ }
+ }
+ }
+}
diff --git a/src/java/com/sun/gluegen/runtime/opengl/GLUnifiedName.java b/src/java/com/sun/gluegen/runtime/opengl/GLUnifiedName.java
new file mode 100644
index 0000000..44b5b1b
--- /dev/null
+++ b/src/java/com/sun/gluegen/runtime/opengl/GLUnifiedName.java
@@ -0,0 +1,222 @@
+/*
+ * Copyright (c) 2003-2005 Sun Microsystems, Inc. All Rights Reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * - Redistribution of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * - Redistribution in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * Neither the name of Sun Microsystems, Inc. or the names of
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * This software is provided "AS IS," without a warranty of any kind. ALL
+ * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES,
+ * INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A
+ * PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN
+ * MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE FOR
+ * ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
+ * DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR
+ * ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR
+ * DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE
+ * DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY,
+ * ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF
+ * SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
+ *
+ * You acknowledge that this software is not designed or intended for use
+ * in the design, construction, operation or maintenance of any nuclear
+ * facility.
+ *
+ */
+
+package com.sun.gluegen.runtime.opengl;
+
+import java.util.*;
+import com.sun.gluegen.runtime.*;
+
+public class GLUnifiedName implements Cloneable {
+ //GL_XYZ : GL_XYZ, GL_XYZ_GL2, GL_XYZ_ARB, GL_XYZ_OES, GL_XYZ_OML
+ //GL_XYZ : GL_XYZ, GL_GL2_XYZ, GL_ARB_XYZ, GL_OES_XYZ, GL_OML_XYZ
+ //
+ // Pass-1 Unify ARB extensions with the same value
+ // Pass-2 Unify vendor extensions,
+ // if exist as an ARB extension with the same value.
+ // Pass-3 Emit
+
+ public static final String[] extensionsARB = { "GL2", "ARB", "OES", "OML" };
+ public static final String[] extensionsVEN = { "EXT", "SGI", "SGIS", "SGIX", "NV", "AMD", "ATI", "HP", "IBM", "WIN" };
+
+ public static final boolean isExtension(String[] extensions, String str) {
+ for(int i = extensions.length - 1 ; i>=0 ; i--) {
+ if(str.endsWith(extensions[i])) {
+ return true;
+ }
+ if(str.startsWith("GL_"+extensions[i]+"_")) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ public static final String normalize(String[] extensions, String str) {
+ boolean touched = false;
+ for(int i = extensions.length - 1 ; !touched && i>=0 ; i--) {
+ if(str.endsWith("_"+extensions[i])) {
+ // enums
+ str = str.substring(0, str.length()-1-extensions[i].length());
+ touched=true;
+ } else if(str.endsWith(extensions[i])) {
+ // functions
+ str = str.substring(0, str.length()-extensions[i].length());
+ touched=true;
+ }
+ if(str.startsWith("GL_"+extensions[i]+"_")) {
+ str = "GL_"+str.substring(4+extensions[i].length());
+ touched=true;
+ }
+ }
+ return str;
+ }
+ public static final String normalizeARB(String str) {
+ return normalize(extensionsARB, str);
+ }
+ public static final boolean isExtensionARB(String str) {
+ return isExtension(extensionsARB, str);
+ }
+ public static final String normalizeVEN(String str) {
+ return normalize(extensionsVEN, str);
+ }
+ public static final boolean isExtensionVEN(String str) {
+ return isExtension(extensionsVEN, str);
+ }
+
+ public static final int getNamePermutationNumber(String name) {
+ if(isExtensionARB(name) || isExtensionVEN(name)) {
+ // no name permutation, if it's already a known extension
+ return 1;
+ }
+ return 1 + extensionsARB.length + extensionsVEN.length;
+ }
+
+ public static final String getNamePermutation(String name, int i) {
+ // identity
+ if(i==0) {
+ return name;
+ }
+ if(0>i || i>=(1+extensionsARB.length + extensionsVEN.length)) {
+ throw new RuntimeException("Index out of range [0.."+(1+extensionsARB.length+extensionsVEN.length-1)+"]: "+i);
+ }
+ // ARB
+ i-=1;
+ if(i<extensionsARB.length) {
+ return name+extensionsARB[i];
+ }
+ // VEN
+ i-=extensionsARB.length;
+ return name+extensionsVEN[i];
+ }
+
+ /**
+ */
+
+ public GLUnifiedName(String name) {
+ this(name, normalizeARB(name));
+ }
+
+ protected GLUnifiedName(String orig, String uni) {
+ this.nameOrig=new ArrayList();
+ this.nameOrig.add(orig);
+ this.nameUni=uni;
+ }
+
+ protected GLUnifiedName(List origs, String uni) {
+ this.nameOrig=new ArrayList();
+ this.nameOrig.addAll(origs);
+ this.nameUni=uni;
+ }
+
+ public void resetUni() {
+ nameUni=(String)nameOrig.get(0);
+ }
+ public void resetOriginal() {
+ nameOrig.clear();
+ nameOrig.add(nameUni);
+ }
+
+ public void addOrig(String name) {
+ if(!nameOrig.contains(name)) {
+ nameOrig.add(name);
+ }
+ }
+
+ public boolean isExtensionARB() {
+ boolean res = false;
+ for (Iterator iter = nameOrig.iterator(); !res && iter.hasNext(); ) {
+ res = isExtensionARB((String)iter.next());
+ }
+ return res;
+ }
+
+ public void normalizeVEN() {
+ nameUni=normalizeVEN(nameUni);
+ }
+
+ public boolean isExtensionVEN() {
+ boolean res = false;
+ for (Iterator iter = nameOrig.iterator(); !res && iter.hasNext(); ) {
+ res = isExtensionVEN((String)iter.next());
+ }
+ return res;
+ }
+
+ public boolean equals(Object obj) {
+ if (obj == this) {
+ return true;
+ }
+ if(null==obj || !(obj instanceof GLUnifiedName)) return false;
+ GLUnifiedName uen = (GLUnifiedName) obj;
+ return nameUni.equals(uen.nameUni);
+ }
+
+ public String getCommentString() {
+ if(nameOrig.size()==1 && ((String)nameOrig.get(0)).equals(nameUni)) {
+ return new String();
+ }
+ String res = " /** " + nameUni + ": Alias of: ";
+ for (Iterator iter = nameOrig.iterator(); iter.hasNext(); ) {
+ res = res.concat((String)iter.next()+", ");
+ }
+ res = res.concat(" */");
+ return res;
+ }
+
+ public String toString() {
+ if(nameOrig.size()==1 && ((String)nameOrig.get(0)).equals(nameUni)) {
+ return nameUni;
+ }
+ String res = nameUni + " /* " ;
+ for (Iterator iter = nameOrig.iterator(); iter.hasNext(); ) {
+ res = res.concat((String)iter.next()+", ");
+ }
+ res = res.concat(" */");
+ return res;
+ }
+
+ public Object clone() {
+ return new GLUnifiedName(nameOrig, nameUni);
+ }
+
+ public String getUni() { return nameUni; }
+ public List getOrig() { return nameOrig; }
+ public String getOrig(int i) { return (String)nameOrig.get(i); }
+
+ private List nameOrig;
+ private String nameUni;
+}
+