/******************************************************************************* * 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(); } }