blob: fb0e520e42ef972d4c8305c6b3cc3ea75cb8ccf2 [file] [log] [blame]
<?xml version="1.0"?>
<document>
<properties>
<author email="">Conor MacNeill</author>
<author email="stefan.bodewig@freenet.de">Stefan Bodewig</author>
<title>Welcome</title>
</properties>
<body>
<section name="Ant 1.6beta3">
<p>Apache Ant 1.6beta3 is now available for <a
href="http://cvs.apache.org/dist/ant/v1.6beta3/">download</a>. As
we've already said in the announcements of Ant 1.5.4, this release
requires JDK 1.2 or later to run.</p>
<p>We encourage user to give this beta a release a try and report
any bugs found so that we get a chance to fix them before we make
the final release of Ant 1.6.</p>
<p>Ant 1.6 adds a lot of new features, most prominently support
for XML namespaces as well as a new concept of Ant libraries that
makes use of namespaces to avoid name clashes of custom tasks.
For a longer list of fixed bugs and new features see the release
notes.</p>
<p>The manual of Ant 1.6 is available on line
<a href="manual-1.6beta/"> here</a>.</p>
<p>If you find anything that hasn't been covered in the manual (I bet you
did) or could be explained better, feel free to help us out in the
<a href="http://nagoya.apache.org/wiki/apachewiki.cgi?NewAntFeaturesInDetail">Wiki </a>.</p>
</section>
<section name="Ant 1.5.4">
<p>Apache Ant 1.5.4 is now available for
<a href="http://ant.apache.org/bindownload.cgi">download</a>.
</p>
<div class="warning">
<div class="label">Note</div>
<div class="content">Ant 1.5.4 will be the last release that supports
JDK 1.1. The next major release of Ant, Ant 1.6, will require JDK 1.2 or
later
</div>
</div>
</section>
<section name="Apache Ant">
<p>
Apache Ant is a Java-based build tool. In theory, it is kind of like
Make, but without Make's wrinkles.
</p>
<p>
Why another build tool when there is already <em>make</em>, <em>gnumake</em>,
<em>nmake</em>, <em>jam</em>, and
others? Because all those tools have limitations that Ant's original author
couldn't live with when developing software across multiple platforms. Make-like
tools are inherently shell-based -- they evaluate a set of dependencies, then
execute commands not unlike what you would issue in a shell. This means that you
can easily extend these tools by using or writing any program for the OS that
you are working on. However, this also means that you limit yourself to the OS,
or at least the OS type such as Unix, that you are working on.
</p>
<p>
Makefiles are inherently evil as well. Anybody who has worked on them for any
time has run into the dreaded tab problem. &quot;Is my command not executing
because I have a space in front of my tab!!!&quot; said the original author of
Ant way too many times. Tools like Jam took care of this to a great degree, but
still have yet another format to use and remember.
</p>
<p>
Ant is different. Instead of a model where it is extended with shell-based
commands, Ant is extended using Java classes. Instead of writing shell commands,
the configuration files are XML-based, calling out a target tree where various
tasks get executed. Each task is run by an object that implements a particular
Task interface.
</p>
<p>
Granted, this removes some of the expressive power that is inherent by being
able to construct a shell command such as
<code>`find . -name foo -exec rm {}`</code>, but it
gives you the ability to be cross platform -- to work anywhere and everywhere.
And hey, if you really need to execute a shell command, Ant has an
<code>&lt;exec&gt;</code> task that
allows different commands to be executed based on the OS that it is executing
on.
</p>
</section>
<section name="Documentation">
<p>
You can view the documentation for the current release (Apache Ant 1.5.4)
<a href="manual/index.html">online</a>
</p>
<p>
Comprehensive documentation is included in the source and binary distributions.
</p>
</section>
<section name="Nightly Builds">
<p>
If you wish to use the latest Ant features, you can try downloading a nightly
build from <a href="http://cvs.apache.org/builds/ant/nightly/">here</a>
</p>
</section>
<section name="Get Involved">
<ul>
<li><a href="http://jakarta.apache.org/getinvolved/getinvolvedindex.html">Get Involved</a></li>
<li><a href="mail.html">Join Mailing Lists</a></li>
<li><a href="http://marc.theaimsgroup.com/?l=ant-dev&amp;r=1&amp;w=2">Search the Dev Mailing List</a>
</li>
<li><a href="http://marc.theaimsgroup.com/?l=ant-user&amp;r=1&amp;w=2">Search the User Mailing List</a>
</li>
</ul>
</section>
</body>
</document>