Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Java manipulation of XML made easy
Java Other
Fetching latest commit...
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.


Introduction to the JDOM project

Please see the JDOM web site at
and GitHub repository at

Quick-Start for JDOM
See the github wiki for a Primer on using JDOM:

Also see the web site  It has links to
numerous articles and books covering JDOM.

Installing the build tools

The JDOM build system is based on Apache Ant.  Ant is a little but very
handy tool that uses a build file written in XML (build.xml) as building
instructions. For more information refer to "".

The only thing that you have to make sure of is that the "JAVA_HOME"
environment property is set to match the top level directory containing the
JVM you want to use. For example:

C:\> set JAVA_HOME=C:\jdk1.6

or on Mac:

% setenv JAVA_HOME /System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK/Home
> JAVA_HOME=/System/Library/Frameworks/JavaVM.framework/Versions/CurrentJDK/Home; export JAVA_HOME
  (ksh, bash)

or on Unix:

% setenv JAVA_HOME /usr/local/java
> JAVA_HOME=/usr/java; export JAVA_HOME
  (ksh, bash)

That's it!

Building instructions

If you do not have the full source code it can be cloned from GitHub. The JDOM
project at has the instructions and source
URL to make the git clone easy.

You will need to have Apache Ant 1.8.2 or later, and you will need Java JDK 1.6
or later.

Ok, let's build the code. First, make sure your current working directory is
where the build.xml file is located. Then run "ant".

If everything is right and all the required packages are visible, this action
will generate a file called "" in the
"./build/package" directory. This is the same 'zip' file that is distributed
as the official JDOM distribution.

The name of the zip file (and the jar names inside the zip) is controlled by
the two ant properties 'name' and 'version'. The package is called
"${name}-${version}.zip". The 'official' JDOM Build process is done by
creating a file '' in the 'top' folder of the JDOM code, and
it contains the single line (or whatever the appropriate version is):


If your favourite Java IDE happens to be Eclipse, you can run the 'eclipse' ant
target, and that will configure your Eclipse project to have all the right
'source' folders, and 'Referenced Libraries'. After running the 'ant eclipse'
target, you should refresh your Eclipse project, and you should have a project
with no errors or warnings.

Build targets

The build system is not only responsible for compiling JDOM into a jar file,
but is also responsible for creating the HTML documentation in the form of

These are the meaningful targets for this build file:

 - package [default] -> generates ./build/package/jdom*.zip
 - compile -> compiles the source code
 - javadoc -> generates the API documentation in ./build/javadocs
 - junit -> runs the JUnit tests
 - coverage -> generates test coverage metrics
 - eclipse -> generates an Eclipse project (source folders, jars, etc)
 - clean -> restores the distribution to its original and clean state
 - maven -> generates the package, and makes a 'bundle' for maven-central

To learn the details of what each target does, read the build.xml file.  It is
quite understandable.

Bug Reports

Bug reports go to the jdom-interest list at  But *BEFORE YOU POST*
make sure you've tested against the LATEST code available from GitHub (or the
daily snapshot).  Odds are good your bug has already been fixed.  If it hasn't
been fixed in the latest version, then when posting *BE SURE TO SAY* which
code version you tested against.  For example, "GitHub from October 3rd".  Also
be sure to include enough information to reproduce the bug and full exception
stack traces.  You might also want to read the FAQ at to find
out if your problem is not really a bug and just a common misunderstanding
about how XML or JDOM works.

Searching for Information

The JDOM mailing lists are archived and easily searched at
Something went wrong with that request. Please try again.