Ant PDF

Download as pdf or txt
Download as pdf or txt
You are on page 1of 13

JAVA Means DURGASOFT

An Introduction to Ant

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
1
JAVA Means DURGASOFT

Index
Installing Ant
Ant Setup
Project Organization
Anatomy of a Build File
Projects
Build File
Properties
Build File with Properties
Targets
Build File with Targets
Tasks
Initialization Target & Tasks
Compilation Target & Tasks
Javadoc Target & Tasks
Cleanup Target & Tasks
Completed Build File (1 of 2)
Completed Build File (2 of 2)
Running Ant Command Line
Running Ant Eclipse

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
2
JAVA Means DURGASOFT

What is Ant?

Ant is a Java based tool for automating the buildprocess


Similar to make but implemented using Java
Platform independent commands (works on Windows,Mac &Unix)
XML based format
Avoids the dreaded tab issue in make files
Easily extendable using Java classes
Ant is an open source (free) Apache project

Automating the Build (C & make)

The goal is to automate the build process

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
3
JAVA Means DURGASOFT

Installing Ant
Ant can be downloaded from http://ant.apache.org/
Ant comes bundled as a zip file or a tarball
Simply unwrap the file to some directorywhere you want to store the executables
I typically unwrap the zip file into C:\ProgramFiles, and rename to C:\Program Files\ant\
This directory is known as ANT_HOME

Ant Setup

Set the ANT_HOME environment variable towhere you installed Ant


Add the ANT_HOME/bin directory to your path
Set the JAVA_HOME environment variable tothe location where you installed Java
Setting environment variables
Windows: right click My Computer Properties Advanced Environment Variables
UNIX: shell specific settings

Project Organization

The following example assumes that yourworkspace will be organized like so

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
4
JAVA Means DURGASOFT

Anatomy of a Build File

Ants build files are written in XML


Convention is to call file build.xml
Each build file contains
A project
At least 1 target
Targets are composed of some number of tasks
Build files may also contain properties
Like macros in a make file
Comments are within <!-- --> blocks

Projects

The project tag is used to define theproject you wish to work with
Projects tags typically contain 3 attributes
name a logical name for the project
default the default target to execute
basedir the base directory for which alloperations are done relative to
Additionally, a description for the projectcan be specified from within the project tag

Build File

<project name="Sample Project" default="compile" basedir=".">


<description>
A sample build file for this project
</description>
</project>

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
5
JAVA Means DURGASOFT

Properties

Build files may contain constants (knownas properties) to assign a value to avariable which
can then be usedthroughout the project
Makes maintaining large build files moremanageable
Projects can have a set of properties
Property tags consist of a name/value pair
Analogous to macros from make

Build File with Properties

<project name="Sample Project" default="compile" basedir=".">


<description>
A sample build file for this project
</description>
<!-- global properties for this build file -->
<property name="source.dir" location="src"/>
<property name="build.dir" location="bin"/>
<property name="doc.dir" location="doc"/>
</project>

Targets

The target tag has the following required attribute


name the logical name for a target
Targets may also have optional attributes such as
depends a list of other target names for which this task is
dependant upon, the specified task(s) get executed first
description a description of what a target does
Like make files, targets in Ant can depend on some
number of other targets
For example, we might have a target to create a jarfile, which
first depends upon another target to compile the code
A build file may additionally specify a default target

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
6
JAVA Means DURGASOFT

Build File with Targets

<project name="Sample Project" default="compile" basedir=".">


...
<!-- set up some directories used by this project -->
<target name="init" description="setup project directories">
</target>
<!-- Compile the java code in srcdir into build dir -->
<target name="compile" depends="init" description="compile java sources">
</target>
<!-- Generate javadocs for current project into docs dir -->
<target name="doc" depends="init" description="generate documentation">
</target>
<!-- Delete the build & doc directories and Emacs backup (*~) files -->
<target name="clean" description="tidy up the workspace">
</target>
</project>

Tasks

A task represents an action that needs execution


