blob: 0d97478d37039da2d6d60a353198b100f9b4b9ed [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2007 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.wst.server.core.internal.tar;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Enumeration;
import java.util.zip.GZIPInputStream;
/**
* Reads a .tar or .tar.gz archive file, providing an index enumeration
* and allows for accessing an InputStream for arbitrary files in the
* archive.
* <p>
* Copied from org.eclipse.ui.internal.wizards.datatransfer.
* </p>
*/
public class TarFile {
private File file;
protected TarInputStream entryEnumerationStream;
protected TarEntry curEntry;
private TarInputStream entryStream;
/**
* 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);
}
entryEnumerationStream = new TarInputStream(in);
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();
}
/**
* Create a new TarFile for the given path name.
*
* @param filename
* @throws TarException
* @throws IOException
*/
public TarFile(String filename) throws TarException, IOException {
this(new File(filename));
}
/**
* 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)) {
InputStream in = new FileInputStream(file);
// First, check if it's a GZIPInputStream.
try {
in = new GZIPInputStream(in);
} catch(IOException e) {
in = new FileInputStream(file);
}
entryStream = new TarInputStream(in, entry) {
public void close() {
// Ignore close() since we want to reuse the stream.
}
};
}
if(entryStream == null) {
System.out.println("huh?"); //$NON-NLS-1$
}
return entryStream;
}
/**
* Returns the path name of the file this archive represents.
*
* @return path
*/
public String getName() {
return file.getPath();
}
}