9e856e
From 3ea58b7374f5451e693f09f9295e210006d1e7ff Mon Sep 17 00:00:00 2001
9e856e
From: Hiram Chirino <hiram@hiramchirino.com>
9e856e
Date: Mon, 6 May 2013 09:49:55 -0400
9e856e
Subject: [PATCH 6/6] Simplify shared lib extraction.
9e856e
9e856e
---
9e856e
 .../org/fusesource/hawtjni/runtime/Library.java    | 79 ++++++++--------------
9e856e
 1 file changed, 29 insertions(+), 50 deletions(-)
9e856e
9e856e
diff --git a/hawtjni-runtime/src/main/java/org/fusesource/hawtjni/runtime/Library.java b/hawtjni-runtime/src/main/java/org/fusesource/hawtjni/runtime/Library.java
9e856e
index c23081d..422bd2f 100755
9e856e
--- a/hawtjni-runtime/src/main/java/org/fusesource/hawtjni/runtime/Library.java
9e856e
+++ b/hawtjni-runtime/src/main/java/org/fusesource/hawtjni/runtime/Library.java
9e856e
@@ -9,13 +9,11 @@
9e856e
  *******************************************************************************/
9e856e
 package org.fusesource.hawtjni.runtime;
9e856e
 
9e856e
-import java.io.File;
9e856e
-import java.io.FileOutputStream;
9e856e
-import java.io.IOException;
9e856e
-import java.io.InputStream;
9e856e
+import java.io.*;
9e856e
 import java.net.MalformedURLException;
9e856e
 import java.net.URL;
9e856e
 import java.util.ArrayList;
9e856e
+import java.util.Random;
9e856e
 import java.util.regex.Pattern;
9e856e
 
9e856e
 /**
9e856e
@@ -206,16 +204,19 @@ public class Library {
9e856e
     private boolean exractAndLoad(ArrayList<String> errors, String version, String customPath, String resourcePath) {
9e856e
         URL resource = classLoader.getResource(resourcePath);
9e856e
         if( resource !=null ) {
9e856e
-            
9e856e
+
9e856e
             String libName = name + "-" + getBitModel();
9e856e
             if( version !=null) {
9e856e
                 libName += "-" + version;
9e856e
             }
9e856e
-            
9e856e
+            String []libNameParts = map(libName).split("\\.");
9e856e
+            String prefix = libNameParts[0]+"-";
9e856e
+            String suffix = "."+libNameParts[1];
9e856e
+
9e856e
             if( customPath!=null ) {
9e856e
                 // Try to extract it to the custom path...
9e856e
-                File target = file(customPath, map(libName));
9e856e
-                if( extract(errors, resource, target) ) {
9e856e
+                File target = extract(errors, resource, prefix, suffix, file(customPath));
9e856e
+                if( target!=null ) {
9e856e
                     if( load(errors, target) ) {
9e856e
                         return true;
9e856e
                     }
9e856e
@@ -224,8 +225,8 @@ public class Library {
9e856e
             
9e856e
             // Fall back to extracting to the tmp dir
9e856e
             customPath = System.getProperty("java.io.tmpdir");
9e856e
-            File target = file(customPath, map(libName));
9e856e
-            if( extract(errors, resource, target) ) {
9e856e
+            File target = extract(errors, resource, prefix, suffix, file(customPath));
9e856e
+            if( target!=null ) {
9e856e
                 if( load(errors, target) ) {
9e856e
                     return true;
9e856e
                 }
9e856e
@@ -259,67 +260,45 @@ public class Library {
9e856e
         return libName;
9e856e
     }
9e856e
 
9e856e
-    private boolean extract(ArrayList<String> errors, URL source, File target) {
9e856e
-        FileOutputStream os = null;
9e856e
-        InputStream is = null;
9e856e
-        boolean extracting = false;
9e856e
+    private File extract(ArrayList<String> errors, URL source, String prefix, String suffix, File directory) {
9e856e
+        File target = null;
9e856e
         try {
9e856e
-            if (!target.exists() || isStale(source, target) ) {
9e856e
+            FileOutputStream os = null;
9e856e
+            InputStream is = null;
9e856e
+            try {
9e856e
+                target = File.createTempFile(prefix, suffix, directory);
9e856e
                 is = source.openStream();
9e856e
                 if (is != null) {
9e856e
                     byte[] buffer = new byte[4096];
9e856e
                     os = new FileOutputStream(target);
9e856e
-                    extracting = true;
9e856e
                     int read;
9e856e
                     while ((read = is.read(buffer)) != -1) {
9e856e
                         os.write(buffer, 0, read);
9e856e
                     }
9e856e
-                    os.close();
9e856e
-                    is.close();
9e856e
                     chmod("755", target);
9e856e
                 }
9e856e
+                target.deleteOnExit();
9e856e
+                return target;
9e856e
+            } finally {
9e856e
+                close(os);
9e856e
+                close(is);
9e856e
             }
9e856e
         } catch (Throwable e) {
9e856e
-            try {
9e856e
-                if (os != null)
9e856e
-                    os.close();
9e856e
-            } catch (IOException e1) {
9e856e
-            }
9e856e
-            try {
9e856e
-                if (is != null)
9e856e
-                    is.close();
9e856e
-            } catch (IOException e1) {
9e856e
-            }
9e856e
-            if (extracting && target.exists())
9e856e
+            if( target!=null ) {
9e856e
                 target.delete();
9e856e
+            }
9e856e
             errors.add(e.getMessage());
9e856e
-            return false;
9e856e
         }
9e856e
-        return true;
9e856e
+        return null;
9e856e
     }
9e856e
 
9e856e
-    private boolean isStale(URL source, File target) {
9e856e
-        
9e856e
-        if( source.getProtocol().equals("jar") ) {
9e856e
-            // unwrap the jar protocol...
9e856e
+    static private void close(Closeable file) {
9e856e
+        if(file!=null) {
9e856e
             try {
9e856e
-                String parts[] = source.getFile().split(Pattern.quote("!"));
9e856e
-                source = new URL(parts[0]);
9e856e
-            } catch (MalformedURLException e) {
9e856e
-                return false;
9e856e
-            }
9e856e
-        }
9e856e
-        
9e856e
-        File sourceFile=null;
9e856e
-        if( source.getProtocol().equals("file") ) {
9e856e
-            sourceFile = new File(source.getFile());
9e856e
-        }
9e856e
-        if( sourceFile!=null && sourceFile.exists() ) {
9e856e
-            if( sourceFile.lastModified() > target.lastModified() ) {
9e856e
-                return true;
9e856e
+                file.close();
9e856e
+            } catch (Exception ignore) {
9e856e
             }
9e856e
         }
9e856e
-        return false;
9e856e
     }
9e856e
 
9e856e
     private void chmod(String permision, File path) {
9e856e
-- 
9e856e
1.8.1.4
9e856e