Developer guide for Jakarta Commons "Lang"

The Jakarta Commons Lang Package

Developers Guide

$Id$
[Introduction] [Package Structure] [Utility Classes] [Javadoc] [Building]

1. INTRODUCTION

The Lang package contains a set of Java classes that extend the basic JDK classes. This developers guide seeks to set out rules for the naming of classes and methods within the package. The purpose of this, as with all naming standards, is to improve the coherency and consistency of the whole API.

The philosophy of the naming standards is to follow those of the JDK if possible.

2. PACKAGE STRUCTURE

The main package for Lang is org.apache.commons.lang. Subpackages should be created for each group of related items.

Each package should have a package.html file for javadoc. This should describe the use of the package and its scope.

3. UTILITY CLASSES

Utility classes provide additional functionality around a class or interface. Examples include StringUtils and SerializationUtils.

Each class shall follow the naming pattern XxxUtils where Xxx relates to the class or interface that the utility services. Variations on a theme (Integer as opposed to Number) should be dealt with in one Utils class where possible. Each Utils class shall:

A utility class can act as a factory for specific implementations of a class or interface. In such cases the implementations should be non-public, static, inner classes of the utility class. However, if warranted due to maintenance or other reasons, these decorator classes may be moved to top-level classes in a subpackage. The naming of such a subpackage should be discussed and agreed upon on the developers mailing list.

If different overloaded variants of a method are desired, with the same method signature, it should not be indicated via a boolean argument, but via a more focused method name. Rather than replace(boolean repeat), replace and replaceAll, or replaceOnce and replace.

4. JAVADOC

The Sun javadoc guidelines are the starting point for Lang. These points are an extension to make it easier for users reading the generated docs and developers with javadoc-popup capabilities from within their IDE.

General

References to other objects, interfaces or methods use the @link-tag the first time it is referenced in a class or interface. On the following references always enclose it inside <code></code>.

References to null, this, long, int, short, char, byte, double, float and boolean should be enclosed in <code></code>.

Classes/Interfaces/Methods

Use a short description of what the class/interface/method is used for, enclose with <p></p>.

A longer description about what the class/interface/method is used for and if it is needed how it is done. If it is necessary include description of the parameters, what they are used for and how. Enclose with <p></p> where it is needed, try to divide into smaller parts (not to small!) to enhance readability of the generated Javadoc.

If an example is needed enclose it with <pre></pre>. It should be supported with an explanation within a normal paragraph.

Exception throwing

When throwing an exception to indicate a bad argument, always try to throw IllegalArgumentException, even if the argument was null. Do not throw NullPointerException. (Obviously, you should document what the code actually does!)

Deprecations

When deprecating a method or class include a clear reference to when the method will be deleted. This should be of the form 'Method will be removed in Commons Lang 3.0.'.

Language used in code/comments

It has been decided to casually standardize on US-English. To avoid misplaced jeers of 'americanisation', the people making this decision largely write in non-US-English. However, it's not something to get worked up about. Lots of spelling differences will creep in all over.

5.BUILDING

Site Generation

Site generation via maven includes Clover report generation. Since Clover requires a license, the proper license file must be placed where the maven Clover plugin can find it. This can be done as follows:

Building a Release

Commons Lang is intented to interoperate with Java version 1.2 and higher. To achieve this, the distribution must be built with JDK 1.2. Why? Over time the base JDK has changed. Building with JDK 1.4 would make some things in Commons Lang not run with prior libraries. For example, new StringBuffer(StringBuffer) was added after JDK1.2, but compiling under 1.4 could link to it. Run the code under 1.2 and you get a NoSuchMethodError.

To build a release, the distribution should be build with Ant using JDK 1.2. The Ant target dist-build in build.xml can be used to do this. The site can be build with Maven.

Ant 1.6 or higher is required for building the distribution due to the way the build.xml script invokes test cases. It uses the more modern <junit> optional Ant task, rather than the more messy technique of invoking Java with the <java> tag to run the test runner. For this to work, junit.jar must be copied to the Ant home library directory.