001: /*
002: * BEGIN_HEADER - DO NOT EDIT
003: *
004: * The contents of this file are subject to the terms
005: * of the Common Development and Distribution License
006: * (the "License"). You may not use this file except
007: * in compliance with the License.
008: *
009: * You can obtain a copy of the license at
010: * https://open-esb.dev.java.net/public/CDDLv1.0.html.
011: * See the License for the specific language governing
012: * permissions and limitations under the License.
013: *
014: * When distributing Covered Code, include this CDDL
015: * HEADER in each file and include the License file at
016: * https://open-esb.dev.java.net/public/CDDLv1.0.html.
017: * If applicable add the following below this CDDL HEADER,
018: * with the fields enclosed by brackets "[]" replaced with
019: * your own identifying information: Portions Copyright
020: * [year] [name of copyright owner]
021: */
022:
023: /*
024: * @(#)JarFactory.java
025: * Copyright 2004-2007 Sun Microsystems, Inc. All Rights Reserved.
026: *
027: * END_HEADER - DO NOT EDIT
028: */
029: package com.sun.jbi.ui.common;
030:
031: import java.io.FileOutputStream;
032: import java.io.InputStream;
033: import java.io.IOException;
034:
035: import java.util.Enumeration;
036: import java.util.jar.JarException;
037: import java.util.jar.JarFile;
038: import java.io.File;
039: import java.io.FileInputStream;
040:
041: import java.util.zip.ZipFile;
042: import java.util.zip.ZipEntry;
043: import java.util.zip.ZipException;
044: import java.util.zip.ZipOutputStream;
045:
046: public class JarFactory {
047:
048: /* Buffer to read data
049: *
050: */
051: private byte[] mBuffer;
052:
053: /* Unzip Directory
054: *
055: */
056: private String mDir;
057:
058: /**
059: * This object provides utility methods to manipulate DOM tree.
060: * @param dir Directory to unjar
061: */
062: public JarFactory(String dir) {
063:
064: this .mDir = dir;
065: this .mBuffer = new byte[8092];
066: }
067:
068: /**
069: * Unjars a file.
070: *
071: * @param jarFile File to be unjared
072: * @throws IOException if error trying to read entry.
073: * @throws java.util.jar.JarException if error trying to read jar file.
074: */
075: public void unJar(File jarFile) throws IOException, JarException,
076: ZipException {
077:
078: // process all entries in that JAR file
079: JarFile jar = new JarFile(jarFile);
080: unJar(jar);
081: jar.close();
082: }
083:
084: /**
085: * Unjars a file.
086: *
087: * @param jar JarFile to be unjared
088: * @throws IOException if error trying to read entry.
089: * @throws java.util.jar.JarException if error trying to read jar file.
090: */
091: public void unJar(java.util.zip.ZipFile jar) throws IOException,
092: ZipException {
093:
094: // process all entries in that JAR file
095: Enumeration all = jar.entries();
096: while (all.hasMoreElements()) {
097: getEntry(jar, ((ZipEntry) (all.nextElement())));
098: }
099: }
100:
101: /**
102: * Gets one file <code>entry</code> from <code>jarFile</code>.
103: *
104: * @param jarFile the JAR file reference to retrieve <code>entry</code> from.
105: * @param entry the file from the JAR to extract.
106: * @return the ZipEntry name
107: * @throws IOException if error trying to read entry.
108: */
109: public String getEntry(ZipFile jarFile, ZipEntry entry)
110: throws IOException {
111:
112: String entryName = entry.getName();
113: // if a directory, mkdir it (remember to create
114: // intervening subdirectories if needed!)
115: if (entryName.endsWith("/")) {
116: new File(mDir, entryName).mkdirs();
117: return entryName;
118: }
119:
120: File f = new File(mDir, entryName);
121:
122: if (!f.getParentFile().exists()) {
123: f.getParentFile().mkdirs();
124: }
125:
126: // Must be a file; create output stream to the file
127: FileOutputStream fostream = new FileOutputStream(f);
128: InputStream istream = jarFile.getInputStream(entry);
129:
130: // extract files
131: int n = 0;
132: while ((n = istream.read(mBuffer)) > 0) {
133: fostream.write(mBuffer, 0, n);
134: }
135:
136: try {
137: istream.close();
138: fostream.close();
139: } catch (IOException e) {
140: // do nothing
141: }
142: return entryName;
143: }
144:
145: /**
146: * This method is used to create a zip file with the contents of this directory and
147: * keep it in the parent dir
148: * @param zipFileName the name of the zip file
149: * @returns String the path to the newly created zip
150: * @throws IOException if a zip could not be created
151: */
152: public String zip(String zipFileName) throws IOException {
153: try {
154: File dir = new File(mDir);
155: File zipFile = new File(dir.getParent(), zipFileName);
156:
157: ZipOutputStream outstream = new ZipOutputStream(
158: new FileOutputStream(zipFile));
159:
160: String[] filesToAdd = dir.list();
161:
162: for (int i = 0; i < filesToAdd.length; i++) {
163: FileInputStream inStream = new FileInputStream(
164: new File(dir, filesToAdd[i]));
165: outstream.putNextEntry(new ZipEntry(filesToAdd[i]));
166:
167: int len;
168: while ((len = inStream.read(mBuffer)) > 0) {
169: outstream.write(mBuffer, 0, len);
170: }
171: outstream.closeEntry();
172: inStream.close();
173: }
174: outstream.close();
175: return zipFile.getPath();
176: } catch (IOException ex) {
177: throw ex;
178: }
179: }
180:
181: }
|