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/" {} \;
67 lines
2.9 KiB
HTML
67 lines
2.9 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>Apache Ant User Manual—Introduction</title>
|
|
</head>
|
|
|
|
<body>
|
|
<h1 id="introduction">Introduction</h1>
|
|
<p>Apache Ant is a Java-based build tool. In theory, it is kind of like
|
|
<em>make</em>, without <em>make</em>'s wrinkles.</p>
|
|
<h3>Why?</h3>
|
|
<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 on 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. "Is my command not executing
|
|
because I have a space in front of my tab?!!" 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 in 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><exec></code> task that
|
|
allows different commands to be executed based on the OS it is executing
|
|
on.</p>
|
|
|
|
</body>
|
|
</html>
|