Welcome to the official Ivy documentation.
What is Ivy?
Ivy is a tool for managing (recording, tracking, resolving and reporting) project dependencies. It is characterized by the following:
flexibility and configurability - Ivy is essentially process agnostic and is not tied to any methodology or structure. Instead it provides the necessary flexibility and configurability to be adapted to a broad range of dependency management and build processes.
tight integration with Apache Ant - while available as a standalone tool, Ivy works particularly well with Apache Ant providing a number of powerful Ant tasks ranging from dependency resolution to dependency reporting and publication.
Ivy is open source and released under a very permissive [[license Apache License]]. Ivy has a lot of powerful [[features]], the most popular and useful being its flexibility, integration with ant, and its strong transitive dependencies management engine. The transitive dependencies management is a feature which let you get dependencies of your dependencies, transitively. In order to address this problematic ivy needs to find metadata about your modules, usually in an
ivy file
. To find these metadata and your dependencies artifacts (usually jars), Ivy can be configured to use a lot of different
repositories
.
About this doc
Tip: The menu on the left is dynamic, you can click on the arrows to browse the menu without going to each page.
This documentation has been migrated from the old Ivy web site hosted by Jayasoft, feel free to report any problem on the [[mailing-lists]]. If you browse this documentation from your installation of Ivy, you can also check the
online version
for latest updates. You can also browse this documentation offline either by downloading the documentation distribution, or by checking out the doc directory from svn. This documentation uses
xooki
as documentation engine, so you can very easily [[get-involved edit it and submit patches]] when you browse it from source. A
printer-friendly version
of this whole documentation is also provided for your convenience. Since Ivy [[history/2.0.0-alpha-2 2.0.0-alpha-2]], we keep an online history of the documentation. You can thus browse history versions online (in the history menu in the web site) and even check the trunk version documentation currently in development. For earlier versions, we suggest downloading the documentation to browse the documentation corresponding to the version you use. The full history of Ivy versions with corresponding links for download is available in the history menu on the web site.
Other places to go
Check Ivy [[features features]]. Read our [[faq FAQ]]. Ask for help on our [[mailing-lists mailing lists]]. Report bug or feature request in our [[issues issue tracking system]]. Check [[links external tools and resources]].
Overview
This documentation is decomposed in 3 main parts:
[[tutorial]]
The tutorials is the best way to begin to play with ivy. You will easily and quickly learn the basics of Ivy.
[[reference]]
The reference documentation gives you all the details of Ivy. The introduction part is particularly useful: it defines some vocabulary, explains main concepts such as dependency resolvers and patterns, and give an overview on how ivy works internally. It's also in the reference doc that you will find all you always dreamed to know about ivy configuration, ivy files, and ivy use (especially with ant).
[[dev]]
The developers's doc is useful for users who would like to extend Ivy or build it from source. It's also the documentation used by the Ivy team, so you will also find information about how we make releases.