mirror of
https://github.com/apache/ant.git
synced 2025-05-17 21:45:12 +00:00
find . -type f -exec sed -i "s/http:\/\/www.apache.org\/licenses\/LICENSE-2.0/https:\/\/www.apache.org\/licenses\/LICENSE-2.0/" {} \;
222 lines
9.1 KiB
HTML
222 lines
9.1 KiB
HTML
<!DOCTYPE html>
|
|
<!--
|
|
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
contributor license agreements. See the NOTICE file distributed with
|
|
this work for additional information regarding copyright ownership.
|
|
The ASF licenses this file to You 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
|
|
|
|
https://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.
|
|
-->
|
|
<html lang="en">
|
|
|
|
<head>
|
|
<link rel="stylesheet" type="text/css" href="../stylesheets/style.css">
|
|
<title>Unzip Task</title>
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<h2 id="unzip">Unjar/Untar/Unwar/Unzip</h2>
|
|
<h3>Description</h3>
|
|
<p>Unzips a zip-, war-, or jar file.</p>
|
|
<p><a href="../Types/patternset.html">PatternSet</a>s are used to select files to
|
|
extract <em>from</em> the archive. If no patternset is used, all files are extracted.</p>
|
|
|
|
<p><a href="../Types/resources.html#collection">resource collections</a> may be used to select
|
|
archived files to perform unarchival upon. Only file system based resource collections are
|
|
supported by <code>Unjar</code>/<code>Unwar</code>/<code>Unzip</code>, this
|
|
includes <a href="../Types/fileset.html">fileset</a>, <a href="../Types/filelist.html">filelist</a>, <a href="../using.html#path">path</a>,
|
|
and <a href="../Types/resources.html#files">files</a>. <code>Untar</code> supports arbitrary
|
|
resource collections. Prior to Apache Ant 1.7 only <code>fileset</code> has been supported as a
|
|
nested element.</p>
|
|
|
|
<p>You can define filename transformations by using a
|
|
nested <a href="../Types/mapper.html">mapper</a> element. The default mapper is the
|
|
<a href="../Types/mapper.html#identity-mapper">identity mapper</a>.</p>
|
|
<p>File permissions will not be restored on extracted files.</p>
|
|
<p>The <code>untar</code> task recognizes the long pathname entries used by GNU tar.<p>
|
|
|
|
<p><strong>Please note</strong> that different ZIP tools handle timestamps differently when it comes
|
|
to applying timezone offset calculations of files. Some ZIP libraries will store the timestamps as
|
|
they've been read from the filesystem while others will modify the timestamps both when reading and
|
|
writing the files to make all timestamps use the same timezone. A ZIP archive created by one
|
|
library may extract files with "wrong timestamps" when extracted by another library.</p>
|
|
|
|
<p>Ant's ZIP classes use the same algorithm as the InfoZIP tools and zlib (timestamps get adjusted),
|
|
Windows' "compressed folders" function and WinZIP don't change the timestamps. This means that
|
|
using the <code>unzip</code> task on files created by Windows' compressed folders function may
|
|
create files with timestamps that are "wrong", the same is true if you use Windows' functions to
|
|
extract an Ant generated ZIP archive.</p>
|
|
|
|
<h3>Parameters</h3>
|
|
<table class="attr">
|
|
<tr>
|
|
<th scope="col">Attribute</th>
|
|
<th scope="col">Description</th>
|
|
<th scope="col">Required</th>
|
|
</tr>
|
|
<tr>
|
|
<td>src</td>
|
|
<td>archive file to expand.</td>
|
|
<td>Yes, unless filesets are used</td>
|
|
</tr>
|
|
<tr>
|
|
<td>dest</td>
|
|
<td>directory where to store the expanded files.</td>
|
|
<td>Yes</td>
|
|
</tr>
|
|
<tr>
|
|
<td>overwrite</td>
|
|
<td>Overwrite files, even if they are newer than the corresponding entries in the archive
|
|
(<q>true|false</q>).</td>
|
|
<td>No; default is <q>true</q></td>
|
|
</tr>
|
|
<tr>
|
|
<td>compression</td>
|
|
<td><strong>Note</strong>: This attribute is only available for the <code>untar</code> task.<br/>
|
|
compression method. Allowable values are <q>none</q>, <q>gzip</q>, <q>xz</q>
|
|
and <q>bzip2</q>.</td>
|
|
<td>No; default is <q>none</q></td>
|
|
</tr>
|
|
<tr>
|
|
<td>encoding</td>
|
|
<td>The character encoding that has been used for filenames inside the zip file. For a list of
|
|
possible values see
|
|
the <a href="https://docs.oracle.com/javase/8/docs/technotes/guides/intl/encoding.doc.html"
|
|
target="_top">Supported Encodings</a>.<br/> Use the magic value <q>native-encoding</q> for
|
|
default JVM character encoding.<br/> See also the <a href="zip.html#encoding">discussion in
|
|
the zip task page</a></td>
|
|
<td>No; defaults to <q>UTF8</q> for <code>unzip</code> and default JVM character encoding
|
|
for <code>untar</code> task</td>
|
|
</tr>
|
|
<tr>
|
|
<td>failOnEmptyArchive</td>
|
|
<td>whether trying to extract an empty archive is an error. <em>since Ant 1.8.0</em></td>
|
|
<td>No; defaults to <q>false</q></td>
|
|
</tr>
|
|
<tr>
|
|
<td>stripAbsolutePathSpec</td>
|
|
<td>whether Ant should remove leading <q>/</q> or <q>\</q> characters from the extracted file
|
|
name before extracting it. Note that this changes the entry name before
|
|
applying <code>include</code>/<code>exclude</code> patterns and before using the nested
|
|
mappers (if any). <em>since Ant 1.8.0</em></td>
|
|
<td>No; defaults to <q>true</q> <em>since Ant 1.10.4</em>
|
|
(used to default to <q>false</q> prior to that)</td>
|
|
</tr>
|
|
<tr>
|
|
<td>scanForUnicodeExtraFields</td>
|
|
<td><strong>Note</strong>: This attribute is not available for the <code>untar</code> task.<br/>
|
|
If the archive contains Unicode extra fields then use them to set the file names, ignoring the
|
|
specified encoding.<br/>See also the <a href="zip.html#encoding">discussion in the zip task
|
|
page</a></td>
|
|
<td>No; defaults to <q>true</q></td>
|
|
</tr>
|
|
<tr>
|
|
<td>allowFilesToEscapeDest</td>
|
|
<td>Whether to allow the extracted file or directory to be outside of the dest
|
|
directory. <em>since Ant 1.10.4</em></td>
|
|
<td>No, defaults to <q>false</q> unless <var>stripAbsolutePathSpec</var> is <q>false</q> and the
|
|
entry's name starts with a leading path spec.</td>
|
|
</tr>
|
|
</table>
|
|
<h3>Examples</h3>
|
|
<pre><unzip src="${tomcat_src}/tools-src.zip" dest="${tools.home}"/></pre>
|
|
<pre>
|
|
<gunzip src="tools.tar.gz"/>
|
|
<untar src="tools.tar" dest="${tools.home}"/></pre>
|
|
<pre>
|
|
<unzip src="${tomcat_src}/tools-src.zip"
|
|
dest="${tools.home}">
|
|
<patternset>
|
|
<include name="**/*.java"/>
|
|
<exclude name="**/Test*.java"/>
|
|
</patternset>
|
|
</unzip></pre>
|
|
<pre>
|
|
<unzip dest="${tools.home}">
|
|
<patternset>
|
|
<include name="**/*.java"/>
|
|
<exclude name="**/Test*.java"/>
|
|
</patternset>
|
|
<fileset dir=".">
|
|
<include name="**/*.zip"/>
|
|
<exclude name="**/tmp*.zip"/>
|
|
</fileset>
|
|
</unzip></pre>
|
|
<pre>
|
|
<unzip src="apache-ant-bin.zip" dest="${tools.home}">
|
|
<patternset>
|
|
<include name="apache-ant/lib/ant.jar"/>
|
|
</patternset>
|
|
<mapper type="flatten"/>
|
|
</unzip></pre>
|
|
|
|
<p>Extract all images from <samp>ant.jar</samp> which are stored in the <samp>images</samp>
|
|
directory of the jar file (or somewhere under it). While extracting the directory structure
|
|
(<samp>images</samp>) will be preserved.</p>
|
|
<pre>
|
|
<unzip src="${ant.home}/lib/ant.jar" dest="...">
|
|
<patternset>
|
|
<include name="images/"/>
|
|
</patternset>
|
|
</unzip></pre>
|
|
|
|
<p>Extract two files, <samp>ant_logo_large.gif</samp> and <samp>LICENSE.txt</samp>,
|
|
from <samp>ant.jar</samp>. More exactly: extract all files with these names from anywhere in the
|
|
source file. While extracting the directory structure will be preserved.</p>
|
|
<pre>
|
|
<unzip src="${ant.home}/lib/ant.jar" dest="...">
|
|
<patternset>
|
|
<include name="**/ant_logo_large.gif"/>
|
|
<include name="**/LICENSE.txt"/>
|
|
</patternset>
|
|
</unzip></pre>
|
|
|
|
<h3>Related tasks</h3>
|
|
|
|
<p>The task</p>
|
|
|
|
<pre>
|
|
<unzip src="some-archive" dest="some-dir">
|
|
<patternset>
|
|
<include name="some-pattern"/>
|
|
</patternset>
|
|
<mapper type="some-mapper"/>
|
|
</unzip></pre>
|
|
|
|
<p>is identical to</p>
|
|
|
|
<pre>
|
|
<copy todir="some-dir" preservelastmodified="true">
|
|
<zipfileset src="some-archive">
|
|
<patternset>
|
|
<include name="some-pattern"/>
|
|
</patternset>
|
|
</zipfileset>
|
|
<mapper type="some-mapper"/>
|
|
</copy></pre>
|
|
|
|
<p>The same is also true for <code><untar></code>
|
|
and <code><tarfileset></code>. <code><copy></code> offers additional features
|
|
like <a href="../Types/filterchain.html">filtering files</a> on the fly, allowing a file to be
|
|
mapped to multiple destinations or a configurable file system timestamp granularity.</p>
|
|
|
|
<p>"Delete" files from a zipfile.</p>
|
|
|
|
<pre><zip destfile="new.jar">
|
|
<zipfileset src="old.jar">
|
|
<exclude name="do/not/include/this/class"/>
|
|
</zipfileset>
|
|
</zip></pre>
|
|
|
|
</body>
|
|
</html>
|