blob: 5500bc7653be9339ddbb5e86ec299647184f57b3 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2008 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.equinox.internal.p2.core.helpers;
import java.io.*;
import java.util.Enumeration;
import java.util.zip.GZIPInputStream;
/**
* Copied from org.eclipse.ui.internal.wizards.datatransfer.TarFile.
*/
public class TarFile {
private File file;
private TarInputStream entryEnumerationStream;
private TarEntry curEntry;
private TarInputStream entryStream;
private InputStream internalEntryStream;
/**
* Create a new TarFile for the given file.
*
* @param file
* @throws TarException
* @throws IOException
*/
public TarFile(File file) throws TarException, IOException {
this.file = file;
InputStream in = new FileInputStream(file);
// First, check if it's a GZIPInputStream.
try {
in = new GZIPInputStream(in);
} catch (IOException e) {
//If it is not compressed we close
//the old one and recreate
in.close();
in = new FileInputStream(file);
}
try {
entryEnumerationStream = new TarInputStream(in);
} catch (TarException ex) {
in.close();
throw ex;
}
curEntry = entryEnumerationStream.getNextEntry();
}
/**
* Close the tar file input stream.
*
* @throws IOException if the file cannot be successfully closed
*/
public void close() throws IOException {
entryEnumerationStream.close();
if (internalEntryStream != null)
internalEntryStream.close();
}
/**
* Returns an enumeration cataloguing the tar archive.
*
* @return enumeration of all files in the archive
*/
public Enumeration entries() {
return new Enumeration() {
public boolean hasMoreElements() {
return (curEntry != null);
}
public Object nextElement() {
TarEntry oldEntry = curEntry;
try {
curEntry = entryEnumerationStream.getNextEntry();
} catch (TarException e) {
curEntry = null;
} catch (IOException e) {
curEntry = null;
}
return oldEntry;
}
};
}
/**
* Returns a new InputStream for the given file in the tar archive.
*
* @param entry
* @return an input stream for the given file
* @throws TarException
* @throws IOException
*/
public InputStream getInputStream(TarEntry entry) throws TarException, IOException {
if (entryStream == null || !entryStream.skipToEntry(entry)) {
if (internalEntryStream != null) {
internalEntryStream.close();
}
internalEntryStream = new FileInputStream(file);
// First, check if it's a GZIPInputStream.
try {
internalEntryStream = new GZIPInputStream(internalEntryStream);
} catch (IOException e) {
//If it is not compressed we close
//the old one and recreate
internalEntryStream.close();
internalEntryStream = new FileInputStream(file);
}
entryStream = new TarInputStream(internalEntryStream, entry) {
public void close() {
// Ignore close() since we want to reuse the stream.
}
};
}
return entryStream;
}
/**
* Returns the path name of the file this archive represents.
*
* @return path
*/
public String getName() {
return file.getPath();
}
/* (non-Javadoc)
* @see java.util.zip.ZipFile#finalize()
*
*/
protected void finalize() throws Throwable {
close();
}
}