Tasks have a variable number of attributes which aretask dependant
There are a number of build-in tasks, most of which arethings which you would typically do
as part of a buildprocess
Create a directory
Compile java source code
Run the javadoc tool over some files
Create a jar file from a set of files
Remove files/directories
And many, many others
For a full list see: http://ant.apache.org/manual/coretasklist.html

Initialization Target & Tasks

Our initialization target creates the buildand documentation directories


The mkdir task creates a directory
<project name="Sample Project" default="compile" basedir=".">
...
<!-- set up some directories used by this project -->
<target name="init" description="setup project directories">
<mkdirdir="${build.dir}"/>
<mkdirdir="${doc.dir}"/>
</target>
...
</project>

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
7
JAVA Means DURGASOFT

Compilation Target & Tasks

Our compilation target will compile all javafiles in the source directory
The javac task compiles sources into classes
Note the dependence on the init task
<project name="Sample Project" default="compile" basedir=".">
...
<!-- Compile the java code in ${src.dir} into ${build.dir} -->
<target name="compile" depends="init" description="compile java sources">
<javacsrcdir="${source.dir}" destdir="${build.dir}"/>
</target>
...
</project>

Javadoc Target & Tasks

Our documentation target will create theHTML documentation


The javadoc task generates HTMLdocumentation for all sources
<project name="Sample Project" default="compile" basedir=".">
...
<!-- Generate javadocs for current project into ${doc.dir} -->
<target name="doc" depends="init" description="generate documentation">
<javadocsourcepath="${source.dir}" destdir="${doc.dir}"/>
</target>
...
</project>

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
8
JAVA Means DURGASOFT

Cleanup Target & Tasks

We can also use ant to tidy up ourworkspace


The delete task removes files/directories fromthe file system
<project name="Sample Project" default="compile" basedir=".">
...
<!-- Delete the build & doc directories and Emacs backup (*~) files -->
<target name="clean" description="tidy up the workspace">
<delete dir="${build.dir}"/>
<delete dir="${doc.dir}"/>
<delete>
<filesetdefaultexcludes="no" dir="${source.dir}" includes="**/*~"/>
</delete>
</target>
...
</project>

Completed Build File (1 of 2)

<project name="Sample Project" default="compile" basedir=".">


<description>
A sample build file for this project
</description>
<!-- global properties for this build file -->
<property name="source.dir" location="src"/>
<property name="build.dir" location="bin"/>
<property name="doc.dir" location="doc"/>
<!-- set up some directories used by this project -->
<target name="init" description="setup project directories">
<mkdirdir="${build.dir}"/>
<mkdirdir="${doc.dir}"/>
</target>
<!-- Compile the java code in ${src.dir} into ${build.dir} -->

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
9
JAVA Means DURGASOFT

<target name="compile" depends="init" description="compile java sources">


<javacsrcdir="${source.dir}" destdir="${build.dir}"/>
</target>

Completed Build File (2 of 2)

<!-- Generate javadocs for current project into ${doc.dir} -->


<target name="doc" depends="init" description="generate documentation">
<javadocsourcepath="${source.dir}" destdir="${doc.dir}"/>
</target>
<!-- Delete the build & doc directories and Emacs backup (*~) files -->
<target name="clean" description="tidy up the workspace">
<delete dir="${build.dir}"/>
<delete dir="${doc.dir}"/>
<delete>
<filesetdefaultexcludes="no" dir="${source.dir}" includes="**/*~"/>
</delete>
</target>
</project>

Running Ant Command Line

Simply cd into the directory with the build.xml file


and type ant to run the project default target
Or, type ant followed by the name of a target

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
10
JAVA Means DURGASOFT

Running Ant Eclipse

Eclipse comes with out of thebox support for Ant


No need to separatelydownload and configure Ant
Eclipse provides an Ant view
Window Show View Ant
Simply drag and drop a buildfile into the Ant view, thendouble click the target to run

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
11
JAVA Means DURGASOFT

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
12
JAVA Means DURGASOFT

DURGA SOFTWARE SOLUTIONS ,202 HUDA Maitrivanam, Ameerpet , Hyd. Ph: 040-64512786
13

You might also like