summaryrefslogtreecommitdiffstats
path: root/src/java/com/jogamp/openal/impl/ALProcAddressLookup.java
diff options
context:
space:
mode:
authorMichael Bien <[email protected]>2010-07-10 17:33:11 +0200
committerMichael Bien <[email protected]>2010-07-10 17:33:11 +0200
commitafa3632e8df813f54195c8a97833eff5c832d6ee (patch)
tree7ca4afd776f7c12919d598622b9498797273afd4 /src/java/com/jogamp/openal/impl/ALProcAddressLookup.java
parent728c9b6e348520d778009f42633ea9f6e0e782a1 (diff)
fixed alcGetString functionpointer mapping (gluegen does not handle method renames correctly).
ALCImpl is now ALCAbstractImpl. "Custom code" is now in ALCImpl which extends ALCAbstractImpl.
Diffstat (limited to 'src/java/com/jogamp/openal/impl/ALProcAddressLookup.java')
-rwxr-xr-xsrc/java/com/jogamp/openal/impl/ALProcAddressLookup.java33
1 files changed, 24 insertions, 9 deletions
diff --git a/src/java/com/jogamp/openal/impl/ALProcAddressLookup.java b/src/java/com/jogamp/openal/impl/ALProcAddressLookup.java
index 7f16628..45718dd 100755
--- a/src/java/com/jogamp/openal/impl/ALProcAddressLookup.java
+++ b/src/java/com/jogamp/openal/impl/ALProcAddressLookup.java
@@ -39,19 +39,34 @@ import java.lang.reflect.Field;
import com.jogamp.openal.*;
import com.jogamp.gluegen.runtime.*;
-import com.jogamp.openal.impl.ALCProcAddressTable;
-import com.jogamp.openal.impl.ALImpl;
-import com.jogamp.openal.impl.ALProcAddressTable;
/** Helper class for managing OpenAL-related proc address tables. */
public class ALProcAddressLookup {
- private static final ALProcAddressTable alTable = new ALProcAddressTable();
- private static volatile boolean alTableInitialized = false;
- private static final ALCProcAddressTable alcTable = new ALCProcAddressTable();
- private static volatile boolean alcTableInitialized = false;
- private static final DynamicLookup lookup = new DynamicLookup();
- private static volatile NativeLibrary openAL = null;
+
+ private static final ALProcAddressTable alTable;
+ private static final ALCProcAddressTable alcTable;
+
+ private static volatile boolean alTableInitialized = false;
+ private static volatile boolean alcTableInitialized = false;
+
+ private static final DynamicLookup lookup;
+ private static volatile NativeLibrary openAL;
+
+ static {
+ //workaround: map renamed fooImpl back to the real function name
+ FunctionAddressResolver resolver = new FunctionAddressResolver() {
+ public long resolve(String string, DynamicLookupHelper dlh) {
+ if (string.endsWith("Impl")) {
+ string = string.substring(0, string.length() - 4);
+ }
+ return dlh.dynamicLookupFunction(string);
+ }
+ };
+ alcTable = new ALCProcAddressTable(resolver);
+ alTable = new ALProcAddressTable();
+ lookup = new DynamicLookup();
+ }
static class DynamicLookup implements DynamicLookupHelper {
public long dynamicLookupFunction(String functionName) {