ebook img

Apache Ant User Manual - Computer Science - Tech Support PDF

670 Pages·2010·2.07 MB·English
by  
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Apache Ant User Manual - Computer Science - Tech Support

Table of Contents Introduction Installing Ant Using Ant Apache Ant 1.8.1 Manual Running Ant Ant Tasks Concepts and Types This is the manual for version 1.8.1 of Apache Ant. If your version of Ant (as verified Loggers & Listeners with ) is older or newer than this version then this is not the correct Editor/IDE Integration ant -version manual set. Please use the documentation appropriate to your current version. Also, if Developing with Ant you are using a version older than the most recent release, we recommend an upgrade Tutorials to fix bugs as well as provide new functionality. Ant API License Feedback and Troubleshooting Authors Introduction Apache Ant is a Java-based build tool. In theory, it is kind of like make, without make's wrinkles. Why? Why another build tool when there is already make, gnumake, nmake, jam, 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. 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. 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. Granted, this removes some of the expressive power that is inherent in being able to construct a shell command such as , but it gives you the ability to be cross-platform--to work anywhere and `find . -name foo -exec rm {}` everywhere. And hey, if you really need to execute a shell command, Ant has an task that allows different <exec> commands to be executed based on the OS it is executing on. Table of Contents Installing Ant Getting Ant System Requirements Installing Ant Check Installation Building Ant Library Dependencies Platform Specific Issues Proxy configuration Table of Contents Using Ant Writing a Simple Buildfile Projects Targets Tasks Properties Built-in Properties Property Helpers Example Buildfile Token Filters Path-like Structures Command-line Arguments References Use of external tasks Table of Contents Running Ant Command Line Options Library Directories Files Environment Variables Java System Properties Cygwin Users OS/2 Users Running "in the background" Running Ant via Java Table of Contents Ant Tasks Overview of Ant Tasks Core Tasks Optional Tasks Library Dependencies Table of Contents Concepts Targets and Extension-Points Properties and PropertyHelpers ant.build.clonevm build.sysclasspath Ant properties controlling javac Common Attributes Core Types Description Type Directory-based Tasks DirSet FileList FileSet File Mappers FilterChains and FilterReaders FilterSet PatternSet Path-like Structures Permissions PropertySet I/O Redirectors Regexp Resources Resource Collections Selectors TarFileSet XMLCatalog ZipFileSet Optional Types Class Fileset Extension Package Set of Extension Packages Namespace Namespace Support Antlib Antlib Antlib namespace Current namespace Custom Components Custom Components Conditions Selectors FilterReaders Listeners & Loggers Overview Ant has two related features to allow the build process to be monitored: listeners and loggers. Listeners A listener is alerted of the following events: build started build finished target started target finished task started task finished message logged These are used internally for various recording and housekeeping operations, however new listeners may registered on the command line through the argument. -listener Loggers Loggers extend the capabilities of listeners and add the following features: Receives a handle to the standard output and error print streams and therefore can log information to the console or the specified file. -logfile Logging level (-quiet, -verbose, -debug) aware Emacs-mode aware Built-in Listeners/Loggers Classname Description Type The logger used implicitly unless overridden with the BuildLogger org.apache.tools.ant.DefaultLogger - command-line switch. logger This logger omits output of BuildLogger org.apache.tools.ant.NoBannerLogger empty target output. Extends DefaultLogger such that output is still generated the same, and when the build BuildLogger org.apache.tools.ant.listener.MailLogger is finished an e-mail can be sent. Colorifies the build output. BuildLogger org.apache.tools.ant.listener.AnsiColorLogger Passes events to Log4j for BuildListener org.apache.tools.ant.listener.Log4jListener highly customizable logging. Writes the build information BuildLogger org.apache.tools.ant.XmlLogger to an XML file. Prints the time that a build BuildLogger org.apache.tools.ant.TimestampedLogger finished Prints the project name every BuildLogger org.apache.tools.ant.listener.BigProjectLogger target The default logger, with start times, end times and BuildLogger org.apache.tools.ant.listener.ProfileLogger durations added for each task and target. DefaultLogger Simply run Ant normally, or: ant -logger org.apache.tools.ant.DefaultLogger NoBannerLogger Removes output of empty target output. ant -logger org.apache.tools.ant.NoBannerLogger MailLogger The MailLogger captures all output logged through DefaultLogger (standard Ant output) and will send success and failure messages to unique e-mail lists, with control for turning off success or failure messages individually. Properties controlling the operation of MailLogger: Property Description Required MailLogger.mailhost Mail server to use No, default "localhost" MailLogger.port SMTP Port for the Mail server No, default "25" Yes, if SMTP auth is required on your SMTP server MailLogger.user user name for SMTP auth the email message will be then sent using Mime and requires JavaMail Yes, if SMTP auth is required on your SMTP server MailLogger.password password for SMTP auth the email message will be then sent using Mime and requires JavaMail on or true if ssl is needed MailLogger.ssl no This feature requires JavaMail MailLogger.from Mail "from" address Yes, if mail needs to be sent MailLogger.replyto Mail "replyto" address(es), comma-separated No MailLogger.failure.notify Send build failure e-mails? No, default "true" MailLogger.success.notify Send build success e-mails? No, default "true"

Description:
Table of Contents Introduction Installing Ant Using Ant Running Ant Ant Tasks Concepts and Types Loggers & Listeners Editor/IDE Integration Developing with Ant
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.