test/lib/testlibrary/jdk/testlibrary/JarUtils.java
Print this page
*** 23,32 ****
--- 23,33 ----
package jdk.testlibrary;
import java.io.File;
import java.io.FileInputStream;
+ import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.file.Path;
import java.util.ArrayList;
import java.util.Enumeration;
*** 41,51 ****
*/
public final class JarUtils {
/**
! * Create jar file with specified files from specified location.
*/
public static void createJar(String dest, Path filesLocation,
String... fileNames) throws IOException {
try (JarOutputStream jos = new JarOutputStream(
new FileOutputStream(dest), new Manifest())) {
--- 42,53 ----
*/
public final class JarUtils {
/**
! * Create jar file with specified files. If a specified file does not exist,
! * a new jar entry will be created with the file name itself as the content.
*/
public static void createJar(String dest, Path filesLocation,
String... fileNames) throws IOException {
try (JarOutputStream jos = new JarOutputStream(
new FileOutputStream(dest), new Manifest())) {
*** 61,70 ****
--- 63,74 ----
} else {
file = new File(fileName);
}
try (FileInputStream fis = new FileInputStream(file)) {
Utils.transferBetweenStreams(fis, jos);
+ } catch (FileNotFoundException e) {
+ jos.write(fileName.getBytes());
}
}
}
System.out.println();
}
*** 76,86 ****
throws IOException {
createJar(dest, null, files);
}
/**
! * Add specified files to existing jar file.
*/
public static void updateJar(String src, String dest, String... files)
throws IOException {
try (JarOutputStream jos = new JarOutputStream(
new FileOutputStream(dest))) {
--- 80,100 ----
throws IOException {
createJar(dest, null, files);
}
/**
! * Add or remove specified files to existing jar file. If a specified file
! * to be updated or added does not exist, the jar entry will be created
! * with the file name itself as the content.
! *
! * @param src the original jar file name
! * @param dest the new jar file name
! * @param files the files to update. The list is broken into 2 groups
! * by a "-" string. The files before in the 1st group will
! * be either updated or added. The files in the 2nd group
! * will be removed. If no "-" exists, all files belong to
! * the 1st group.
*/
public static void updateJar(String src, String dest, String... files)
throws IOException {
try (JarOutputStream jos = new JarOutputStream(
new FileOutputStream(dest))) {
*** 92,117 ****
Enumeration<JarEntry> entries = srcJarFile.entries();
while (entries.hasMoreElements()) {
JarEntry entry = entries.nextElement();
String name = entry.getName();
boolean found = false;
for (String file : files) {
! if (name.equals(file)) {
updatedFiles.add(file);
found = true;
break;
}
}
if (found) {
System.out.println(String.format("Updating %s with %s",
dest, name));
jos.putNextEntry(new JarEntry(name));
try (FileInputStream fis = new FileInputStream(name)) {
Utils.transferBetweenStreams(fis, jos);
}
} else {
System.out.println(String.format("Copying %s to %s",
name, dest));
jos.putNextEntry(entry);
Utils.transferBetweenStreams(srcJarFile.
getInputStream(entry), jos);
--- 106,141 ----
Enumeration<JarEntry> entries = srcJarFile.entries();
while (entries.hasMoreElements()) {
JarEntry entry = entries.nextElement();
String name = entry.getName();
boolean found = false;
+ boolean update = true;
for (String file : files) {
! if (file.equals("-")) {
! update = false;
! } else if (name.equals(file)) {
updatedFiles.add(file);
found = true;
break;
}
}
if (found) {
+ if (update) {
System.out.println(String.format("Updating %s with %s",
dest, name));
jos.putNextEntry(new JarEntry(name));
try (FileInputStream fis = new FileInputStream(name)) {
Utils.transferBetweenStreams(fis, jos);
+ } catch (FileNotFoundException e) {
+ jos.write(name.getBytes());
}
} else {
+ System.out.println(String.format("Removing %s from %s",
+ name, dest));
+ }
+ } else {
System.out.println(String.format("Copying %s to %s",
name, dest));
jos.putNextEntry(entry);
Utils.transferBetweenStreams(srcJarFile.
getInputStream(entry), jos);
*** 119,134 ****
--- 143,163 ----
}
}
// append new files
for (String file : files) {
+ if (file.equals("-")) {
+ break;
+ }
if (!updatedFiles.contains(file)) {
System.out.println(String.format("Adding %s with %s",
dest, file));
jos.putNextEntry(new JarEntry(file));
try (FileInputStream fis = new FileInputStream(file)) {
Utils.transferBetweenStreams(fis, jos);
+ } catch (FileNotFoundException e) {
+ jos.write(file.getBytes());
}
}
}
}
System.out.println();