All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.tools.ant.taskdefs.Untar Maven / Gradle / Ivy

There is a newer version: 1.0-rc5
Show newest version
/*
 * Copyright  2000-2005 The Apache Software Foundation
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 */

package org.apache.tools.ant.taskdefs;

import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.zip.GZIPInputStream;
import org.apache.tools.ant.BuildException;
import org.apache.tools.ant.Project;
import org.apache.tools.ant.types.EnumeratedAttribute;
import org.apache.tools.ant.util.FileUtils;
import org.apache.tools.bzip2.CBZip2InputStream;
import org.apache.tools.tar.TarEntry;
import org.apache.tools.tar.TarInputStream;



/**
 * Untar a file.
 * 

For JDK 1.1 "last modified time" field is set to current time instead of being * carried from the archive file.

*

PatternSets are used to select files to extract * from the archive. If no patternset is used, all files are extracted. *

*

FileSet>s may be used to select archived files * to perform unarchival upon. *

*

File permissions will not be restored on extracted files.

*

The untar task recognizes the long pathname entries used by GNU tar.

* * @since Ant 1.1 * * @ant.task category="packaging" */ public class Untar extends Expand { /** * compression method */ private UntarCompressionMethod compression = new UntarCompressionMethod(); /** * Set decompression algorithm to use; default=none. * * Allowable values are *

    *
  • none - no compression *
  • gzip - Gzip compression *
  • bzip2 - Bzip2 compression *
* * @param method compression method */ public void setCompression(UntarCompressionMethod method) { compression = method; } /** * No encoding support in Untar. * @param encoding not used * @throws BuildException always * @since Ant 1.6 */ public void setEncoding(String encoding) { throw new BuildException("The " + getTaskName() + " task doesn't support the encoding" + " attribute", getLocation()); } /** * @see Expand#expandFile(FileUtils, File, File) */ protected void expandFile(FileUtils fileUtils, File srcF, File dir) { FileInputStream fis = null; TarInputStream tis = null; try { log("Expanding: " + srcF + " into " + dir, Project.MSG_INFO); fis = new FileInputStream(srcF); tis = new TarInputStream( compression.decompress(srcF, new BufferedInputStream(fis))); TarEntry te = null; while ((te = tis.getNextEntry()) != null) { extractFile(fileUtils, srcF, dir, tis, te.getName(), te.getModTime(), te.isDirectory()); } log("expand complete", Project.MSG_VERBOSE); } catch (IOException ioe) { throw new BuildException("Error while expanding " + srcF.getPath(), ioe, getLocation()); } finally { if (tis != null) { try { tis.close(); } catch (IOException e) { // ignore } } else if (fis != null) { try { fis.close(); } catch (IOException e) { // ignore } } } } /** * Valid Modes for Compression attribute to Untar Task * */ public static final class UntarCompressionMethod extends EnumeratedAttribute { // permissible values for compression attribute /** * No compression */ private static final String NONE = "none"; /** * GZIP compression */ private static final String GZIP = "gzip"; /** * BZIP2 compression */ private static final String BZIP2 = "bzip2"; /** * Constructor */ public UntarCompressionMethod() { super(); setValue(NONE); } /** * Get valid enumeration values * * @return valid values */ public String[] getValues() { return new String[] {NONE, GZIP, BZIP2}; } /** * This method wraps the input stream with the * corresponding decompression method * * @param file provides location information for BuildException * @param istream input stream * @return input stream with on-the-fly decompression * @exception IOException thrown by GZIPInputStream constructor * @exception BuildException thrown if bzip stream does not * start with expected magic values */ private InputStream decompress(final File file, final InputStream istream) throws IOException, BuildException { final String value = getValue(); if (GZIP.equals(value)) { return new GZIPInputStream(istream); } else { if (BZIP2.equals(value)) { final char[] magic = new char[] {'B', 'Z'}; for (int i = 0; i < magic.length; i++) { if (istream.read() != magic[i]) { throw new BuildException( "Invalid bz2 file." + file.toString()); } } return new CBZip2InputStream(istream); } } return istream; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy