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