Javadoc formatting patch, by Fredrik Westermarck

git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/lang/trunk@137133 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Stephen Colebourne 2002-11-16 10:41:03 +00:00
parent c248c060c6
commit 7477a1e08f
15 changed files with 1024 additions and 763 deletions

View File

@ -59,13 +59,13 @@ import java.util.Map;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;
/**
* <code>ArrayUtils</code> contains utility methods for working for
* arrays.
* <p><code>ArrayUtils</code> contains utility methods for working for
* arrays.</p>
*
* @author <a href="mailto:scolebourne@apache.org">Stephen Colebourne</a>
* @author Moritz Petersen
* @author <a href="mailto:fredrik@westermarck.com">Fredrik Westermarck</a>
* @version $Id: ArrayUtils.java,v 1.3 2002/11/15 00:25:45 scolebourne Exp $
* @version $Id: ArrayUtils.java,v 1.4 2002/11/16 10:41:03 scolebourne Exp $
*/
public class ArrayUtils {
@ -91,10 +91,11 @@ public class ArrayUtils {
public static final boolean[] EMPTY_BOOLEAN_ARRAY = new boolean[0];
/**
* ArrayUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>ArrayUtils.clone(new int[] {2})</code>.
* This constructor is public to permit tools that require a JavaBean instance
* to operate.
* <p>ArrayUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>ArrayUtils.clone(new int[] {2})</code>.</p>
*
* <p>This constructor is public to permit tools that require a JavaBean instance
* to operate.</p>
*/
public ArrayUtils() {
}
@ -102,11 +103,12 @@ public class ArrayUtils {
//--------------------------------------------------------------------------
/**
* Outputs an array as a String, treating <code>null</code> as an empty array.
* <p>
* Multi-dimensional arrays are handled correctly, including
* multi-dimensional primitive arrays.
* The format is that of Java source code, for example {a,b}.
* <p>Outputs an array as a String, treating <code>null</code> as an empty array.</p>
*
* <p>Multi-dimensional arrays are handled correctly, including
* multi-dimensional primitive arrays.</p>
*
* <p>The format is that of Java source code, for example {a,b}.</p>
*
* @param array the array to get a toString for, may not be <code>null</code>
* @return a String representation of the array, '{}' if <code>null</code> passed in
@ -116,11 +118,12 @@ public class ArrayUtils {
}
/**
* Outputs an array as a String handling <code>null</code>s.
* <p>
* Multi-dimensional arrays are handled correctly, including
* multi-dimensional primitive arrays.
* The format is that of Java source code, for example {a,b}.
* <p>Outputs an array as a String handling <code>null</code>s.</p>
*
* <p>Multi-dimensional arrays are handled correctly, including
* multi-dimensional primitive arrays.</p>
*
* <p>The format is that of Java source code, for example {a,b}.</p>
*
* @param array the array to get a toString for, may be <code>null</code>
* @param stringIfNull the String to return if the array is <code>null</code>
@ -134,11 +137,12 @@ public class ArrayUtils {
}
/**
* Converts the given array into a {@link Map}. Each element of the array
* <p>Converts the given array into a {@link Map}. Each element of the array
* must be either a {@link Map.Entry} or an Array, containing at least two
* elements, where the first element is used as key and the second as
* value. This method can be used to initialize:
* value.</p>
*
* <p>This method can be used to initialize:</p>
* <pre>
* // Create a Map mapping colors.
* Map colorMap = MapUtils.toMap(new String[][] {{
@ -149,7 +153,7 @@ public class ArrayUtils {
*
* @param array an array whose elements are either a {@link Map.Entry} or
* an Array containing at least two elements
* @return a Map that was created from the array
* @return a <code>Map</code> that was created from the array
* @throws IllegalArgumentException if the array is <code>null</code>
* @throws IllegalArgumentException if one element of this Array is
* itself an Array containing less then two elements
@ -184,10 +188,11 @@ public class ArrayUtils {
}
// /**
// * Output the array as a String.
// * <p>
// * Multi-dimensional arrays are handled by the Object[] method.
// * The format is that of Java source code, for example {1,2}.
// * <p>Output the array as a String.</p>
// *
// * <p>Multi-dimensional arrays are handled by the Object[] method.</p>
// *
// * <p>The format is that of Java source code, for example {1,2}.</p>
// *
// * @param array the array to get a toString for, must not be <code>null</code>
// * @return a String representation of the array
@ -198,10 +203,11 @@ public class ArrayUtils {
// }
//
// /**
// * Output the array as a String.
// * <p>
// * Multi-dimensional arrays are handled by the Object[] method.
// * The format is that of Java source code, for example {1,2}.
// * <p>Output the array as a String.</p>
// *
// * <p>Multi-dimensional arrays are handled by the Object[] method.</p>
// *
// * <p>The format is that of Java source code, for example {1,2}.</p>
// *
// * @param array the array to get a toString for, must not be <code>null</code>
// * @return a String representation of the array
@ -212,10 +218,11 @@ public class ArrayUtils {
// }
//
// /**
// * Output the array as a String.
// * <p>
// * Multi-dimensional arrays are handled by the Object[] method.
// * The format is that of Java source code, for example {1,2}.
// * <p>Output the array as a String.</p>
// *
// * <p>Multi-dimensional arrays are handled by the Object[] method.</p>
// *
// * <p>The format is that of Java source code, for example {1,2}.</p>
// *
// * @param array the array to get a toString for, must not be <code>null</code>
// * @return a String representation of the array
@ -226,10 +233,11 @@ public class ArrayUtils {
// }
//
// /**
// * Output the array as a String.
// * <p>
// * Multi-dimensional arrays are handled by the Object[] method.
// * The format is that of Java source code, for example {1,2}.
// * <p>Output the array as a String.</p>
// *
// * <p>Multi-dimensional arrays are handled by the Object[] method.</p>
// *
// * <p>The format is that of Java source code, for example {1,2}.</p>
// *
// * @param array the array to get a toString for, must not be <code>null</code>
// * @return a String representation of the array
@ -240,10 +248,11 @@ public class ArrayUtils {
// }
//
// /**
// * Output the array as a String.
// * <p>
// * Multi-dimensional arrays are handled by the Object[] method.
// * The format is that of Java source code, for example {1.0,2.0}.
// * <p>Output the array as a String.</p>
// *
// * <p>Multi-dimensional arrays are handled by the Object[] method.</p>
// *
// * <p>The format is that of Java source code, for example {1.0,2.0}.</p>
// *
// * @param array the array to get a toString for, must not be <code>null</code>
// * @return a String representation of the array
@ -254,10 +263,11 @@ public class ArrayUtils {
// }
//
// /**
// * Output the array as a String.
// * <p>
// * Multi-dimensional arrays are handled by the Object[] method.
// * The format is that of Java source code, for example {1.0,2.0}.
// * <p>Output the array as a String.</p>
// *
// * <p>Multi-dimensional arrays are handled by the Object[] method.</p>
// *
// * <p>The format is that of Java source code, for example {1.0,2.0}.</p>
// *
// * @param array the array to get a toString for, must not be <code>null</code>
// * @return a String representation of the array
@ -268,10 +278,11 @@ public class ArrayUtils {
// }
//
// /**
// * Output the array as a String.
// * <p>
// * Multi-dimensional arrays are handled by the Object[] method.
// * The format is that of Java source code, for example {true,false}.
// * <p>Output the array as a String.</p>
// *
// * <p>Multi-dimensional arrays are handled by the Object[] method.</p>
// *
// * <p>The format is that of Java source code, for example {true,false}.</p>
// *
// * @param array the array to get a toString for, must not be <code>null</code>
// * @return a String representation of the array
@ -284,12 +295,14 @@ public class ArrayUtils {
//--------------------------------------------------------------------------
/**
* Shallow clones an array returning a typecast result and handling <code>null</code>.
* <p>
* The objecs in the array are not cloned.
* <p>Shallow clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* <p>The objecs in the array are not cloned.</p>
*
* @param array the array to shallow clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static Object[] clone(Object[] array) {
if (array == null) {
@ -299,10 +312,12 @@ public class ArrayUtils {
}
/**
* Clones an array returning a typecast result and handling <code>null</code>.
* <p>Clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* @param array the array to clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static long[] clone(long[] array) {
if (array == null) {
@ -312,10 +327,12 @@ public class ArrayUtils {
}
/**
* Clones an array returning a typecast result and handling <code>null</code>.
* <p>Clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* @param array the array to clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static int[] clone(int[] array) {
if (array == null) {
@ -325,10 +342,12 @@ public class ArrayUtils {
}
/**
* Clones an array returning a typecast result and handling <code>null</code>.
* <p>Clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* @param array the array to clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static short[] clone(short[] array) {
if (array == null) {
@ -338,10 +357,12 @@ public class ArrayUtils {
}
/**
* Clones an array returning a typecast result and handling <code>null</code>.
* <p>Clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* @param array the array to clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static byte[] clone(byte[] array) {
if (array == null) {
@ -351,10 +372,12 @@ public class ArrayUtils {
}
/**
* Clones an array returning a typecast result and handling <code>null</code>.
* <p>Clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* @param array the array to clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static double[] clone(double[] array) {
if (array == null) {
@ -364,10 +387,12 @@ public class ArrayUtils {
}
/**
* Clones an array returning a typecast result and handling <code>null</code>.
* <p>Clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* @param array the array to clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static float[] clone(float[] array) {
if (array == null) {
@ -377,10 +402,12 @@ public class ArrayUtils {
}
/**
* Clones an array returning a typecast result and handling <code>null</code>.
* <p>Clones an array returning a typecast result and handling
* <code>null</code>.</p>
*
* @param array the array to clone, may not be <code>null</code>
* @return the cloned array, or <code>null</code> if <code>null</code> passed in
* @return the cloned array, or <code>null</code> if <code>null</code>
* passed in
*/
public static boolean[] clone(boolean[] array) {
if (array == null) {
@ -392,9 +419,10 @@ public class ArrayUtils {
//--------------------------------------------------------------------------
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.
*
* <p>Any multi-dimensional aspects of the arrays are ignored.</p>
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -411,9 +439,10 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.</p>
*
* <p>Any multi-dimensional aspects of the arrays are ignored.</p>
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -430,9 +459,10 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.</p>
*
* <p>Any multi-dimensional aspects of the arrays are ignored.</p>
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -449,9 +479,10 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.</p>
*
* <p>Any multi-dimensional aspects of the arrays are ignored.</p>
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -468,9 +499,10 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.</p>
*
* <p>Any multi-dimensional aspects of the arrays are ignored.</p>
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -487,9 +519,10 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.</p>
*
* <p>Any multi-dimensional aspects of the arrays are ignored.</p>
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -506,9 +539,10 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.</p>
*
* <p>Any multi-dimensional aspects of the arrays are ignored</p>.
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -525,9 +559,10 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same length, treating <code>null</code>
* arrays as length 0.
* Any multi-dimensional aspects of the arrays are ignored.
* <p>Checks whether two arrays are the same length, treating
* <code>null</code> arrays as length <code>0</code>.</p>
*
* <p>Any multi-dimensional aspects of the arrays are ignored.</p>
*
* @param array1 the first array, may be <code>null</code>
* @param array2 the second array, may be <code>null</code>
@ -544,8 +579,8 @@ public class ArrayUtils {
}
/**
* Checks whether two arrays are the same type taking into account
* multi-dimensional arrays.
* <p>Checks whether two arrays are the same type taking into account
* multi-dimensional arrays.</p>
*
* @param array1 the first array, must not be <code>null</code>
* @param array2 the second array, must not be <code>null</code>

View File

@ -55,13 +55,14 @@ package org.apache.commons.lang;
*/
/**
* A range of characters. Able to understand the idea of a contiguous
* sublist of an alphabet, a negated concept, and a set of characters.
* Used by CharSet to handle sets of characters.
* <p>A range of characters. Able to understand the idea of a contiguous
* sublist of an alphabet, a negated concept, and a set of characters.</p>
*
* <p>Used by <code>CharSet</code> to handle sets of characters.</p>
*
* @author <a href="bayard@generationjava.com">Henri Yandell</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Id: CharRange.java,v 1.1 2002/07/19 03:35:54 bayard Exp $
* @version $Id: CharRange.java,v 1.2 2002/11/16 10:41:03 scolebourne Exp $
*/
class CharRange {
@ -75,7 +76,7 @@ class CharRange {
private boolean negated;
/**
* Construct a CharRange over a single character.
* <p>Construct a <code>CharRange</code> over a single character.</p>
*
* @param start char over which this range is placed
*/
@ -84,7 +85,7 @@ class CharRange {
}
/**
* Construct a CharRange over a set of characters.
* <p>Construct a <code>CharRange</code> over a set of characters.</p>
*
* @param start char start character in this range. inclusive
* @param close char close character in this range. inclusive
@ -95,11 +96,11 @@ class CharRange {
}
/**
* Construct a CharRange over a set of characters.
* <p>Construct a <code>CharRange</code> over a set of characters.</p>
*
* @param start String start first character is in this range (inclusive).
* @param close String first character is close character in this
* range (inclusive).
* range (inclusive).
*/
public CharRange(String start, String close) {
this.start = start.charAt(0);
@ -107,7 +108,7 @@ class CharRange {
}
/**
* Get the start character for this character range
* <p>Get the start character for this character range.</p>
*
* @return start char (inclusive)
*/
@ -116,7 +117,7 @@ class CharRange {
}
/**
* Get the end character for this character range
* <p>Get the end character for this character range.</p>
*
* @return end char (inclusive)
*/
@ -125,7 +126,7 @@ class CharRange {
}
/**
* Set the start character for this character range
* <p>Set the start character for this character range.</p>
*
* @param ch start char (inclusive)
*/
@ -134,7 +135,7 @@ class CharRange {
}
/**
* Set the end character for this character range
* <p>Set the end character for this character range.</p>
*
* @param ch start char (inclusive)
*/
@ -143,18 +144,19 @@ class CharRange {
}
/**
* Is this CharRange over many characters
* <p>Is this <code>CharRange</code> over many characters.</p>
*
* @return boolean true is many characters
* @return boolean <code>true</code> is many characters
*/
public boolean isRange() {
return this.close != UNSET;
}
/**
* Is the passed in character inside this range
* <p>Is the passed in character <code>ch</code> inside
* this range.</p>
*
* @return boolean true is in range
* @return boolean <code>true</code> is in range
*/
public boolean inRange(char ch) {
if(isRange()) {
@ -165,27 +167,28 @@ class CharRange {
}
/**
* Checks if this CharRange is negated.
* <p>Checks if this <code>CharRange</code> is negated.</p>
*
* @return boolean true is negated
* @return boolean <code>true</code> is negated
*/
public boolean isNegated() {
return negated;
}
/**
* Sets this character range to be negated or not.
* This implies that this CharRange is over all characters except
* the ones in this range.
* <p>Sets this character range to be negated or not.</p>
*
* @param negated true to negate the range
* <p>This implies that this <code>CharRange</code> is over
* all characters except the ones in this range.</p>
*
* @param negated <code>true</code> to negate the range
*/
public void setNegated(boolean negated) {
this.negated = negated;
}
/**
* Output a string representation of the character range
* <p>Output a string representation of the character range.</p>
*
* @return string representation
*/

View File

@ -59,21 +59,25 @@ import java.util.LinkedList;
import java.util.List;
/**
* A set of characters. You can iterate over the characters in the
* set.
* <p>A set of characters. You can iterate over the characters in the
* set.</p>
*
* @author <a href="bayard@generationjava.com">Henri Yandell</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Id: CharSet.java,v 1.5 2002/10/09 04:35:03 sullis Exp $
* @version $Id: CharSet.java,v 1.6 2002/11/16 10:41:03 scolebourne Exp $
*/
public class CharSet {
private List set = new LinkedList();
/**
* Restricted constructor. Use the factory method evaluateSet().
* <p>Restricted constructor.</p>
*
* @throws NullPointerException if any of set[i] is null or if set is null
* <p>Use the factory method
* {@link CharSetUtils#evaluateSet(java.lang.String[])}.</p>
*
* @throws NullPointerException if any of set[i] is <code>null</code>
* or if set is <code>null</code>
*/
protected CharSet(String[] set) {
int sz = set.length;
@ -83,10 +87,12 @@ public class CharSet {
}
/**
* Does the set contain the character specified
* <p>Does the <code>CharSet</code> contain the specified
* character <code>ch</code>.</p>
*
* @param ch the character to check for
* @return true if it does contain it
* @return <code>true</code> if it does contain the character
* <code>ch</code>
*/
public boolean contains(char ch) {
Iterator iterator = set.iterator();
@ -107,10 +113,10 @@ public class CharSet {
}
/**
* Add a set definition string to the set
* <p>Add a set definition string to the <code>CharSet</code>.</p>
*
* @param str set definition string
* @throws NullPointerException if str is null
* @throws NullPointerException if <code>str</code> is <code>null</code>
*/
protected void add(String str) {
int sz = str.length();
@ -145,7 +151,7 @@ public class CharSet {
}
/**
* Returns a string representation of the set
* <p>Returns a string representation of the set.</p>
*
* @return string representation
*/

View File

@ -55,46 +55,52 @@ package org.apache.commons.lang;
*/
/**
* Numerous routines to manipulate a character set.
* <p>Numerous routines to manipulate a <code>CharSet</code>.</p>
*
* @author <a href="bayard@generationjava.com">Henri Yandell</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Id: CharSetUtils.java,v 1.6 2002/09/29 08:20:52 bayard Exp $
* @version $Id: CharSetUtils.java,v 1.7 2002/11/16 10:41:03 scolebourne Exp $
*/
public class CharSetUtils {
/**
* CharSetUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>CharSetUtils.evaluateSet(null);</code>.
* This constructor is public to permit tools that require a JavaBean instance
* to operate.
* <p>CharSetUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>CharSetUtils.evaluateSet(null);</code>.</p>
*
* <p>This constructor is public to permit tools that require a JavaBean instance
* to operate.</p>
*/
public CharSetUtils() {
}
/**
* Creates a CharSetUtils object which allows a certain amount of
* set logic to be performed upon the following syntax:
* <p>Creates a CharSetUtils object which allows a certain amount of
* set logic to be performed upon the following syntax:</p>
*
* <ul>
* <li>"aeio" which implies 'a','e',..
* <li>"^e" implies not e. However it only negates, it's not
* a set in itself due to the size of that set in unicode.
* <li>"ej-m" implies e,j->m. e,j,k,l,m.
* </ul>
*
* "aeio" which implies 'a','e',..
* "^e" implies not e. However it only negates, it's not
* a set in itself due to the size of that set in unicode.
* "ej-m" implies e,j->m. e,j,k,l,m.
* @param set
* @return CharSet
* @throws NullPointerException if any of set[i] is null or if set is null
* @param set
* @return CharSet
*/
public static CharSet evaluateSet(String[] set) {
return new CharSet(set);
}
/**
* Squeezes any repititions of a character that is mentioned in the
* supplied set. An example is:
* squeeze("hello", "el") => "helo"
* See evaluateSet for set-syntax.
* <p>Squeezes any repititions of a character that is mentioned in the
* supplied set.</p>
*
* <p>An example is:</p>
* <ul>
* <li>squeeze("hello", "el") => "helo"
* </ul>
* @see #evaluateSet(java.lang.String[]) for set-syntax.
*
* @param str the string to work from
* @param set the character set to use for manipulation
@ -106,14 +112,19 @@ public class CharSetUtils {
}
/**
* Squeezes any repititions of a character that is mentioned in the
* supplied set. An example is:
* squeeze("hello", {"el"}) => "helo"
* See evaluateSet for set-syntax.
* <p>Squeezes any repititions of a character that is mentioned in the
* supplied set.</p>
*
* <p>An example is:</p>
* <ul>
* <li>squeeze("hello", {"el"}) => "helo"
* </ul>
* @see #evaluateSet(java.lang.String[]) for set-syntax.
*
* @param str the string to work from
* @param set the character set to use for manipulation
* @throws NullPointerException if str is null
* @throws NullPointerException if <code>str</code> is
* <code>null</code>
*/
public static String squeeze(String str, String[] set) {
CharSet chars = evaluateSet(set);
@ -136,9 +147,13 @@ public class CharSetUtils {
}
/**
* Takes an argument in set-syntax, see evaluateSet,
* and returns the number of characters present in the specified string.
* An example would be: count("hello", {"c-f","o"}) returns 2.
* <p>Takes an argument in set-syntax, see evaluateSet,
* and returns the number of characters present in the specified string.</p>
*
* <p>An example would be:</p>
* <ul>
* <li>count("hello", {"c-f","o"}) returns 2.
* </ul>
*
* @param str String target to count characters in
* @param set String set of characters to count
@ -150,9 +165,13 @@ public class CharSetUtils {
}
/**
* Takes an argument in set-syntax, see evaluateSet,
* and returns the number of characters present in the specified string.
* An example would be: count("hello", {"c-f","o"}) returns 2.
* <p>Takes an argument in set-syntax, see evaluateSet,
* and returns the number of characters present in the specified string.</p>
*
* An example would be:</p>
* <ul>
* <li>count("hello", {"c-f","o"}) returns 2.
* </ul>
*
* @param str String target to count characters in
* @param set String[] set of characters to count
@ -171,9 +190,13 @@ public class CharSetUtils {
}
/**
* Takes an argument in set-syntax, see evaluateSet,
* and deletes any of characters present in the specified string.
* An example would be: delete("hello", {"c-f","o"}) returns "hll"
* <p>Takes an argument in set-syntax, see evaluateSet,
* and deletes any of characters present in the specified string.</p>
*
* <p>An example would be:</p>
* <ul>
* <li>delete("hello", {"c-f","o"}) returns "hll"
* </ul>
*
* @param str String target to delete characters from
* @param set String set of characters to delete
@ -185,13 +208,18 @@ public class CharSetUtils {
}
/**
* Takes an argument in set-syntax, see evaluateSet,
* and deletes any of characters present in the specified string.
* An example would be: delete("hello", {"c-f","o"}) returns "hll"
* <p>Takes an argument in set-syntax, see evaluateSet,
* and deletes any of characters present in the specified string.</p>
*
* <p>An example would be:</p>
* <ul>
* <li>delete("hello", {"c-f","o"}) returns "hll"
* </ul>
*
* @param str String target to delete characters from
* @param set String[] set of characters to delete
* @throws NullPointerException of str is null
* @throws NullPointerException of <code>str</code> is
* <code>null</code>
*/
public static String delete(String str, String[] set) {
CharSet chars = evaluateSet(set);
@ -207,16 +235,22 @@ public class CharSetUtils {
}
/**
* Translate characters in a String.
* An example is: translate("hello", "ho", "jy") => jelly
* If the length of characters to search for is greater than the
* length of characters to replace, then the last character is
* used.
* <p>Translate characters in a String.</p>
*
* @param target String to replace characters in
* <p>An example is:</p>
* <ul>
* <li>translate("hello", "ho", "jy") => jelly
* </ul>
*
* <p>If the length of characters to search for is greater than the
* length of characters to replace, then the last character is
* used.</p>
*
* @param target String to replace characters in
* @param repl String to find that will be replaced
* @param with String to put into the target String
* @throws NullPointerException if target, with or repl is null
* @throws NullPointerException if <code>target</code>, with
* or <code>repl</code> is <code>null</code>
*/
public static String translate(String target, String repl, String with) {
StringBuffer buffer = new StringBuffer(target.length());

View File

@ -57,19 +57,21 @@ import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/**
* <code>ClassUtils</code> contains utility methods for working for
* classes without using reflection.
* <p><code>ClassUtils</code> contains utility methods for working for
* classes without using reflection.</p>
*
* @author <a href="mailto:scolebourne@apache.org">Stephen Colebourne</a>
* @version $Id: ClassUtils.java,v 1.4 2002/11/14 22:29:25 scolebourne Exp $
* @version $Id: ClassUtils.java,v 1.5 2002/11/16 10:41:03 scolebourne Exp $
*/
public class ClassUtils {
/**
* ClassUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>ClassUtils.getShortClassName(cls)</code>.
* This constructor is public to permit tools that require a JavaBean instance
* to operate.
* <p>ClassUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as
* <code>ClassUtils.getShortClassName(cls)</code>.</p>
*
* <p>This constructor is public to permit tools that require a JavaBean
* instance to operate.</p>
*/
public ClassUtils() {
}
@ -77,9 +79,11 @@ public class ClassUtils {
// -------------------------------------------------------------------------
/**
* Gets the class name minus the package name from a Class.
* <p>Gets the class name minus the package name from a
* <code>Class</code>.</p>
*
* @param cls the class to get the short name for, must not be <code>null</code>
* @param cls the class to get the short name for, must not be
* <code>null</code>
* @return the class name without the package name
* @throws IllegalArgumentException if the class is <code>null</code>
*/
@ -91,9 +95,11 @@ public class ClassUtils {
}
/**
* Gets the class name minus the package name for an Object.
* <p>Gets the class name minus the package name for an
* <code>Object</code>.</p>
*
* @param object the class to get the short name for, must not be <code>null</code>
* @param object the class to get the short name for, must not be
* <code>null</code>
* @return the class name of the object without the package name
* @throws IllegalArgumentException if the object is <code>null</code>
*/
@ -105,9 +111,9 @@ public class ClassUtils {
}
/**
* Gets the class name minus the package name from a String.
* <p>
* The string passed in is assumed to be a class name - it is not checked.
* <p>Gets the class name minus the package name from a String.</p>
*
* <p>The string passed in is assumed to be a class name - it is not checked.</p>
*
* @param className the className to get the short name for, must not be empty
* @return the class name of the class without the package name
@ -132,9 +138,10 @@ public class ClassUtils {
// -------------------------------------------------------------------------
/**
* Gets the package name of a Class.
* <p>Gets the package name of a <code>Class</code>.</p>
*
* @param cls the class to get the package name for, must not be <code>null</code>
* @param cls the class to get the package name for, must not be
* <code>null</code>
* @return the package name
* @throws IllegalArgumentException if the class is <code>null</code>
*/
@ -146,9 +153,10 @@ public class ClassUtils {
}
/**
* Gets the package name of an Object.
* <p>Gets the package name of an <code>Object</code>.</p>
*
* @param object the class to get the package name for, must not be <code>null</code>
* @param object the class to get the package name for, must not be
* <code>null</code>
* @return the package name
* @throws IllegalArgumentException if the object is <code>null</code>
*/
@ -160,9 +168,9 @@ public class ClassUtils {
}
/**
* Gets the package name from a String.
* <p>
* The string passed in is assumed to be a class name - it is not checked.
* <p>Gets the package name from a <code>String</code>.</p>
*
* <p>The string passed in is assumed to be a class name - it is not checked.</p>
*
* @param className the className to get the package name for, must not be empty
* @return the package name
@ -182,10 +190,10 @@ public class ClassUtils {
// -------------------------------------------------------------------------
/**
* Gets a list of superclasses for the given class.
* <p>Gets a <code>List</code> of superclasses for the given class.</p>
*
* @param cls the class to look up, must not be <code>null</code>
* @return the list of superclasses in order going up from this one
* @return the <code>List</code> of superclasses in order going up from this one
* @throws IllegalArgumentException if the class is <code>null</code>
*/
public static List getAllSuperclasses(Class cls) {
@ -202,14 +210,15 @@ public class ClassUtils {
}
/**
* Gets a list of all interfaces implemented by the given class.
* <p>
* The order is determined by looking through each interface in turn as
* <p>Gets a <code>List</code> of all interfaces implemented by the given
* class.</p>
*
* <p>The order is determined by looking through each interface in turn as
* declared in the source file and following its hieracrchy up. Later
* duplicates are ignored, so the order is maintained.
* duplicates are ignored, so the order is maintained.</p>
*
* @param cls the class to look up, must not be <code>null</code>
* @return the list of interfaces in order
* @return the <code>List</code> of interfaces in order
* @throws IllegalArgumentException if the class is <code>null</code>
*/
public static List getAllInterfaces(Class cls) {
@ -234,14 +243,14 @@ public class ClassUtils {
}
// /**
// * Gets a list of subclasses of the specified class.
// * <p>
// * This method searches the classpath to find all the subclasses
// * <p>Gets a <code>List</code> of subclasses of the specified class.</p>
// *
// * <p>This method searches the classpath to find all the subclasses
// * of a particular class available. No classes are loaded, the
// * returned list contains class names, not classes.
// * returned list contains class names, not classes.</p>
// *
// * @param cls the class to find subclasses for
// * @return the list of subclass String class names
// * @return the <code>List</code> of subclass String class names
// * @throws IllegalArgumentException if the class is <code>null</code>
// */
// public static List getAllSubclassNames(Class cls) {
@ -253,13 +262,13 @@ public class ClassUtils {
// }
// /**
// * Gets a list of subclasses of the specified class.
// * <p>
// * This method searches the classpath to find all the subclasses
// * of a particular class available.
// * <p>Gets a <code>List</code> of subclasses of the specified class.</p>
// *
// * <p>This method searches the classpath to find all the subclasses
// * of a particular class available.</p>
// *
// * @param cls the class to find subclasses for
// * @return the list of subclasses
// * @return the <code>List</code> of subclasses
// * @throws IllegalArgumentException if the class is <code>null</code>
// */
// public static List getAllSubclasses(Class cls) {
@ -268,14 +277,14 @@ public class ClassUtils {
// }
// /**
// * Gets a list of implementations of the specified interface.
// * <p>
// * This method searches the classpath to find all the implementations
// * <p>Gets a <code>List</code> of implementations of the specified interface.</p>
// *
// * <p>This method searches the classpath to find all the implementations
// * of a particular interface available. No classes are loaded, the
// * returned list contains class names, not classes.
// * returned list contains class names, not classes.</p>
// *
// * @param cls the class to find sub classes for
// * @return the list of implementation String class names
// * @return the <code>List</code> of implementation String class names
// * @throws IllegalArgumentException if the class is <code>null</code>
// */
// public static List getAllImplementationClassNames(Class cls) {
@ -287,14 +296,15 @@ public class ClassUtils {
// }
/**
* Given a list of class names, this method converts them into classes.
* A new list is returned. If the class name cannot be found, <code>null</code>
* is stored in the list. If the class name in the list is <code>null</code>,
* <code>null</code> is stored in the output list.
* <p>Given a <code>List</code> of class names, this method converts them into classes. *
* A new <code>List</code> is returned. If the class name cannot be found, <code>null</code>
* is stored in the <code>List</code>. If the class name in the <code>List</code> is
* <code>null</code>, <code>null</code> is stored in the output <code>List</code>.</p>
*
* @param classNames the classNames to change, the class is stored back
* into the list. <code>null</code> will be stored in the list if no class is found.
* @return the list of Class objects corresponding to the class names
* into the <code>List</code>. <code>null</code> will be stored in the <code>List</code>
* if no class is found.
* @return the <code>List</code> of Class objects corresponding to the class names
* @throws IllegalArgumentException if the classNames is <code>null</code>
*/
public static List convertClassNamesToClasses(List classNames) {
@ -314,8 +324,8 @@ public class ClassUtils {
}
/**
* Given a list of classes, this method finds all those which are
* subclasses or implementations of a specified superclass.
* <p>Given a <code>List</code> of classes, this method finds all those which
* are subclasses or implementations of a specified superclass.</p>
*
* @param classes the classes to check
* @param superclass the superclass to check for
@ -344,30 +354,33 @@ public class ClassUtils {
}
/**
* Checks if an array of Classes can be assigned to another array of Classes.
* <p>
* This can be used to check if parameter types are suitably compatable for
* reflection invocation.
* <p>
* Unlike the Class.isAssignableFrom method, this method takes into
* account widenings of primitive classes and <code>null</code>s.
* <p>
* Primitive widenings allow an int to be assigned to a long, float or
* double. This method returns the correct result for these cases.
* <p>
* <code>Null</code> may be assigned to any reference type. This method will return
* true if <code>null</code> is passed in and the toClass is non-primitive.
* <p>
* Specifically, this method tests whether the type represented by the
* <p>Checks if an array of Classes can be assigned to another array of Classes.</p>
*
* <p>This can be used to check if parameter types are suitably compatable for
* reflection invocation.</p>
*
* <p>Unlike the {@link Class#isAssignableFrom(java.lang.Class)} method, this
* method takes into account widenings of primitive classes and
* <code>null</code>s.</p>
*
* <p>Primitive widenings allow an int to be assigned to a <code>long</code>,
* <code>float</code> or <code>double</code>. This method returns the correct
* result for these cases.</p>
*
* <p><code>Null</code> may be assigned to any reference type. This method will
* return <code>true</code> if <code>null</code> is passed in and the toClass is
* non-primitive.</p>
*
* <p>Specifically, this method tests whether the type represented by the
* specified <code>Class</code> parameter can be converted to the type
* represented by this <code>Class</code> object via an identity conversion
* widening primitive or widening reference conversion. See
* <em>The Java Language Specification</em>, sections 5.1.1, 5.1.2 and
* 5.1.4 for details.
* <em><a href="http://java.sun.com/docs/books/jls/">The Java Language Specification</a></em>,
* sections 5.1.1, 5.1.2 and 5.1.4 for details.</p>
*
* @param classArray the array of Classes to check, may be <code>null</code>
* @param toClassArray the array of Classes to try to assign into, may be <code>null</code>
* @return true if assignment possible
* @return <code>true</code> if assignment possible
*/
public static boolean isAssignable(Class[] classArray, Class[] toClassArray) {
if (ArrayUtils.isSameLength(classArray, toClassArray) == false) {
@ -388,27 +401,30 @@ public class ClassUtils {
}
/**
* Checks if one Class can be assigned to a variable of another Class.
* <p>
* Unlike the Class.isAssignableFrom method, this method takes into
* account widenings of primitive classes and <code>null</code>s.
* <p>
* Primitive widenings allow an int to be assigned to a long, float or
* double. This method returns the correct result for these cases.
* <p>
* Null may be assigned to any reference type. This method will return
* true if <code>null</code> is passed in and the toClass is non-primitive.
* <p>
* Specifically, this method tests whether the type represented by the
* <p>Checks if one <code>Class</code> can be assigned to a variable of
* another <code>Class</code>.</p>
*
* <p>Unlike the {@link Class#isAssignableFrom(java.lang.Class)} method,
* this method takes into account widenings of primitive classes and
* <code>null</code>s.</p>
*
* <p>Primitive widenings allow an int to be assigned to a long, float or
* double. This method returns the correct result for these cases.</p>
*
* <p><code>Null</code> may be assigned to any reference type. This method
* will return <code>true</code> if <code>null</code> is passed in and the
* toClass is non-primitive.</p>
*
* <p>Specifically, this method tests whether the type represented by the
* specified <code>Class</code> parameter can be converted to the type
* represented by this <code>Class</code> object via an identity conversion
* widening primitive or widening reference conversion. See
* <em>The Java Language Specification</em>, sections 5.1.1, 5.1.2 and
* 5.1.4 for details.
* <em><a href="http://java.sun.com/docs/books/jls/">The Java Language Specification</a></em>,
* sections 5.1.1, 5.1.2 and 5.1.4 for details.</p>
*
* @param cls the Class to check, may be <code>null</code>
* @param toClass the Class to try to assign into, must not be <code>null</code>
* @return true if assignment possible
* @return <code>true</code> if assignment possible
* @throws IllegalArgumentException if the toClass is <code>null</code>
*/
public static boolean isAssignable(Class cls, Class toClass) {
@ -470,10 +486,10 @@ public class ClassUtils {
}
/**
* Is the specified class an inner class or static nested class.
* <p>Is the specified class an inner class or static nested class.</p>
*
* @param cls the class to check
* @return true if the class is an inner or static nested class
* @return <code>true</code> if the class is an inner or static nested class
* @throws IllegalArgumentException if the class is <code>null</code>
*/
public static boolean isInnerClass(Class cls) {

View File

@ -63,13 +63,13 @@ import java.lang.reflect.Method;
import java.lang.reflect.InvocationTargetException;
/**
* A utility which takes much of the pain out of the Event/Listener
* <p>A utility which takes much of the pain out of the Event/Listener
* system. It handles the collection, and the loop-notification.
* Reflection is used for the actual notification call.
* Reflection is used for the actual notification call.</p>
*
* Alternate strategies are usable. For example this class currently
* <p>Alternate strategies are usable. For example this class currently
* does not enforce a particular interface, which means it cannot
* cache that method. Doing this probably makes a lot of sense.
* cache that method. Doing this probably makes a lot of sense.</p>
*/
public class Notifier {
@ -93,8 +93,8 @@ public class Notifier {
}
/**
* Construct with the class and the name of the method to
* call upon the listeners.
* <p>Construct with the class and the name of the method to
* call upon the listeners.</p>
*/
public Notifier(Class clss, String name) {
if(clss == null) {
@ -128,10 +128,11 @@ public class Notifier {
}
/**
* Convenience method for when a listener has a single method.
* Currently this method needs to be called, but it's possible
* <p>Convenience method for when a listener has a single method.</p>
*
* <p>Currently this method needs to be called, but it's possible
* that by providing the interface class, it can be assumed as
* to what the listening method is.
* to what the listening method is.</p>
*/
public void notify(EventObject event) throws NotifierException {
if(this.clss == null) {
@ -142,9 +143,10 @@ public class Notifier {
}
/**
* Notify the listeners of a certain event, to a certain method.
* This is usable when a Listener has more than one method and
* a single Notifier wants to be shared.
* <p>Notify the listeners of a certain event, to a certain method.</p>
*
* <p>This is usable when a Listener has more than one method and
* a single <code>Notifier</code> wants to be shared.</p>
*/
private void notify(Method listenerMethod, EventObject event) throws NotifierException {
Iterator itr = getListeners().iterator();
@ -165,9 +167,10 @@ public class Notifier {
}
/**
* Notify the listeners of a certain event, to a certain method.
* This is usable when a Listener has more than one method and
* a single Notifier wants to be shared.
* <p>Notify the listeners of a certain event, to a certain method.</p>
*
* <p>This is usable when a Listener has more than one method and
* a single Notifier wants to be shared.</p>
*/
public void notify(String methodName, EventObject event) throws NotifierException {
Iterator itr = getListeners().iterator();

View File

@ -56,24 +56,24 @@ package org.apache.commons.lang;
import org.apache.commons.lang.exception.NestableException;
/**
* Exception thrown when something goes wrong in notifying.
* <p>Exception thrown when something goes wrong in notifying.</p>
*
* @author <a href="mailto:bayard@apache.org">Henri Yandell</a>
* @version $Id: NotifierException.java,v 1.1 2002/11/12 03:01:05 bayard Exp $
* @version $Id: NotifierException.java,v 1.2 2002/11/16 10:41:03 scolebourne Exp $
*/
public class NotifierException extends NestableException {
/**
* Constructs a new <code>NotifierException</code> without specified
* detail message.
* <p>Constructs a new <code>NotifierException</code> without specified
* detail message.</p>
*/
public NotifierException() {
super();
}
/**
* Constructs a new <code>NotifierException</code> with specified
* detail message.
* <p>Constructs a new <code>NotifierException</code> with specified
* detail message.</p>
*
* @param msg the error message.
*/
@ -82,23 +82,23 @@ public class NotifierException extends NestableException {
}
/**
* Constructs a new <code>NotifierException</code> with specified
* nested <code>Throwable</code> root cause.
* <p>Constructs a new <code>NotifierException</code> with specified
* nested <code>Throwable</code> root cause.</p>
*
* @param rootCause the exception or error that caused this exception
* to be thrown.
* @param rootCause the <code>Exception</code> or <code>Error</code> that
* caused this exception to be thrown.
*/
public NotifierException(Throwable rootCause) {
super(rootCause);
}
/**
* Constructs a new <code>NotifierException</code> with specified
* detail message and nested <code>Throwable</code> root cause.
* <p>Constructs a new <code>NotifierException</code> with specified
* detail message and nested <code>Throwable</code> root cause.</p>
*
* @param msg the error message.
* @param rootCause the exception or error that caused this exception
* to be thrown.
* @param rootCause the <code>Exception</code> or <code>Error</code> that
* caused this exception to be thrown.
*/
public NotifierException(String msg, Throwable rootCause) {
super(msg, rootCause);

View File

@ -55,11 +55,11 @@ package org.apache.commons.lang;
*/
/**
* Represents a range of {@link Number} objects.
* <p>Represents a range of {@link Number} objects.</p>
*
* @author <a href="mailto:chrise@esha.com">Christopher Elkins</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Revision: 1.2 $ $Date: 2002/11/07 16:59:44 $
* @version $Revision: 1.3 $ $Date: 2002/11/16 10:41:03 $
*/
public final class NumberRange {
@ -72,8 +72,8 @@ public final class NumberRange {
/**
* Constructs a new instance using the specified number as both the
* minimum and maximum in theis range.
* <p>Constructs a new <code>NumberRange</code> using the specified
* number as both the minimum and maximum in this range.</p>
*
* @param num the number to use for this range
* @throws NullPointerException if the number is <code>null</code>
@ -88,13 +88,13 @@ public final class NumberRange {
}
/**
* Constructs a new instance with the specified minimum and maximum
* numbers.
* <p>Constructs a new <code>NumberRange</code> with the specified
* minimum and maximum numbers.</p>
*
* @param min the minimum number in this range
* @param max the maximum number in this range
* @throws NullPointerException if either the minimum or maximum number is
* <code>null</code>
* <code>null</code>
*/
public NumberRange(Number min, Number max) {
if (min == null) {
@ -112,7 +112,7 @@ public final class NumberRange {
}
/**
* Returns the minimum number in this range.
* <p>Returns the minimum number in this range.</p>
*
* @return the minimum number in this range
*/
@ -121,7 +121,7 @@ public final class NumberRange {
}
/**
* Returns the maximum number in this range.
* <p>Returns the maximum number in this range.</p>
*
* @return the maximum number in this range
*/
@ -130,11 +130,12 @@ public final class NumberRange {
}
/**
* Tests whether the specified number occurs within this range.
* <p>Tests whether the specified <code>number</code> occurs within
* this range.</p>
*
* @param number the number to test
* @return <code>true</code> if the specified number occurs within this
* range; otherwise, <code>false</code>
* range; otherwise, <code>false</code>
*/
public boolean includesNumber(Number number) {
if (number == null) {
@ -146,11 +147,12 @@ public final class NumberRange {
}
/**
* Tests whether the specified range occurs entirely within this range.
* <p>Tests whether the specified range occurs entirely within this
* range.</p>
*
* @param range the range to test
* @return <code>true</code> if the specified range occurs entirely within
* this range; otherwise, <code>false</code>
* this range; otherwise, <code>false</code>
*/
public boolean includesRange(NumberRange range) {
if (range == null) {
@ -161,11 +163,11 @@ public final class NumberRange {
}
/**
* Tests whether the specified range overlaps with this range.
* <p>Tests whether the specified range overlaps with this range.</p>
*
* @param range the range to test
* @return <code>true</code> if the specified range overlaps with this
* range; otherwise, <code>false</code>
* range; otherwise, <code>false</code>
*/
public boolean overlaps(NumberRange range) {
if (range == null) {
@ -177,11 +179,12 @@ public final class NumberRange {
}
/**
* Indicates whether some other object is "equal" to this one.
* <p>Indicates whether some other <code>Object</code> is "equal" to
* this one</p>.
*
* @param obj the reference object with which to compare
* @return <code>true</code> if this object is the same as the obj
* argument; <code>false</code> otherwise
* argument; <code>false</code> otherwise
*/
public boolean equals(Object obj) {
if (obj == this) {
@ -195,7 +198,7 @@ public final class NumberRange {
}
/**
* Returns a hash code value for this object.
* <p>Returns a hash code value for this object.</p>
*
* @return a hash code value for this object
*/
@ -207,10 +210,11 @@ public final class NumberRange {
}
/**
* Returns the string representation of this range. This string is the
* string representation of the minimum and maximum numbers in the range,
* separated by a hyphen. If a number is negative, then it is enclosed
* in parentheses.
* <p>Returns the string representation of this range.</p>
*
* <p>This string is the string representation of the minimum and
* maximum numbers in the range, separated by a hyphen. If a number
* is negative, then it is enclosed in parentheses.</p>
*
* @return the string representation of this range
*/

View File

@ -57,21 +57,22 @@ package org.apache.commons.lang;
import java.math.BigInteger;
import java.math.BigDecimal;
/**
* Provides extra functionality for Java Number classes.
* <p>Provides extra functionality for Java Number classes</p>.
*
* @author <a href="mailto:bayard@generationjava.com">Henri Yandell</a>
* @author <a href="mailto:rand_mcneely@yahoo.com">Rand McNeely</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @author <a href="mailto:steve.downey@netfolio.com">Steve Downey</a>
* @version $Id: NumberUtils.java,v 1.3 2002/09/28 10:34:54 scolebourne Exp $
* @version $Id: NumberUtils.java,v 1.4 2002/11/16 10:41:03 scolebourne Exp $
*/
public final class NumberUtils {
/**
* NumberUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>NumberUtils.stringToInt("6");</code>.
* This constructor is public to permit tools that require a JavaBean instance
* to operate.
* <p>NumberUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>NumberUtils.stringToInt("6");</code>.</p>
*
* <p>This constructor is public to permit tools that require a JavaBean instance
* to operate.</p>
*/
public NumberUtils() {
}
@ -79,18 +80,20 @@ public final class NumberUtils {
//--------------------------------------------------------------------
/**
* Convert a String to an int, returning zero if the conversion fails
* <p>Convert a <code>String</code> to an <code>int</code>, returning
* <code>zero</code> if the conversion fails.</p>
*
* @param str the string to convert
* @return the int represented by the string, or zero if conversion fails
* @return the int represented by the string, or <code>zero</code> if
* conversion fails
*/
public static int stringToInt(String str) {
return stringToInt(str, 0);
}
/**
* Convert a String to an int, returning a default value if the
* conversion fails.
* <p>Convert a <code>String</code> to an <code>int</code>, returning a
* default value if the conversion fails.</p>
*
* @param str the string to convert
* @param defaultValue the default value
@ -142,23 +145,21 @@ public final class NumberUtils {
// plus minus everything. Prolly more. A lot are not separable.
/**
* <p>
* Turns a string value into a java.lang.Number.
* First, the value is examined for a type qualifier on the end
* <p>Turns a string value into a java.lang.Number.</p>
*
* <p>First, the value is examined for a type qualifier on the end
* (<code>'f','F','d','D','l','L'</code>). If it is found, it starts
* trying to create succissively larger types from the type specified
* until one is found that can hold the value.
* </p>
* <p>
* If a type specifier is not found, it will check for a decimal point
* and then try successively larger types from Integer to BigInteger
* and from Float to BigDecimal.
* </p>
* <p>
* If the string starts with "0x" or "-0x", it will be interpreted as a
* hexadecimal integer. Values with leading 0's will not be interpreted
* as octal.
* </p>
* until one is found that can hold the value.</p>
*
* <p>If a type specifier is not found, it will check for a decimal point
* and then try successively larger types from <code>Integer</code> to
* <code>BigInteger</code> and from <code>Float</code> to
* <code>BigDecimal</code>.</p>
*
* <p>If the string starts with <code>0x</code> or <code>-0x</code>, it
* will be interpreted as a hexadecimal integer. Values with leading
* <code>0</code>'s will not be interpreted as octal.</p>
*
* @param val String containing a number
* @return Number created from the string
@ -309,10 +310,12 @@ public final class NumberUtils {
}
/**
* Utility method for createNumber. Returns true if s is null
* <p>Utility method for {@link #createNumber(java.lang.String)}.</p>
*
* <p>Returns <code>true</code> if s is <code>null</code>.</p>
*
* @param s the String to check
* @return if it is all zeros or null
* @return if it is all zeros or <code>null</code>
*/
private static boolean isAllZeros(String s) {
if (s == null) {
@ -329,10 +332,10 @@ public final class NumberUtils {
//--------------------------------------------------------------------
/**
* Convert a String to a Float
* <p>Convert a <code>String</code> to a <code>Float</code>.</p>
*
* @param val a String to convert
* @return converted Float
* @param val a <code>String</code> to convert
* @return converted <code>Float</code>
* @throws NumberFormatException if the value cannot be converted
*/
public static Float createFloat(String val) {
@ -340,10 +343,10 @@ public final class NumberUtils {
}
/**
* Convert a String to a Double
* <p>Convert a <code>String</code> to a <code>Double</code>.</p>
*
* @param val a String to convert
* @return converted Double
* @param val a <code>String</code> to convert
* @return converted <code>Double</code>
* @throws NumberFormatException if the value cannot be converted
*/
public static Double createDouble(String val) {
@ -351,11 +354,11 @@ public final class NumberUtils {
}
/**
* Convert a String to a Integer, handling hex and
* octal notations.
* <p>Convert a <code>String</code> to a <code>Integer</code>, handling
* hex and octal notations.</p>
*
* @param val a String to convert
* @return converted Integer
* @param val a <code>String</code> to convert
* @return converted <code>Integer</code>
* @throws NumberFormatException if the value cannot be converted
*/
public static Integer createInteger(String val) {
@ -364,10 +367,10 @@ public final class NumberUtils {
}
/**
* Convert a String to a Long
* <p>Convert a <code>String</code> to a <code>Long</code>.</p>
*
* @param val a String to convert
* @return converted Long
* @param val a <code>String</code> to convert
* @return converted <code>Long</code>
* @throws NumberFormatException if the value cannot be converted
*/
public static Long createLong(String val) {
@ -375,10 +378,10 @@ public final class NumberUtils {
}
/**
* Convert a String to a BigInteger
* <p>Convert a <code>String</code> to a <code>BigInteger</code>.</p>
*
* @param val a String to convert
* @return converted BigInteger
* @param val a <code>String</code> to convert
* @return converted <code>BigInteger</code>
* @throws NumberFormatException if the value cannot be converted
*/
public static BigInteger createBigInteger(String val) {
@ -387,10 +390,10 @@ public final class NumberUtils {
}
/**
* Convert a String to a BigDecimal
* <p>Convert a <code>String</code> to a <code>BigDecimal</code>.</p>
*
* @param val a String to convert
* @return converted BigDecimal
* @param val a <code>String</code> to convert
* @return converted <code>BigDecimal</code>
* @throws NumberFormatException if the value cannot be converted
*/
public static BigDecimal createBigDecimal(String val) {
@ -401,7 +404,7 @@ public final class NumberUtils {
//--------------------------------------------------------------------
/**
* Gets the minimum of three long values.
* <p>Gets the minimum of three <code>long</code> values.</p>
*
* @param a value 1
* @param b value 2
@ -419,7 +422,7 @@ public final class NumberUtils {
}
/**
* Gets the minimum of three int values.
* <p>Gets the minimum of three <code>int</code> values.</p>
*
* @param a value 1
* @param b value 2
@ -437,7 +440,7 @@ public final class NumberUtils {
}
/**
* Gets the maximum of three long values.
* <p>Gets the maximum of three <code>long</code> values.</p>
*
* @param a value 1
* @param b value 2
@ -455,7 +458,7 @@ public final class NumberUtils {
}
/**
* Gets the maximum of three int values.
* <p>Gets the maximum of three <code>int</code> values.</p>
*
* @param a value 1
* @param b value 2
@ -475,31 +478,38 @@ public final class NumberUtils {
//--------------------------------------------------------------------
/**
* Compares two doubles for order.
* <p>
* This method is more comprhensive than the standard Java greater than,
* less than and equals operators.
* It returns -1 if the first value is less than the second.
* It returns +1 if the first value is greater than the second.
* It returns 0 if the values are equal.
* <p>Compares two <code>doubles</code> for order.</p>
*
* <p>This method is more comprehensive than the standard Java greater
* than, less than and equals operators.</p>
* <ul>
* <li>It returns <code>-1</code> if the first value is less than the second.
* <li>It returns <code>+1</code> if the first value is greater than the second.
* <li>It returns <code>0</code> if the values are equal.
* </ul>
*
* <p>
* The ordering is as follows, largest to smallest:
* <ul>
* <li>NaN
* <li>Positive infinity
* <li>Maximum double
* <li>Normal positve numbers
* <li>+0.0
* <li>-0.0
* <li>Normal negative numbers
* <li>Minimum double (-Double.MAX_VALUE)
* <li>Negative infinity
* <li>NaN
* <li>Positive infinity
* <li>Maximum double
* <li>Normal positve numbers
* <li>+0.0
* <li>-0.0
* <li>Normal negative numbers
* <li>Minimum double (-Double.MAX_VALUE)
* <li>Negative infinity
* </ul>
* Comparing NaN with NaN will return 0.
* </p>
*
* @param lhs the first double
* @param rhs the second double
* @return -1 if lhs is less, +1 if greater, 0 if equal to rhs
* <p>Comparing <code>NaN</code> with <code>NaN</code> will
* return <code>0</code>.</p>
*
* @param lhs the first <code>double</code>
* @param rhs the second <code>double</code>
* @return <code>-1</code> if lhs is less, <code>+1</code> if greater,
* <code>0</code> if equal to rhs
*/
public static int compare(double lhs, double rhs) {
if (lhs < rhs) {
@ -531,15 +541,17 @@ public final class NumberUtils {
}
/**
* Compares two floats for order.
* <p>
* This method is more comprhensive than the standard Java greater than,
* less than and equals operators.
* It returns -1 if the first value is less than the second.
* It returns +1 if the first value is greater than the second.
* It returns 0 if the values are equal.
* <p>
* The ordering is as follows, largest to smallest:
* <p>Compares two floats for order.</p>
*
* <p>This method is more comprhensive than the standard Java greater than,
* less than and equals operators.</p>
* <ul>
* <li>It returns <code>-1</code> if the first value is less than the second.
* <li>It returns <code>+1</code> if the first value is greater than the second.
* <li>It returns <code>0</code> if the values are equal.
* </ul>
*
* <p> The ordering is as follows, largest to smallest:
* <ul>
* <li>NaN
* <li>Positive infinity
@ -551,11 +563,14 @@ public final class NumberUtils {
* <li>Minimum float (-Float.MAX_VALUE)
* <li>Negative infinity
* </ul>
* Comparing NaN with NaN will return 0.
*
* @param lhs the first float
* @param rhs the second float
* @return -1 if lhs is less, +1 if greater, 0 if equal to rhs
* <p>Comparing <code>NaN</code> with <code>NaN</code> will return
* <code>0</code>.</p>
*
* @param lhs the first <code>float</code>
* @param rhs the second <code>float</code>
* @return <code>-1</code> if lhs is less, <code>+1</code> if greater,
* <code>0</code> if equal to rhs
*/
public static int compare(float lhs, float rhs) {
if (lhs < rhs) {
@ -589,11 +604,14 @@ public final class NumberUtils {
//--------------------------------------------------------------------
/**
* Checks whether the String contains only digit characters.
* Null and blank string will return false.
* <p>Checks whether the <code>String</code> contains only
* digit characters.</p>
*
* @param str the string to check
* @return boolean contains only unicode numeric
* <p><code>Null</code> and empty String will return
* <code>false</code>.</p>
*
* @param str the <code>String</code> to check
* @return <code>true</code> if str contains only unicode numeric
*/
public static boolean isDigits(String str) {
if ((str == null) || (str.length() == 0)) {
@ -608,17 +626,17 @@ public final class NumberUtils {
}
/**
* <p>
* Checks whether the String a valid Java number.
* Valid numbers include hexadecimal marked with the "0x" qualifier,
* scientific notation and numbers marked with a type qualifier (e.g. 123L).
* </p>
* <p>
* Null and blank string will return false.
* </p>
* <p>Checks whether the String a valid Java number.</p>
*
* @param str the string to check
* @return true if the string is a correctly formatted number
* <p>Valid numbers include hexadecimal marked with the <code>0x</code>
* qualifier, scientific notation and numbers marked with a type
* qualifier (e.g. 123L).</p>
*
* <p><code>Null</code> and empty String will return
* <code>false</code>.</p>
*
* @param str the <code>String</code> to check
* @return <code>true</code> if the string is a correctly formatted number
*/
public static boolean isNumber(String str) {
if ((str == null) || (str.length() == 0)) {

View File

@ -55,35 +55,41 @@ package org.apache.commons.lang;
import java.io.Serializable;
/**
* Common <code>Object</code> manipulation routines.
* <p>Common <code>Object</code> manipulation routines.</p>
*
* @author <a href="mailto:nissim@nksystems.com">Nissim Karpenstein</a>
* @author <a href="mailto:janekdb@yahoo.co.uk">Janek Bogucki</a>
* @author <a href="mailto:dlr@finemaltcoding.com">Daniel Rall</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Id: ObjectUtils.java,v 1.4 2002/09/22 09:18:33 scolebourne Exp $
* @version $Id: ObjectUtils.java,v 1.5 2002/11/16 10:41:03 scolebourne Exp $
*/
public class ObjectUtils {
/**
* Singleton used as a null placeholder where null has another meaning.
* <p>
* For example, in a <code>HashMap</code> the get(key) method returns null
* if the Map contains null or if there is no matching key. The Null
* placeholder can be used to distinguish between these two cases.
* <p>
* Another example is <code>HashTable</code>, where <code>null</code>
* cannot be stored.
* <p>
* This instance is Serializable.
* <p>Singleton used as a <code>null</code> placeholder where
* <code>null</code> has another meaning.</p>
*
* <p>For example, in a <code>HashMap</code> the
* {@link java.util.HashMap#get(java.lang.Object)} method returns
* <code>null</code> if the <code>Map</code> contains
* <code>null</code> or if there is no matching key. The
* <code>Null</code> placeholder can be used to distinguish between
* these two cases.</p>
*
* <p>Another example is <code>HashTable</code>, where <code>null</code>
* cannot be stored.</p>
*
* <p>This instance is Serializable.</p>
*/
public static final Null NULL = new Null();
/**
* ObjectUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>ObjectUtils.defaultIfNull("a","b");</code>.
* This constructor is public to permit tools that require a JavaBean instance
* to operate.
* <p><code>ObjectUtils</code> instances should NOT be constructed in
* standard programming. Instead, the class should be used as
* <code>ObjectUtils.defaultIfNull("a","b");</code>.</p>
*
* <p>This constructor is public to permit tools that require a JavaBean instance
* to operate.</p>
*/
public ObjectUtils() {
}
@ -91,19 +97,20 @@ public class ObjectUtils {
//--------------------------------------------------------------------
/**
* Returns a default value if the object passed is null.
* <p>Returns a default value if the object passed is
* <code>null</code>.</p>
*
* @param object the object to test
* @param object the <code>Object</code> to test
* @param defaultValue the default value to return
* @return object if it is not null, defaultValue otherwise
* @return <code>object</code> if it is not <code>null</code>, defaultValue otherwise
*/
public static Object defaultIfNull(Object object, Object defaultValue) {
return (object != null ? object : defaultValue);
}
/**
* Compares two objects for equality, where either one or both
* objects may be <code>null</code>.
* <p>Compares two objects for equality, where either one or both
* objects may be <code>null</code>.</p>
*
* @param object1 the first object
* @param object2 the second object
@ -120,11 +127,14 @@ public class ObjectUtils {
}
/**
* Gets the toString that would be produced by Object if a class did not
* override toString itself. Null will return null.
* <p>Gets the toString that would be produced by <code>Object</code>
* if a class did not override toString itself. <code>Null</code>
* will return <code>null</code>.</p>
*
* @param object the object to create a toString for, may be null
* @return the default toString text, or null if null passed in
* @param object the object to create a toString for, may be
* <code>null</code>
* @return the default toString text, or <code>null</code> if
* <code>null</code> passed in
*/
public static String identityToString(Object object) {
if (object == null) {
@ -138,14 +148,17 @@ public class ObjectUtils {
}
/**
* Class used as a null placeholder where null has another meaning.
* <p>
* For example, in a <code>HashMap</code> the get(key) method returns null
* if the Map contains null or if there is no matching key. The Null
* placeholder can be used to distinguish between these two cases.
* <p>
* Another example is <code>HashTable</code>, where <code>null</code>
* cannot be stored.
* <p>Class used as a null placeholder where null has another meaning.</p>
*
* <p>For example, in a <code>HashMap</code> the
* {@link java.util.HashMap#get(java.lang.Object)} method returns
* <code>null</code> if the <code>Map</code> contains
* <code>null</code> or if there is no matching key. The
* <code>Null</code> placeholder can be used to distinguish between
* these two cases.</p>
*
* <p>Another example is <code>HashTable</code>, where <code>null</code>
* cannot be stored.</p>
*/
public static class Null implements Serializable {
/**
@ -155,7 +168,8 @@ public class ObjectUtils {
}
/**
* Ensure singleton.
* <p>Ensure singleton.</p>
*
* @return the singleton value
*/
private Object readResolve() {

View File

@ -63,29 +63,33 @@ import java.util.Random;
* @author <a href="mailto:bayard@generationjava.com">Henri Yandell</a>
* @author <a href="mailto:steven@caswell.name">Steven Caswell</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Id: RandomStringUtils.java,v 1.5 2002/09/28 10:34:54 scolebourne Exp $
* @version $Id: RandomStringUtils.java,v 1.6 2002/11/16 10:41:03 scolebourne Exp $
*/
public class RandomStringUtils {
/**
* Random object used by random method. This has to be not local
* <p>Random object used by random method. This has to be not local
* to the random method so as to not return the same value in the
* same millisecond.
* same millisecond.</p>
*/
private static final Random RANDOM = new Random();
/**
* RandomStringUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>RandomStringUtils.random(5);</code>.
* This constructor is public to permit tools that require a JavaBean instance
* to operate.
* <p><code>RandomStringUtils</code> instances should NOT be constructed in
* standard programming. Instead, the class should be used as
* <code>RandomStringUtils.random(5);</code>.</p>
*
* <p>This constructor is public to permit tools that require a JavaBean instance
* to operate.</p>
*/
public RandomStringUtils() {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of all characters.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* <p>Characters will be chosen from the set of all characters.</p>
*
* @param count length of random string to create
* @return the random string
@ -95,9 +99,11 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of characters whose
* ASCII value is between 32 and 127 .
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* <p>Characters will be chosen from the set of characters whose
* ASCII value is between <code>32</code> and <code>127</code>.</p>
*
* @param count length of random string to create
* @return the random string
@ -107,9 +113,11 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of alphabetic
* characters.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* <p>Characters will be chosen from the set of alphabetic
* characters.</p>
*
* @param count length of random string to create
* @return the random string
@ -119,9 +127,11 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of alpha-numeric
* characters.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* <u>Characters will be chosen from the set of alpha-numeric
* characters.</p>
*
* @param count length of random string to create
* @return the random string
@ -131,9 +141,11 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of numeric
* characters.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* <p>Characters will be chosen from the set of numeric
* characters.</p>
*
* @param count length of random string to create
* @return the random string
@ -143,15 +155,17 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of alpha-numeric
* characters as indicated by the arguments.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* <p>Characters will be chosen from the set of alpha-numeric
* characters as indicated by the arguments.</p>
*
* @param count length of random string to create
* @param letters if <code>true</code>, generated string will include
* alphabetic characters
* alphabetic characters
* @param numbers if <code>true</code>, generatd string will include
* numeric characters
* numeric characters
* @return the random string
*/
public static String random(int count, boolean letters, boolean numbers) {
@ -159,17 +173,19 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of alpha-numeric
* characters as indicated by the arguments.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* <p>Characters will be chosen from the set of alpha-numeric
* characters as indicated by the arguments.</p>
*
* @param count length of random string to create
* @param start int position in set of chars to start at
* @param end int position in set of chars to end before
* @param start position in set of chars to start at
* @param end position in set of chars to end before
* @param letters if <code>true</code>, generated string will include
* alphabetic characters
* @param numbers if <code>true</code>, generatd string will include
* numeric characters
* alphabetic characters
* @param numbers if <code>true</code>, generated string will include
* numeric characters
* @return the random string
*/
public static String random(int count, int start, int end, boolean letters, boolean numbers) {
@ -177,24 +193,27 @@ public class RandomStringUtils {
}
/**
* Creates a random string based on a variety of options.
* If start and end are both 0, start and end are set to ' ' and 'z', the ASCII
* printable characters, will be used, unless letters and numbers are both
* false, in which case, start and end are set to 0 and Integer.MAX_VALUE.
* <p>
* If set is not null, characters between start and end are chosen.
* <p>
* <p>Creates a random string based on a variety of options.</p>
*
* @param count int length of random string to create
* @param start int position in set of chars to start at
* @param end int position in set of chars to end before
* @param letters boolean only allow letters?
* @param numbers boolean only allow numbers?
* @param set char[] set of chars to choose randoms from.
* If null, then it will use the set of all chars.
* <p>If start and end are both <code>0</code>, start and end are set
* to <code>' '</code> and <code>'z'</code>, the ASCII printable
* characters, will be used, unless letters and numbers are both
* <code>false</code>, in which case, start and end are set to
* <code>0</code> and <code>Integer.MAX_VALUE</code>.
*
* <p>If set is not <code>null</code>, characters between start and
* end are chosen.</p>
*
* @param count length of random string to create
* @param start position in set of chars to start at
* @param end position in set of chars to end before
* @param letters only allow letters?
* @param numbers only allow numbers?
* @param set set of chars to choose randoms from. If <code>null</code>,
* then it will use the set of all chars.
* @return the random string
* @throws ArrayIndexOutOfBoundsException if there are not (end - start) + 1
* characters in the set array.
* @throws ArrayIndexOutOfBoundsException if there are not
* <code>(end - start) + 1</code> characters in the set array.
*/
public static String random(int count, int start, int end, boolean letters, boolean numbers, char[] set) {
if( (start == 0) && (end == 0) ) {
@ -231,11 +250,13 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of characters
* specified.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* @param count int length of random string to create
* <p>Characters will be chosen from the set of characters
* specified.</p>
*
* @param count length of random string to create
* @param set String containing the set of characters to use
* @return the random string
*/
@ -244,11 +265,12 @@ public class RandomStringUtils {
}
/**
* Creates a random string whose length is the number of characters
* specified. Characters will be chosen from the set of characters
* specified.
* <p>Creates a random string whose length is the number of characters
* specified.</p>
*
* @param count int length of random string to create
* <p>Characters will be chosen from the set of characters specified.</p>
*
* @param count length of random string to create
* @param set character array containing the set of characters to use
* @return the random string
*/

View File

@ -57,25 +57,26 @@ package org.apache.commons.lang;
import org.apache.commons.lang.exception.NestableRuntimeException;
/**
* Exception thrown when the Serialization process fails. The original
* error is wrapped within this one.
* <p>Exception thrown when the Serialization process fails.</p>
*
* <p>The original error is wrapped within this one.</p>
*
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Id: SerializationException.java,v 1.2 2002/08/31 11:11:03 scolebourne Exp $
* @version $Id: SerializationException.java,v 1.3 2002/11/16 10:41:03 scolebourne Exp $
*/
public class SerializationException extends NestableRuntimeException {
/**
* Constructs a new <code>SerializationException</code> without specified
* detail message.
* <p>Constructs a new <code>SerializationException</code> without specified
* detail message.</p>
*/
public SerializationException() {
super();
}
/**
* Constructs a new <code>SerializationException</code> with specified
* detail message.
* <p>Constructs a new <code>SerializationException</code> with specified
* detail message.</p>
*
* @param msg The error message.
*/
@ -84,23 +85,23 @@ public class SerializationException extends NestableRuntimeException {
}
/**
* Constructs a new <code>SerializationException</code> with specified
* nested <code>Throwable</code>.
* <p>Constructs a new <code>SerializationException</code> with specified
* nested <code>Throwable</code>.</p>
*
* @param cause The exception or error that caused this exception
* to be thrown.
* @param cause The <code>Exception</code> or <code>Error</code>
* that caused this exception to be thrown.
*/
public SerializationException(Throwable cause) {
super(cause);
}
/**
* Constructs a new <code>SerializationException</code> with specified
* detail message and nested <code>Throwable</code>.
* <p>Constructs a new <code>SerializationException</code> with specified
* detail message and nested <code>Throwable</code>.</p>
*
* @param msg The error message.
* @param cause The exception or error that caused this exception
* to be thrown.
* @param cause The <code>Exception</code> or <code>Error</code>
* that caused this exception to be thrown.
*/
public SerializationException(String msg, Throwable cause) {
super(msg, cause);

View File

@ -64,8 +64,8 @@ import java.io.OutputStream;
import java.io.Serializable;
/**
* Methods that assist with the serialization process, or perform
* additional functionality based on serialization.
* <p>Methods that assist with the serialization process, or perform
* additional functionality based on serialization.</p>
* <ul>
* <li>Deep clone using serialization
* <li>Serialize managing finally and IOException
@ -76,25 +76,25 @@ import java.io.Serializable;
* @author <a href="mailto:janekdb@yahoo.co.uk">Janek Bogucki</a>
* @author <a href="mailto:dlr@finemaltcoding.com">Daniel Rall</a>
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
* @version $Id: SerializationUtils.java,v 1.2 2002/08/31 11:09:45 scolebourne Exp $
* @version $Id: SerializationUtils.java,v 1.3 2002/11/16 10:41:03 scolebourne Exp $
*/
public class SerializationUtils {
/**
* Constructor for SerializationUtils is private
* <p>Constructor for SerializationUtils is private.</p>
*/
private SerializationUtils() {
super();
}
/**
* Deep clone an object using serialization.
* <p>
* This is many times slower than writing clone methods by hand
* <p>Deep clone an <code>Object</code> using serialization.</p>
*
* <p>This is many times slower than writing clone methods by hand
* on all objects in your object graph. However, for complex object
* graphs, or for those that don't support deep cloning this can
* be a simple alternative implementation. Of course all the objects
* must be <code>Serializable</code>.
* must be <code>Serializable</code>.</p>
*
* @param object the <code>Serializable</code> object to clone
* @return the cloned object
@ -105,10 +105,11 @@ public class SerializationUtils {
}
/**
* Serializes an object to the specified stream. The stream will
* be closed once the object is written. This avoids the need for
* a finally clause, and maybe also exception handling, in the
* application code.
* <p>Serializes an <code>Object</code> to the specified stream.</p>
*
* <p>The stream will be closed once the object is written.
* This avoids the need for a finally clause, and maybe also exception
* handling, in the application code.</p>
*
* @param obj the object to serialize to bytes
* @param outputStream the stream to write to
@ -135,7 +136,8 @@ public class SerializationUtils {
}
/**
* Serializes an object to a byte array for storage/serialization.
* <p>Serializes an <code>Object</code> to a byte array for
* storage/serialization.</p>
*
* @param obj the object to serialize to bytes
* @return a byte[] with the converted Serializable
@ -148,10 +150,11 @@ public class SerializationUtils {
}
/**
* Deserializes an object from the specified stream. The stream will
* be closed once the object is written. This avoids the need for
* a finally clause, and maybe also exception handling, in the
* application code.
* <p>Deserializes an <code>Object</code> from the specified stream.</p>
*
* <p>The stream will be closed once the object is written. This
* avoids the need for a finally clause, and maybe also exception
* handling, in the application code.</p>
*
* @param inputStream the serialized object input stream
* @return the deserialized object
@ -180,7 +183,7 @@ public class SerializationUtils {
}
/**
* Deserializes a single object from an array of bytes.
* <p>Deserializes a single <code>Object</code> from an array of bytes.</p>
*
* @param objectData the serialized object
* @return the deserialized object

File diff suppressed because it is too large Load Diff

View File

@ -55,21 +55,23 @@ package org.apache.commons.lang;
*/
/**
* Common <code>System</code> class helpers.
* <p>Common <code>System</code> class helpers.</p>
*
* @author Based on code from Avalon Excalibur
* @author Based on code from Lucene
* @author <a href="mailto:scolebourne@apache.org">Stephen Colebourne</a>
* @author <a href="mailto:sdowney@panix.com">Steve Downey</a>
* @version $Id: SystemUtils.java,v 1.3 2002/10/29 19:47:02 bayard Exp $
* @version $Id: SystemUtils.java,v 1.4 2002/11/16 10:41:03 scolebourne Exp $
*/
public class SystemUtils {
/**
* SystemUtils instances should NOT be constructed in standard programming.
* Instead, the class should be used as <code>SystemUtils.FILE_SEPARATOR</code>.
* This constructor is public to permit tools that require a JavaBean instance
* to operate.
* <P>SystemUtils instances should NOT be constructed in standard
* programming. Instead, the class should be used as
* <code>SystemUtils.FILE_SEPARATOR</code>.</p>
*
* <p>This constructor is public to permit tools that require a JavaBean
* instance to operate.</p>
*/
public SystemUtils() {
}
@ -409,10 +411,13 @@ public class SystemUtils {
// }
/**
* Get the Java version number as a float.
* Example output:<br>
* 1.2f for JDK 1.2<br>
* 1.31f for JDK 1.3.1<br>
* <p>Get the Java version number as a <code>float</code>.</p>
*
* <P>Example output:</p>
* <ul>
* <li><code>1.2f</code> for JDK 1.2
* <li><code>1.31f</code> for JDK 1.3.1
* </ul>
*
* @return the version, for example 1.31f for JDK 1.3.1
*/
@ -425,13 +430,17 @@ public class SystemUtils {
}
/**
* Is the Java version at the the requested version.
* Example input:<br>
* 1.2f for JDK 1.2<br>
* 1.31f for JDK 1.3.1<br>
* <p>Is the Java version at the the requested version.</p>
*
* <p>Example input:</p>
* <ul>
* <li><code>1.2f</code> for JDK 1.2
* <li><code>1.31f</code> for JDK 1.3.1
* </ul>
*
* @param requiredVersion the required version, for example 1.31f
* @return true if the actual version is equal or greater than the required version
* @return <code>true</code> if the actual version is equal or greater
* than the required version
*/
public boolean isJavaVersionAtLeast(float requiredVersion) {
return (getJavaVersion() >= requiredVersion);