Blame SOURCES/0002-Load-system-library.patch

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