use vorbis libs from local directory in linux
This commit is contained in:
parent
497b9735f5
commit
78e579f6be
|
@ -61,7 +61,7 @@ public abstract class AL {
|
||||||
* String that requests a certain device or device configuration.
|
* String that requests a certain device or device configuration.
|
||||||
* If null is specified, the implementation will provide an
|
* If null is specified, the implementation will provide an
|
||||||
* implementation specific default.
|
* implementation specific default.
|
||||||
*/
|
*/
|
||||||
protected static String deviceArguments;
|
protected static String deviceArguments;
|
||||||
|
|
||||||
/** Frequency for mixing output buffer, in units of Hz. */
|
/** Frequency for mixing output buffer, in units of Hz. */
|
||||||
|
@ -73,40 +73,40 @@ public abstract class AL {
|
||||||
/** Flag, indicating a synchronous context. */
|
/** Flag, indicating a synchronous context. */
|
||||||
protected static int contextSynchronized = ALC.ALC_FALSE;
|
protected static int contextSynchronized = ALC.ALC_FALSE;
|
||||||
|
|
||||||
/** Have we been created? */
|
/** Have we been created? */
|
||||||
protected static boolean created;
|
protected static boolean created;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
initialize();
|
initialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Static initialization
|
* Static initialization
|
||||||
*/
|
*/
|
||||||
private static void initialize() {
|
private static void initialize() {
|
||||||
System.loadLibrary(org.lwjgl.Sys.getLibraryName());
|
System.loadLibrary(org.lwjgl.Sys.getLibraryName());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Native method to create AL instance
|
* Native method to create AL instance
|
||||||
*
|
*
|
||||||
* @param oalPaths Array of strings containing paths to search for OpenAL library
|
* @param oalPaths Array of strings containing paths to search for OpenAL library
|
||||||
* @return true if the AL creation process succeeded
|
* @return true if the AL creation process succeeded
|
||||||
*/
|
*/
|
||||||
protected static native void nCreate(String[] oalPaths) throws OpenALException;
|
protected static native void nCreate(String[] oalPaths) throws OpenALException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Native method the destroy the AL
|
* Native method the destroy the AL
|
||||||
*/
|
*/
|
||||||
protected static native void nDestroy();
|
protected static native void nDestroy();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return true if AL has been created
|
* @return true if AL has been created
|
||||||
*/
|
*/
|
||||||
public static boolean isCreated() {
|
public static boolean isCreated() {
|
||||||
return created;
|
return created;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an OpenAL instance. Using this constructor will cause OpenAL to
|
* Creates an OpenAL instance. Using this constructor will cause OpenAL to
|
||||||
* open the device using supplied device argument, and create a context using the context values
|
* open the device using supplied device argument, and create a context using the context values
|
||||||
|
@ -119,12 +119,12 @@ public abstract class AL {
|
||||||
*/
|
*/
|
||||||
public static void create(String deviceArguments, int contextFrequency, int contextRefresh, boolean contextSynchronized)
|
public static void create(String deviceArguments, int contextFrequency, int contextRefresh, boolean contextSynchronized)
|
||||||
throws OpenALException {
|
throws OpenALException {
|
||||||
|
|
||||||
if (created) {
|
if (created) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
AL.deviceArguments = deviceArguments;
|
AL.deviceArguments = deviceArguments;
|
||||||
AL.contextFrequency = contextFrequency;
|
AL.contextFrequency = contextFrequency;
|
||||||
AL.contextRefresh = contextRefresh;
|
AL.contextRefresh = contextRefresh;
|
||||||
|
@ -138,55 +138,50 @@ public abstract class AL {
|
||||||
* open the default device, and create a context using default values.
|
* open the default device, and create a context using default values.
|
||||||
*/
|
*/
|
||||||
public static void create() throws OpenALException {
|
public static void create() throws OpenALException {
|
||||||
if(created) {
|
if(created) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// need to pass path of possible locations of OAL to native side
|
// need to pass path of possible locations of OAL to native side
|
||||||
String libpath = System.getProperty("java.library.path");
|
String libpath = System.getProperty("java.library.path");
|
||||||
String seperator = System.getProperty("path.separator");
|
String seperator = System.getProperty("path.separator");
|
||||||
String libname;
|
String jwsLibname;
|
||||||
String jwsLibname;
|
|
||||||
|
|
||||||
// libname is hardcoded atm - this will change in a near future...
|
switch (Display.getPlatform()) {
|
||||||
switch (Display.getPlatform()) {
|
case Display.PLATFORM_WGL:
|
||||||
case Display.PLATFORM_WGL:
|
jwsLibname = "lwjglaudio";
|
||||||
libname = "lwjglaudio.dll";
|
break;
|
||||||
jwsLibname = "lwjglaudio";
|
case Display.PLATFORM_GLX:
|
||||||
break;
|
jwsLibname = "openal";
|
||||||
case Display.PLATFORM_GLX:
|
break;
|
||||||
libname = "libopenal.so";
|
case Display.PLATFORM_AGL:
|
||||||
jwsLibname = "openal";
|
jwsLibname = "openal";
|
||||||
break;
|
break;
|
||||||
case Display.PLATFORM_AGL:
|
default:
|
||||||
libname = "openal.dylib";
|
throw new OpenALException("Unknown platform");
|
||||||
jwsLibname = "openal";
|
}
|
||||||
break;
|
|
||||||
default:
|
String jwsPath = getPathFromJWS(jwsLibname);
|
||||||
throw new OpenALException("Unknown platform");
|
if (jwsPath != null) {
|
||||||
}
|
libpath += seperator
|
||||||
|
+ jwsPath.substring(0, jwsPath.lastIndexOf(File.separator));
|
||||||
String jwsPath = getPathFromJWS(jwsLibname);
|
}
|
||||||
if (jwsPath != null) {
|
|
||||||
libpath += seperator
|
|
||||||
+ jwsPath.substring(0, jwsPath.lastIndexOf(File.separator));
|
|
||||||
}
|
|
||||||
|
|
||||||
StringTokenizer st = new StringTokenizer(libpath, seperator);
|
StringTokenizer st = new StringTokenizer(libpath, seperator);
|
||||||
|
|
||||||
//create needed string array
|
//create needed string array
|
||||||
String[] oalPaths = new String[st.countTokens() + 1];
|
String[] oalPaths = new String[st.countTokens() + 1];
|
||||||
|
|
||||||
//build paths
|
//build paths
|
||||||
for (int i = 0; i < oalPaths.length - 1; i++) {
|
for (int i = 0; i < oalPaths.length - 1; i++) {
|
||||||
oalPaths[i] = st.nextToken() + File.separator + libname;
|
oalPaths[i] = st.nextToken() + File.separator;
|
||||||
}
|
}
|
||||||
|
|
||||||
//add cwd path
|
//add cwd path
|
||||||
oalPaths[oalPaths.length - 1] = libname;
|
oalPaths[oalPaths.length - 1] = "";
|
||||||
nCreate(oalPaths);
|
nCreate(oalPaths);
|
||||||
|
|
||||||
ALC.create();
|
ALC.create();
|
||||||
|
|
||||||
device = ALC.alcOpenDevice(deviceArguments);
|
device = ALC.alcOpenDevice(deviceArguments);
|
||||||
|
|
||||||
|
@ -202,17 +197,17 @@ public abstract class AL {
|
||||||
|
|
||||||
ALC.alcMakeContextCurrent(context.context);
|
ALC.alcMakeContextCurrent(context.context);
|
||||||
|
|
||||||
created = true;
|
created = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Exit cleanly by calling destroy.
|
* Exit cleanly by calling destroy.
|
||||||
*/
|
*/
|
||||||
public static void destroy() {
|
public static void destroy() {
|
||||||
if(!created) {
|
if(!created) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ALC.alcDestroyContext(context.context);
|
ALC.alcDestroyContext(context.context);
|
||||||
ALC.alcCloseDevice(device.device);
|
ALC.alcCloseDevice(device.device);
|
||||||
ALC.destroy();
|
ALC.destroy();
|
||||||
|
@ -225,36 +220,36 @@ public abstract class AL {
|
||||||
contextFrequency = -1;
|
contextFrequency = -1;
|
||||||
contextRefresh = -1;
|
contextRefresh = -1;
|
||||||
contextSynchronized = ALC.ALC_FALSE;
|
contextSynchronized = ALC.ALC_FALSE;
|
||||||
|
|
||||||
created = false;
|
created = false;
|
||||||
nDestroy();
|
nDestroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tries to locate OpenAL from the JWS Library path
|
* Tries to locate OpenAL from the JWS Library path
|
||||||
* This method exists because OpenAL is loaded from native code, and as such
|
* This method exists because OpenAL is loaded from native code, and as such
|
||||||
* is exempt from JWS library loading rutines. OpenAL therefore always fails.
|
* is exempt from JWS library loading rutines. OpenAL therefore always fails.
|
||||||
* We therefore invoke the protected method of the JWS classloader to see if it can
|
* We therefore invoke the protected method of the JWS classloader to see if it can
|
||||||
* locate it.
|
* locate it.
|
||||||
*
|
*
|
||||||
* @param libname Name of library to search for
|
* @param libname Name of library to search for
|
||||||
* @return Absolute path to library if found, otherwise null
|
* @return Absolute path to library if found, otherwise null
|
||||||
*/
|
*/
|
||||||
private static String getPathFromJWS(String libname) {
|
private static String getPathFromJWS(String libname) {
|
||||||
try {
|
try {
|
||||||
|
|
||||||
Sys.log("JWS Classloader looking for: " + libname);
|
Sys.log("JWS Classloader looking for: " + libname);
|
||||||
|
|
||||||
Object o = AL.class.getClassLoader();
|
Object o = AL.class.getClassLoader();
|
||||||
Class c = o.getClass();
|
Class c = o.getClass();
|
||||||
Method findLibrary =
|
Method findLibrary =
|
||||||
c.getMethod("findLibrary", new Class[] { String.class });
|
c.getMethod("findLibrary", new Class[] { String.class });
|
||||||
Object[] arguments = new Object[] { libname };
|
Object[] arguments = new Object[] { libname };
|
||||||
return (String) findLibrary.invoke(o, arguments);
|
return (String) findLibrary.invoke(o, arguments);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Sys.log("Failure locating OpenAL using classloader:" + e);
|
Sys.log("Failure locating OpenAL using classloader:" + e);
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,8 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
#include "extal.h"
|
#include "extal.h"
|
||||||
#include "common_tools.h"
|
#include "common_tools.h"
|
||||||
|
|
||||||
|
@ -125,6 +127,9 @@ EAXGet eaxGet; // EAXGet function, ret$
|
||||||
HMODULE handleOAL;
|
HMODULE handleOAL;
|
||||||
#endif
|
#endif
|
||||||
#ifdef _X11
|
#ifdef _X11
|
||||||
|
void* handleOGG;
|
||||||
|
void* handleVorbis;
|
||||||
|
void* handleVorbisFile;
|
||||||
void* handleOAL;
|
void* handleOAL;
|
||||||
#endif
|
#endif
|
||||||
#ifdef _AGL
|
#ifdef _AGL
|
||||||
|
@ -187,6 +192,35 @@ static void* GetFunctionPointer(const char* function) {
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Concatenate two strings
|
||||||
|
*/
|
||||||
|
static char *concatenate(const char *str1, const char *str2) {
|
||||||
|
int length1 = strlen(str1);
|
||||||
|
int length2 = strlen(str2);
|
||||||
|
char *str = (char *)calloc(length1 + length2 + 1, sizeof(char));
|
||||||
|
strncpy(str, str1, length1);
|
||||||
|
strncpy(str + length1, str2, length2 + 1);
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef _X11
|
||||||
|
static void closeVorbisLibs(void) {
|
||||||
|
if (handleOGG != NULL) {
|
||||||
|
dlclose(handleOGG);
|
||||||
|
handleOGG = NULL;
|
||||||
|
}
|
||||||
|
if (handleVorbis != NULL) {
|
||||||
|
dlclose(handleVorbis);
|
||||||
|
handleVorbis = NULL;
|
||||||
|
}
|
||||||
|
if (handleVorbisFile != NULL) {
|
||||||
|
dlclose(handleVorbisFile);
|
||||||
|
handleVorbisFile = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Loads the OpenAL Library
|
* Loads the OpenAL Library
|
||||||
*/
|
*/
|
||||||
|
@ -199,13 +233,35 @@ static bool LoadOpenAL(JNIEnv *env, jobjectArray oalPaths) {
|
||||||
const char *path_str = env->GetStringUTFChars(path, NULL);
|
const char *path_str = env->GetStringUTFChars(path, NULL);
|
||||||
printfDebug("Testing '%s'\n", path_str);
|
printfDebug("Testing '%s'\n", path_str);
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
handleOAL = LoadLibrary(path_str);
|
char *lib_str = concatenate(path_str, "lwjglaudio.dll");
|
||||||
|
handleOAL = LoadLibrary(lib_str);
|
||||||
|
free(lib_str);
|
||||||
#endif
|
#endif
|
||||||
#ifdef _X11
|
#ifdef _X11
|
||||||
handleOAL = dlopen(path_str, RTLD_LAZY);
|
char *lib_str = concatenate(path_str, "libogg.so.0");
|
||||||
|
handleOGG = dlopen(lib_str, RTLD_LAZY);
|
||||||
|
free(lib_str);
|
||||||
|
|
||||||
|
lib_str = concatenate(path_str, "libvorbis.so.0");
|
||||||
|
handleVorbis = dlopen(lib_str, RTLD_LAZY);
|
||||||
|
free(lib_str);
|
||||||
|
|
||||||
|
lib_str = concatenate(path_str, "libvorbisfile.so.3");
|
||||||
|
handleVorbisFile = dlopen(lib_str, RTLD_LAZY);
|
||||||
|
free(lib_str);
|
||||||
|
|
||||||
|
lib_str = concatenate(path_str, "libopenal.so");
|
||||||
|
handleOAL = dlopen(lib_str, RTLD_LAZY);
|
||||||
|
free(lib_str);
|
||||||
|
|
||||||
|
if (handleOAL == NULL) {
|
||||||
|
closeVorbisLibs();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
#ifdef _AGL
|
#ifdef _AGL
|
||||||
handleOAL = NSAddImage(path_str, NSADDIMAGE_OPTION_RETURN_ON_ERROR);
|
char *lib_str = concatenate(path_str, "openal.dylib");
|
||||||
|
handleOAL = NSAddImage(lib_str, NSADDIMAGE_OPTION_RETURN_ON_ERROR);
|
||||||
|
free(lib_str);
|
||||||
#endif
|
#endif
|
||||||
if (handleOAL != NULL) {
|
if (handleOAL != NULL) {
|
||||||
printfDebug("Found OpenAL at '%s'\n", path_str);
|
printfDebug("Found OpenAL at '%s'\n", path_str);
|
||||||
|
@ -225,7 +281,11 @@ static void UnLoadOpenAL() {
|
||||||
FreeLibrary(handleOAL);
|
FreeLibrary(handleOAL);
|
||||||
#endif
|
#endif
|
||||||
#ifdef _X11
|
#ifdef _X11
|
||||||
dlclose(handleOAL);
|
if (handleOAL != NULL) {
|
||||||
|
dlclose(handleOAL);
|
||||||
|
handleOAL = NULL;
|
||||||
|
}
|
||||||
|
closeVorbisLibs();
|
||||||
#endif
|
#endif
|
||||||
#ifdef _AGL
|
#ifdef _AGL
|
||||||
// Cannot remove the image
|
// Cannot remove the image
|
||||||
|
|
Loading…
Reference in New Issue