[patch] FileUtil nitpicking on safeClose
    Eckenfels. Bernd 
    B.Eckenfels at seeburger.de
       
    Fri May  1 19:11:30 UTC 2015
    
    
  
Here it is inline
diff -r 6f73b8573922 jmh-core/src/main/java/org/openjdk/jmh/util/FileUtils.java
--- a/jmh-core/src/main/java/org/openjdk/jmh/util/FileUtils.java        Thu Apr 30 16:40:52 2015 +0300
+++ b/jmh-core/src/main/java/org/openjdk/jmh/util/FileUtils.java        Fri May 01 03:09:54 2015 +0200
@@ -66,35 +66,25 @@
      * @throws IOException if things go crazy
      */
     public static File extractFromResource(String name) throws IOException {
-        InputStream fis = null;
+        InputStream is = null;
         OutputStream fos = null;
-        BufferedInputStream bis = null;
-        BufferedOutputStream bos = null;
         try {
-            fis = FileUtils.class.getResourceAsStream(name);
-            bis = new BufferedInputStream(fis);
+            is = FileUtils.class.getResourceAsStream(name);
             File temp = FileUtils.tempFile("extracted");
             fos = new FileOutputStream(temp);
-            bos = new BufferedOutputStream(fos);
-            byte[] b = new byte[1024];
+            byte[] buf = new byte[8096];
-            int available = bis.available();
-            while (available > 0) {
-                int length = Math.min(b.length, available);
-
-                int read = bis.read(b, 0, length);
-                bos.write(b, 0, read);
-
-                available = bis.available();
+            int read;
+            while ((read = is.read(buf)) != -1) {
+                fos.write(buf, 0, read);
             }
+            fos.close();
             return temp;
         } finally {
-            FileUtils.safelyClose(bis);
-            FileUtils.safelyClose(bos);
-            FileUtils.safelyClose(fis);
+            FileUtils.safelyClose(is);
             FileUtils.safelyClose(fos);
         }
     }
@@ -187,17 +177,24 @@
     }
     public static void copy(String src, String dst) throws IOException {
-        FileInputStream fis = new FileInputStream(src);
-        FileOutputStream fos = new FileOutputStream(dst);
+        FileInputStream fis = null;
+        FileOutputStream fos = null;
+        try
+        {
+            fis = new FileInputStream(src);
+            fos = new FileOutputStream(dst);
-        byte[] buf = new byte[8192];
-        int read;
-        while ((read = fis.read(buf)) != -1) {
-            fos.write(buf, 0, read);
+            byte[] buf = new byte[8192];
+            int read;
+            while ((read = fis.read(buf)) != -1) {
+                fos.write(buf, 0, read);
+            }
+
+            fos.close();
+        } finally {
+            FileUtils.safelyClose(fos);
+            FileUtils.safelyClose(fis);
         }
-
-        FileUtils.safelyClose(fos);
-        FileUtils.safelyClose(fis);
     }
     public static void safelyClose(OutputStream out) {
SEEBURGER AG            Vorstand/SEEBURGER Executive Board:
Sitz der Gesellschaft/Registered Office:                Bernd Seeburger, Axel Haas, Michael Kleeberg, Friedemann Heinz, Dr. Martin Kuntz, Matthias Feßenbecker
Edisonstr. 1
D-75015 Bretten         Vorsitzender des Aufsichtsrats/Chairperson of the SEEBURGER Supervisory Board:
Tel.: 07252 / 96 - 0            Dr. Franz Scherer
Fax: 07252 / 96 - 2222
Internet: http://www.seeburger.de               Registergericht/Commercial Register:
e-mail: info at seeburger.de               HRB 240708 Mannheim
Dieses E-Mail ist nur für den Empfänger bestimmt, an den es gerichtet ist und kann vertrauliches bzw. unter das Berufsgeheimnis fallendes Material enthalten. Jegliche darin enthaltene Ansicht oder Meinungsäußerung ist die des Autors und stellt nicht notwendigerweise die Ansicht oder Meinung der SEEBURGER AG dar. Sind Sie nicht der Empfänger, so haben Sie diese E-Mail irrtümlich erhalten und jegliche Verwendung, Veröffentlichung, Weiterleitung, Abschrift oder jeglicher Druck dieser E-Mail ist strengstens untersagt. Weder die SEEBURGER AG noch der Absender (Eckenfels. Bernd) übernehmen die Haftung für Viren; es obliegt Ihrer Verantwortung, die E-Mail und deren Anhänge auf Viren zu prüfen.
This email is intended only for the recipient(s) to whom it is addressed. This email may contain confidential material that may be protected by professional secrecy. Any fact or opinion contained, or expression of the material herein, does not necessarily reflect that of SEEBURGER AG. If you are not the addressee or if you have received this email in error, any use, publication or distribution including forwarding, copying or printing is strictly prohibited. Neither SEEBURGER AG, nor the sender (Eckenfels. Bernd) accept liability for viruses; it is your responsibility to check this email and its attachments for viruses.
    
    
More information about the jmh-dev
mailing list