|
|
d6df71 |
From 3d08314de0494ff8bdc1a7bccc0ecc1730dbdd60 Mon Sep 17 00:00:00 2001
|
|
|
d6df71 |
From: Michael Simacek <msimacek@redhat.com>
|
|
|
d6df71 |
Date: Mon, 16 Jan 2017 11:31:32 +0100
|
|
|
d6df71 |
Subject: [PATCH 2/6] Load system library
|
|
|
d6df71 |
|
|
|
d6df71 |
---
|
|
|
d6df71 |
src/com/sun/jna/Native.java | 97 ++-------------------------------------------
|
|
|
d6df71 |
1 file changed, 4 insertions(+), 93 deletions(-)
|
|
|
d6df71 |
|
|
|
d6df71 |
diff --git a/src/com/sun/jna/Native.java b/src/com/sun/jna/Native.java
|
|
|
d6df71 |
index 91b195f..9ac3815 100644
|
|
|
d6df71 |
--- a/src/com/sun/jna/Native.java
|
|
|
d6df71 |
+++ b/src/com/sun/jna/Native.java
|
|
|
d6df71 |
@@ -829,101 +829,12 @@ public final class Native implements Version {
|
|
|
d6df71 |
|
|
|
d6df71 |
/**
|
|
|
d6df71 |
* Loads the JNA stub library.
|
|
|
d6df71 |
- * First tries jna.boot.library.path, then the system path, then from the
|
|
|
d6df71 |
- * jar file.
|
|
|
d6df71 |
+ * MODIFIED FROM UPSTREAM - we rip out all sorts of gunk here that is
|
|
|
d6df71 |
+ * unnecessary when JNA is properly installed with the OS.
|
|
|
d6df71 |
*/
|
|
|
d6df71 |
private static void loadNativeDispatchLibrary() {
|
|
|
d6df71 |
- if (!Boolean.getBoolean("jna.nounpack")) {
|
|
|
d6df71 |
- try {
|
|
|
d6df71 |
- removeTemporaryFiles();
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- catch(IOException e) {
|
|
|
d6df71 |
- System.err.println("JNA Warning: IOException removing temporary files: " + e.getMessage());
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
-
|
|
|
d6df71 |
- String libName = System.getProperty("jna.boot.library.name", "jnidispatch");
|
|
|
d6df71 |
- String bootPath = System.getProperty("jna.boot.library.path");
|
|
|
d6df71 |
- if (bootPath != null) {
|
|
|
d6df71 |
- // String.split not available in 1.4
|
|
|
d6df71 |
- StringTokenizer dirs = new StringTokenizer(bootPath, File.pathSeparator);
|
|
|
d6df71 |
- while (dirs.hasMoreTokens()) {
|
|
|
d6df71 |
- String dir = dirs.nextToken();
|
|
|
d6df71 |
- File file = new File(new File(dir), System.mapLibraryName(libName).replace(".dylib", ".jnilib"));
|
|
|
d6df71 |
- String path = file.getAbsolutePath();
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Looking in " + path);
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- if (file.exists()) {
|
|
|
d6df71 |
- try {
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Trying " + path);
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- System.setProperty("jnidispatch.path", path);
|
|
|
d6df71 |
- System.load(path);
|
|
|
d6df71 |
- jnidispatchPath = path;
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Found jnidispatch at " + path);
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- return;
|
|
|
d6df71 |
- } catch (UnsatisfiedLinkError ex) {
|
|
|
d6df71 |
- // Not a problem if already loaded in anoteher class loader
|
|
|
d6df71 |
- // Unfortunately we can't distinguish the difference...
|
|
|
d6df71 |
- //System.out.println("File found at " + file + " but not loadable: " + ex.getMessage());
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- if (Platform.isMac()) {
|
|
|
d6df71 |
- String orig, ext;
|
|
|
d6df71 |
- if (path.endsWith("dylib")) {
|
|
|
d6df71 |
- orig = "dylib";
|
|
|
d6df71 |
- ext = "jnilib";
|
|
|
d6df71 |
- } else {
|
|
|
d6df71 |
- orig = "jnilib";
|
|
|
d6df71 |
- ext = "dylib";
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- path = path.substring(0, path.lastIndexOf(orig)) + ext;
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Looking in " + path);
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- if (new File(path).exists()) {
|
|
|
d6df71 |
- try {
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Trying " + path);
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- System.setProperty("jnidispatch.path", path);
|
|
|
d6df71 |
- System.load(path);
|
|
|
d6df71 |
- jnidispatchPath = path;
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Found jnidispatch at " + path);
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- return;
|
|
|
d6df71 |
- } catch (UnsatisfiedLinkError ex) {
|
|
|
d6df71 |
- System.err.println("File found at " + path + " but not loadable: " + ex.getMessage());
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- if (!Boolean.getBoolean("jna.nosys")) {
|
|
|
d6df71 |
- try {
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Trying (via loadLibrary) " + libName);
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- System.loadLibrary(libName);
|
|
|
d6df71 |
- if (DEBUG_JNA_LOAD) {
|
|
|
d6df71 |
- System.out.println("Found jnidispatch on system path");
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- return;
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- catch(UnsatisfiedLinkError e) {
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- if (!Boolean.getBoolean("jna.noclasspath")) {
|
|
|
d6df71 |
- loadNativeDispatchLibraryFromClasspath();
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
- else {
|
|
|
d6df71 |
- throw new UnsatisfiedLinkError("Unable to locate JNA native support library");
|
|
|
d6df71 |
- }
|
|
|
d6df71 |
+ jnidispatchPath = "@LIBDIR@/" + System.mapLibraryName("jnidispatch");
|
|
|
d6df71 |
+ System.load(jnidispatchPath);
|
|
|
d6df71 |
}
|
|
|
d6df71 |
|
|
|
d6df71 |
static final String JNA_TMPLIB_PREFIX = "jna";
|
|
|
d6df71 |
--
|
|
|
d6df71 |
2.14.3
|
|
|
d6df71 |
|