Implement changes to StringUtils.isEmpty and friends
This is an incompatible change for isEmpty and isNotEmpty from 1.0 git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/lang/trunk@137441 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
25b9bd6244
commit
f59fb46272
|
@ -1,4 +1,4 @@
|
||||||
$Id: RELEASE-NOTES.txt,v 1.11 2003/07/15 23:42:13 scolebourne Exp $
|
$Id: RELEASE-NOTES.txt,v 1.12 2003/07/16 21:19:22 scolebourne Exp $
|
||||||
|
|
||||||
Commons Lang Package
|
Commons Lang Package
|
||||||
Version 2.0
|
Version 2.0
|
||||||
|
@ -11,6 +11,16 @@ This document contains the release notes for this version of the Commons
|
||||||
Lang package. Commons Lang is a set of utility functions and reusable
|
Lang package. Commons Lang is a set of utility functions and reusable
|
||||||
components that should be a help in any Java environment.
|
components that should be a help in any Java environment.
|
||||||
|
|
||||||
|
|
||||||
|
INCOMPATIBLE CHANGES:
|
||||||
|
Some StringUtils methods have changed functionality from 1.0.
|
||||||
|
isEmpty()
|
||||||
|
isNotEmpty()
|
||||||
|
chomp(String)
|
||||||
|
chomp(String,String)
|
||||||
|
Check your code before implementing this release.
|
||||||
|
|
||||||
|
|
||||||
NEW FEATURES:
|
NEW FEATURES:
|
||||||
|
|
||||||
Since the release of the 1.0 package the following classes have been added:
|
Since the release of the 1.0 package the following classes have been added:
|
||||||
|
@ -63,9 +73,11 @@ lang:
|
||||||
SerializationUtils:
|
SerializationUtils:
|
||||||
added empty constructor
|
added empty constructor
|
||||||
StringUtils:
|
StringUtils:
|
||||||
isEmpty() changed to not trim.
|
isEmpty() changed to not trim and return false for null.
|
||||||
|
isNotEmpty() changed return true for null.
|
||||||
chomp() changed to be more like Perl.
|
chomp() changed to be more like Perl.
|
||||||
Twenty-one new methods.
|
Various methods changed in the handling of null (less exceptions).
|
||||||
|
Thirty-one new methods.
|
||||||
Eight methods deprecated.
|
Eight methods deprecated.
|
||||||
SystemUtils:
|
SystemUtils:
|
||||||
isJavaVersionAtLeast(int) added. getJavaVersion() deprecated.
|
isJavaVersionAtLeast(int) added. getJavaVersion() deprecated.
|
||||||
|
@ -150,6 +162,7 @@ lang:
|
||||||
NumberUtils:
|
NumberUtils:
|
||||||
now deprecated, see math subpackage
|
now deprecated, see math subpackage
|
||||||
|
|
||||||
|
|
||||||
CHANGES: [In 'diff' format]
|
CHANGES: [In 'diff' format]
|
||||||
|
|
||||||
Jar changes
|
Jar changes
|
||||||
|
@ -248,8 +261,12 @@ org.apache.commons.lang.StringUtils
|
||||||
--------------------
|
--------------------
|
||||||
> public static java.lang.String trimToNull(java.lang.String);
|
> public static java.lang.String trimToNull(java.lang.String);
|
||||||
> public static java.lang.String trimToEmpty(java.lang.String);
|
> public static java.lang.String trimToEmpty(java.lang.String);
|
||||||
|
> public static boolean isEmptyOrNull(java.lang.String);
|
||||||
|
> public static boolean isNotEmptyOrNull(java.lang.String);
|
||||||
> public static boolean isEmptyTrimmed(java.lang.String);
|
> public static boolean isEmptyTrimmed(java.lang.String);
|
||||||
> public static boolean isNotEmptyTrimmed(java.lang.String);
|
> public static boolean isNotEmptyTrimmed(java.lang.String);
|
||||||
|
> public static boolean isEmptyTrimmedOrNull(java.lang.String);
|
||||||
|
> public static boolean isNotEmptyTrimmedOrNull(java.lang.String);
|
||||||
> public static java.lang.String join(java.lang.Object[], char);
|
> public static java.lang.String join(java.lang.Object[], char);
|
||||||
> public static java.lang.String join(java.util.Iterator, char);
|
> public static java.lang.String join(java.util.Iterator, char);
|
||||||
> public static java.lang.String slice(java.lang.String);
|
> public static java.lang.String slice(java.lang.String);
|
||||||
|
@ -268,16 +285,12 @@ org.apache.commons.lang.StringUtils
|
||||||
> public static boolean containsOnly(java.lang.String, java.lang.String);
|
> public static boolean containsOnly(java.lang.String, java.lang.String);
|
||||||
> public static boolean containsNone(java.lang.String, java.lang.String);
|
> public static boolean containsNone(java.lang.String, java.lang.String);
|
||||||
> public static boolean containsNone(java.lang.String, char[]);
|
> public static boolean containsNone(java.lang.String, char[]);
|
||||||
> public static boolean containsOnly(java.lang.String, char[]);
|
|
||||||
> public static int indexOfAnyBut(java.lang.String, char[]);
|
> public static int indexOfAnyBut(java.lang.String, char[]);
|
||||||
> public static int indexOfAnyBut(java.lang.String, java.lang.String);
|
> public static int indexOfAnyBut(java.lang.String, java.lang.String);
|
||||||
> public static java.lang.String defaultString(java.lang.Object);
|
|
||||||
> public static java.lang.String defaultString(java.lang.Object, java.lang.String);
|
|
||||||
> public static java.lang.String abbreviate(java.lang.String, int);
|
> public static java.lang.String abbreviate(java.lang.String, int);
|
||||||
> public static java.lang.String abbreviate(java.lang.String, int, int);
|
> public static java.lang.String abbreviate(java.lang.String, int, int);
|
||||||
> public static java.lang.String difference(java.lang.String, java.lang.String);
|
> public static java.lang.String difference(java.lang.String, java.lang.String);
|
||||||
> public static int differenceAt(java.lang.String, java.lang.String);
|
> public static int differenceAt(java.lang.String, java.lang.String);
|
||||||
< public static boolean containsOnly(java.lang.String, char[]);
|
|
||||||
---
|
---
|
||||||
> static {};
|
> static {};
|
||||||
|
|
||||||
|
|
|
@ -62,7 +62,7 @@ import java.util.List;
|
||||||
* @author Stephen Colebourne
|
* @author Stephen Colebourne
|
||||||
* @author <a href="mailto:ggregory@seagullsw.com">Gary Gregory</a>
|
* @author <a href="mailto:ggregory@seagullsw.com">Gary Gregory</a>
|
||||||
* @since 2.0
|
* @since 2.0
|
||||||
* @version $Id: ClassUtils.java,v 1.14 2003/07/16 00:39:05 scolebourne Exp $
|
* @version $Id: ClassUtils.java,v 1.15 2003/07/16 21:19:22 scolebourne Exp $
|
||||||
*/
|
*/
|
||||||
public class ClassUtils {
|
public class ClassUtils {
|
||||||
|
|
||||||
|
@ -133,12 +133,13 @@ public class ClassUtils {
|
||||||
*
|
*
|
||||||
* <p>The string passed in is assumed to be a class name - it is not checked.</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
|
* @param className the className to get the short name for,
|
||||||
|
* must not be empty or <code>null</code>
|
||||||
* @return the class name of the class without the package name
|
* @return the class name of the class without the package name
|
||||||
* @throws IllegalArgumentException if the className is empty
|
* @throws IllegalArgumentException if the className is empty
|
||||||
*/
|
*/
|
||||||
public static String getShortClassName(String className) {
|
public static String getShortClassName(String className) {
|
||||||
if (StringUtils.isEmpty(className)) {
|
if (StringUtils.isEmptyOrNull(className)) {
|
||||||
throw new IllegalArgumentException("The class name must not be empty");
|
throw new IllegalArgumentException("The class name must not be empty");
|
||||||
}
|
}
|
||||||
char[] chars = className.toCharArray();
|
char[] chars = className.toCharArray();
|
||||||
|
@ -172,8 +173,8 @@ public class ClassUtils {
|
||||||
/**
|
/**
|
||||||
* <p>Gets the package name of a <code>Class</code>.</p>
|
* <p>Gets the package name of a <code>Class</code>.</p>
|
||||||
*
|
*
|
||||||
* @param cls the class to get the package name for, must not be
|
* @param cls the class to get the package name for,
|
||||||
* <code>null</code>
|
* must not be <code>null</code>
|
||||||
* @return the package name
|
* @return the package name
|
||||||
* @throws IllegalArgumentException if the class is <code>null</code>
|
* @throws IllegalArgumentException if the class is <code>null</code>
|
||||||
*/
|
*/
|
||||||
|
@ -189,12 +190,13 @@ public class ClassUtils {
|
||||||
*
|
*
|
||||||
* <p>The string passed in is assumed to be a class name - it is not checked.</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
|
* @param className the className to get the package name for,
|
||||||
|
* must not be empty or <code>null</code>
|
||||||
* @return the package name
|
* @return the package name
|
||||||
* @throws IllegalArgumentException if the className is empty
|
* @throws IllegalArgumentException if the className is empty
|
||||||
*/
|
*/
|
||||||
public static String getPackageName(String className) {
|
public static String getPackageName(String className) {
|
||||||
if (StringUtils.isEmpty(className)) {
|
if (StringUtils.isEmptyOrNull(className)) {
|
||||||
throw new IllegalArgumentException("The class name must not be empty");
|
throw new IllegalArgumentException("The class name must not be empty");
|
||||||
}
|
}
|
||||||
int i = className.lastIndexOf(PACKAGE_SEPARATOR_CHAR);
|
int i = className.lastIndexOf(PACKAGE_SEPARATOR_CHAR);
|
||||||
|
|
|
@ -90,7 +90,7 @@ import org.apache.commons.lang.math.NumberUtils;
|
||||||
* @author Arun Mammen Thomas
|
* @author Arun Mammen Thomas
|
||||||
* @author <a href="mailto:ggregory@seagullsw.com">Gary Gregory</a>
|
* @author <a href="mailto:ggregory@seagullsw.com">Gary Gregory</a>
|
||||||
* @since 1.0
|
* @since 1.0
|
||||||
* @version $Id: StringUtils.java,v 1.57 2003/07/16 20:19:24 scolebourne Exp $
|
* @version $Id: StringUtils.java,v 1.58 2003/07/16 21:19:22 scolebourne Exp $
|
||||||
*/
|
*/
|
||||||
public class StringUtils {
|
public class StringUtils {
|
||||||
|
|
||||||
|
@ -129,16 +129,16 @@ public class StringUtils {
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Removes control characters, including whitespace, from both
|
* <p>Removes control characters (char <= 32) from both
|
||||||
* ends of this String, handling <code>null</code> by returning
|
* ends of this String, handling <code>null</code> by returning
|
||||||
* an empty String ("").</p>
|
* an empty String ("").</p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.clean("abc") = "abc"
|
|
||||||
* StringUtils.clean(" abc ") = "abc"
|
|
||||||
* StringUtils.clean(" ") = ""
|
|
||||||
* StringUtils.clean("") = ""
|
|
||||||
* StringUtils.clean(null) = ""
|
* StringUtils.clean(null) = ""
|
||||||
|
* StringUtils.clean("abc") = "abc"
|
||||||
|
* StringUtils.clean(" abc ") = "abc"
|
||||||
|
* StringUtils.clean(" ") = ""
|
||||||
|
* StringUtils.clean("") = ""
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* @see java.lang.String#trim()
|
* @see java.lang.String#trim()
|
||||||
|
@ -152,18 +152,19 @@ public class StringUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Removes control characters, including whitespace, from both
|
* <p>Removes control characters (char <= 32) from both
|
||||||
* ends of this String, handling <code>null</code> by returning
|
* ends of this String, handling <code>null</code> by returning
|
||||||
* <code>null</code>.</p>
|
* <code>null</code>.</p>
|
||||||
*
|
*
|
||||||
* <p>The string is trimmed using {@link String#trim()}.</p>
|
* <p>The string is trimmed using {@link String#trim()}.
|
||||||
|
* Trim removes start and end characters <= 32.</p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.trim("abc") = "abc"
|
|
||||||
* StringUtils.trim(" abc ") = "abc"
|
|
||||||
* StringUtils.trim(" ") = ""
|
|
||||||
* StringUtils.trim("") = ""
|
|
||||||
* StringUtils.trim(null) = null
|
* StringUtils.trim(null) = null
|
||||||
|
* StringUtils.trim("abc") = "abc"
|
||||||
|
* StringUtils.trim(" abc ") = "abc"
|
||||||
|
* StringUtils.trim(" ") = ""
|
||||||
|
* StringUtils.trim("") = ""
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* @see java.lang.String#trim()
|
* @see java.lang.String#trim()
|
||||||
|
@ -176,18 +177,19 @@ public class StringUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Removes control characters, including whitespace, from both
|
* <p>Removes control characters (char <= 32) from both
|
||||||
* ends of this string returning <code>null</code> if the string is
|
* ends of this string returning <code>null</code> if the string is
|
||||||
* empty ("") after the trim or if it is <code>null</code>.
|
* empty ("") after the trim or if it is <code>null</code>.
|
||||||
*
|
*
|
||||||
* <p>The string is trimmed using {@link String#trim()}.</p>
|
* <p>The string is trimmed using {@link String#trim()}.
|
||||||
|
* Trim removes start and end characters <= 32.</p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.trimToNull("abc") = "abc"
|
|
||||||
* StringUtils.trimToNull(" abc ") = "abc"
|
|
||||||
* StringUtils.trimToNull(" ") = null
|
|
||||||
* StringUtils.trimToNull("") = null
|
|
||||||
* StringUtils.trimToNull(null) = null
|
* StringUtils.trimToNull(null) = null
|
||||||
|
* StringUtils.trimToNull("abc") = "abc"
|
||||||
|
* StringUtils.trimToNull(" abc ") = "abc"
|
||||||
|
* StringUtils.trimToNull(" ") = null
|
||||||
|
* StringUtils.trimToNull("") = null
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* @see java.lang.String#trim()
|
* @see java.lang.String#trim()
|
||||||
|
@ -201,18 +203,19 @@ public class StringUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Removes control characters, including whitespace, from both
|
* <p>Removes control characters (char <= 32) from both
|
||||||
* ends of this string returning an empty string ("") if the string
|
* ends of this string returning an empty string ("") if the string
|
||||||
* is empty ("") after the trim or if it is <code>null</code>.
|
* is empty ("") after the trim or if it is <code>null</code>.
|
||||||
*
|
*
|
||||||
* <p>The string is trimmed using {@link String#trim()}.</p>
|
* <p>The string is trimmed using {@link String#trim()}.
|
||||||
|
* Trim removes start and end characters <= 32.</p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.trimToEmpty("abc") = "abc"
|
|
||||||
* StringUtils.trimToEmpty(" abc ") = "abc"
|
|
||||||
* StringUtils.trimToEmpty(" ") = ""
|
|
||||||
* StringUtils.trimToEmpty("") = ""
|
|
||||||
* StringUtils.trimToEmpty(null) = ""
|
* StringUtils.trimToEmpty(null) = ""
|
||||||
|
* StringUtils.trimToEmpty("abc") = "abc"
|
||||||
|
* StringUtils.trimToEmpty(" abc ") = "abc"
|
||||||
|
* StringUtils.trimToEmpty(" ") = ""
|
||||||
|
* StringUtils.trimToEmpty("") = ""
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* @see java.lang.String#trim()
|
* @see java.lang.String#trim()
|
||||||
|
@ -227,6 +230,14 @@ public class StringUtils {
|
||||||
* <p>Deletes all 'space' characters from a String as defined by
|
* <p>Deletes all 'space' characters from a String as defined by
|
||||||
* {@link Character#isSpace(char)}.</p>
|
* {@link Character#isSpace(char)}.</p>
|
||||||
*
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.deleteSpaces(null) = null
|
||||||
|
* StringUtils.deleteSpaces("abc") = "abc"
|
||||||
|
* StringUtils.deleteSpaces(" \t abc \n ") = "abc"
|
||||||
|
* StringUtils.deleteSpaces("ab c") = "abc"
|
||||||
|
* StringUtils.deleteSpaces("a\nb\tc ") = "abc"
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
* <p>Spaces are defined as <code>{' ', '\t', '\r', '\n', '\b'}</code>
|
* <p>Spaces are defined as <code>{' ', '\t', '\r', '\n', '\b'}</code>
|
||||||
* in line with the deprecated <code>isSpace</code> method.</p>
|
* in line with the deprecated <code>isSpace</code> method.</p>
|
||||||
*
|
*
|
||||||
|
@ -244,6 +255,12 @@ public class StringUtils {
|
||||||
* <p>Deletes all whitespaces from a String as defined by
|
* <p>Deletes all whitespaces from a String as defined by
|
||||||
* {@link Character#isWhitespace(char)}.</p>
|
* {@link Character#isWhitespace(char)}.</p>
|
||||||
*
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.deleteWhitespace(null) = null
|
||||||
|
* StringUtils.deleteWhitespace("abc") = "abc"
|
||||||
|
* StringUtils.deleteWhitespace(" abc ") = "abc"
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
* @param str the String to delete whitespace from, may be null
|
* @param str the String to delete whitespace from, may be null
|
||||||
* @return the String without whitespaces, <code>null</code> if null string input
|
* @return the String without whitespaces, <code>null</code> if null string input
|
||||||
*/
|
*/
|
||||||
|
@ -265,10 +282,11 @@ public class StringUtils {
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Checks if a String is <code>null</code> or empty ("").</p>
|
* <p>Checks if a String is empty ("").
|
||||||
|
* <code>null</code> returns <code>false</code></p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.isEmpty(null) = true
|
* StringUtils.isEmpty(null) = false
|
||||||
* StringUtils.isEmpty("") = true
|
* StringUtils.isEmpty("") = true
|
||||||
* StringUtils.isEmpty(" ") = false
|
* StringUtils.isEmpty(" ") = false
|
||||||
* StringUtils.isEmpty("bob") = false
|
* StringUtils.isEmpty("bob") = false
|
||||||
|
@ -276,43 +294,133 @@ public class StringUtils {
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* <p>NOTE: This method changed in version 2.0.
|
* <p>NOTE: This method changed in version 2.0.
|
||||||
* It no longer trims the String.
|
* It no longer trims the String, and null is no longer true.
|
||||||
* That functionality is available in isEmptyTrimmed().</p>
|
* That functionality is available in isEmptyTrimmedOrNull().</p>
|
||||||
*
|
*
|
||||||
* @param str the String to check, may be null
|
* @param str the String to check, may be null
|
||||||
* @return <code>true</code> if the String is <code>null</code> or empty
|
* @return <code>true</code> if the String is empty
|
||||||
*/
|
*/
|
||||||
public static boolean isEmpty(String str) {
|
public static boolean isEmpty(String str) {
|
||||||
return (str == null || str.length() == 0);
|
return (str != null && str.length() == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Checks if a String is not <code>null</code> and not empty ("").</p>
|
* <p>Checks if a String is not empty ("").
|
||||||
|
* <code>null</code> returns <code>true</code></p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.isNotEmpty(null) = false
|
* StringUtils.isNotEmpty(null) = true
|
||||||
* StringUtils.isNotEmpty("") = false
|
* StringUtils.isNotEmpty("") = false
|
||||||
* StringUtils.isNotEmpty(" ") = true
|
* StringUtils.isNotEmpty(" ") = true
|
||||||
* StringUtils.isNotEmpty("bob") = true
|
* StringUtils.isNotEmpty("bob") = true
|
||||||
* StringUtils.isNotEmpty(" bob ") = true
|
* StringUtils.isNotEmpty(" bob ") = true
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
|
* <p>NOTE: This method changed in version 2.0.
|
||||||
|
* It no longer returns false for null.
|
||||||
|
* That functionality is available in isNotEmptyOrNull().</p>
|
||||||
|
*
|
||||||
* @param str the String to check, may be null
|
* @param str the String to check, may be null
|
||||||
* @return <code>true</code> if the String is not <code>null</code> and not empty
|
* @return <code>true</code> if the String is not empty
|
||||||
*/
|
*/
|
||||||
public static boolean isNotEmpty(String str) {
|
public static boolean isNotEmpty(String str) {
|
||||||
|
return (str == null || str.length() > 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Checks if a String is empty ("") or <code>null</code>.</p>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.isEmptyOrNull(null) = true
|
||||||
|
* StringUtils.isEmptyOrNull("") = true
|
||||||
|
* StringUtils.isEmptyOrNull(" ") = false
|
||||||
|
* StringUtils.isEmptyOrNull("bob") = false
|
||||||
|
* StringUtils.isEmptyOrNull(" bob ") = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param str the String to check, may be null
|
||||||
|
* @return <code>true</code> if the String is empty or null
|
||||||
|
*/
|
||||||
|
public static boolean isEmptyOrNull(String str) {
|
||||||
|
return (str == null || str.length() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Checks if a String is not not empty ("") and not <code>null</code>.</p>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.isNotEmptyOrNull(null) = false
|
||||||
|
* StringUtils.isNotEmptyOrNull("") = false
|
||||||
|
* StringUtils.isNotEmptyOrNull(" ") = true
|
||||||
|
* StringUtils.isNotEmptyOrNull("bob") = true
|
||||||
|
* StringUtils.isNotEmptyOrNull(" bob ") = true
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @param str the String to check, may be null
|
||||||
|
* @return <code>true</code> if the String is neither empty nor null
|
||||||
|
*/
|
||||||
|
public static boolean isNotEmptyOrNull(String str) {
|
||||||
return (str != null && str.length() > 0);
|
return (str != null && str.length() > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Checks if a trimmed String is <code>null</code> or empty ("").</p>
|
* <p>Checks if a trimmed String is empty ("").
|
||||||
|
* <code>null</code> returns <code>false</code></p>
|
||||||
|
*
|
||||||
|
* <p>The string is trimmed using {@link String#trim()}.
|
||||||
|
* Trim removes start and end characters <= 32.</p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.isNotEmpty(null) = true
|
* StringUtils.isEmptyTrimmed(null) = false
|
||||||
* StringUtils.isNotEmpty("") = true
|
* StringUtils.isEmptyTrimmed("") = true
|
||||||
* StringUtils.isNotEmpty(" ") = true
|
* StringUtils.isEmptyTrimmed(" ") = true
|
||||||
* StringUtils.isNotEmpty("bob") = false
|
* StringUtils.isEmptyTrimmed("bob") = false
|
||||||
* StringUtils.isNotEmpty(" bob ") = false
|
* StringUtils.isEmptyTrimmed(" bob ") = false
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @see java.lang.String#trim()
|
||||||
|
* @param str the String to check, may be null
|
||||||
|
* @return <code>true</code> if the String is empty after trim()
|
||||||
|
*/
|
||||||
|
public static boolean isEmptyTrimmed(String str) {
|
||||||
|
return (str != null && str.trim().length() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Checks if a trimmed String is not empty ("").</p>
|
||||||
|
* <code>null</code> returns <code>true</code></p>
|
||||||
|
*
|
||||||
|
* <p>The string is trimmed using {@link String#trim()}.
|
||||||
|
* Trim removes start and end characters <= 32.</p>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.isNotEmptyTrimmed(null) = true
|
||||||
|
* StringUtils.isNotEmptyTrimmed("") = false
|
||||||
|
* StringUtils.isNotEmptyTrimmed(" ") = false
|
||||||
|
* StringUtils.isNotEmptyTrimmed("bob") = true
|
||||||
|
* StringUtils.isNotEmptyTrimmed(" bob ") = true
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
|
* @see java.lang.String#trim()
|
||||||
|
* @param str the String to check, may be null
|
||||||
|
* @return <code>true</code> if the String is not empty after trim()
|
||||||
|
*/
|
||||||
|
public static boolean isNotEmptyTrimmed(String str) {
|
||||||
|
return (str == null || str.trim().length() > 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <p>Checks if a trimmed String is empty ("") or <code>null</code>.</p>
|
||||||
|
*
|
||||||
|
* <p>The string is trimmed using {@link String#trim()}.
|
||||||
|
* Trim removes start and end characters <= 32.</p>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.isEmptyTrimmedOrNull(null) = true
|
||||||
|
* StringUtils.isEmptyTrimmedOrNull("") = true
|
||||||
|
* StringUtils.isEmptyTrimmedOrNull(" ") = true
|
||||||
|
* StringUtils.isEmptyTrimmedOrNull("bob") = false
|
||||||
|
* StringUtils.isEmptyTrimmedOrNull(" bob ") = false
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* @see java.lang.String#trim()
|
* @see java.lang.String#trim()
|
||||||
|
@ -320,19 +428,22 @@ public class StringUtils {
|
||||||
* @return <code>true</code> if the String is <code>null</code>
|
* @return <code>true</code> if the String is <code>null</code>
|
||||||
* or empty after trim()
|
* or empty after trim()
|
||||||
*/
|
*/
|
||||||
public static boolean isEmptyTrimmed(String str) {
|
public static boolean isEmptyTrimmedOrNull(String str) {
|
||||||
return (str == null || str.trim().length() == 0);
|
return (str == null || str.trim().length() == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Checks if a trimmed String is not <code>null</code> and not empty ("").</p>
|
* <p>Checks if a trimmed String is not empty ("") and not <code>null</code>.</p>
|
||||||
|
*
|
||||||
|
* <p>The string is trimmed using {@link String#trim()}.
|
||||||
|
* Trim removes start and end characters <= 32.</p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* StringUtils.isNotEmpty(null) = false
|
* StringUtils.isNotEmptyTrimmedOrNull(null) = false
|
||||||
* StringUtils.isNotEmpty("") = false
|
* StringUtils.isNotEmptyTrimmedOrNull("") = false
|
||||||
* StringUtils.isNotEmpty(" ") = false
|
* StringUtils.isNotEmptyTrimmedOrNull(" ") = false
|
||||||
* StringUtils.isNotEmpty("bob") = true
|
* StringUtils.isNotEmptyTrimmedOrNull("bob") = true
|
||||||
* StringUtils.isNotEmpty(" bob ") = true
|
* StringUtils.isNotEmptyTrimmedOrNull(" bob ") = true
|
||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* @see java.lang.String#trim()
|
* @see java.lang.String#trim()
|
||||||
|
@ -340,7 +451,7 @@ public class StringUtils {
|
||||||
* @return <code>true</code> if the String is not <code>null</code>
|
* @return <code>true</code> if the String is not <code>null</code>
|
||||||
* and not empty after trim()
|
* and not empty after trim()
|
||||||
*/
|
*/
|
||||||
public static boolean isNotEmptyTrimmed(String str) {
|
public static boolean isNotEmptyTrimmedOrNull(String str) {
|
||||||
return (str != null && str.trim().length() > 0);
|
return (str != null && str.trim().length() > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -375,7 +486,7 @@ public class StringUtils {
|
||||||
* <p>Compares two Strings, returning <code>true</code> if they are equal ignoring
|
* <p>Compares two Strings, returning <code>true</code> if they are equal ignoring
|
||||||
* the case.</p>
|
* the case.</p>
|
||||||
*
|
*
|
||||||
* <p><code>Nulls</code> are handled without exceptions. Two <code>null</code>
|
* <p><code>null</code>s are handled without exceptions. Two <code>null</code>
|
||||||
* references are considered equal. Comparison is case insensitive.</p>
|
* references are considered equal. Comparison is case insensitive.</p>
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
|
@ -401,6 +512,16 @@ public class StringUtils {
|
||||||
*
|
*
|
||||||
* <p><code>null</code> String will return <code>-1</code>.</p>
|
* <p><code>null</code> String will return <code>-1</code>.</p>
|
||||||
*
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.indexOfAny(null, null) = -1
|
||||||
|
* StringUtils.indexOfAny(null, ["ab","cd"]) = -1
|
||||||
|
* StringUtils.indexOfAny("zzabyycdxx", null) = -1
|
||||||
|
* StringUtils.indexOfAny("zzabyycdxx", []) = -1
|
||||||
|
* StringUtils.indexOfAny("zzabyycdxx", ["ab","cd"]) = 2
|
||||||
|
* StringUtils.indexOfAny("zzabyycdxx", ["cd","ab"]) = 2
|
||||||
|
* StringUtils.indexOfAny("zzabyycdxx", ["mn","op"]) = -1
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
* @param str the String to check, may be null
|
* @param str the String to check, may be null
|
||||||
* @param searchStrs the Strings to search for, may be null
|
* @param searchStrs the Strings to search for, may be null
|
||||||
* @return the first index of any of the searchStrs in str, -1 if no match
|
* @return the first index of any of the searchStrs in str, -1 if no match
|
||||||
|
@ -435,6 +556,16 @@ public class StringUtils {
|
||||||
*
|
*
|
||||||
* <p><code>null</code> string will return <code>-1</code>.</p>
|
* <p><code>null</code> string will return <code>-1</code>.</p>
|
||||||
*
|
*
|
||||||
|
* <pre>
|
||||||
|
* StringUtils.lastIndexOfAny(null, null) = -1
|
||||||
|
* StringUtils.lastIndexOfAny(null, ["ab","cd"]) = -1
|
||||||
|
* StringUtils.lastIndexOfAny("zzabyycdxx", null) = -1
|
||||||
|
* StringUtils.lastIndexOfAny("zzabyycdxx", []) = -1
|
||||||
|
* StringUtils.lastIndexOfAny("zzabyycdxx", ["ab","cd"]) = 6
|
||||||
|
* StringUtils.lastIndexOfAny("zzabyycdxx", ["cd","ab"]) = 6
|
||||||
|
* StringUtils.lastIndexOfAny("zzabyycdxx", ["mn","op"]) = -1
|
||||||
|
* </pre>
|
||||||
|
*
|
||||||
* @param str the String to check, may be null
|
* @param str the String to check, may be null
|
||||||
* @param searchStrs the Strings to search for, may be null
|
* @param searchStrs the Strings to search for, may be null
|
||||||
* @return the last index of any of the Strings, -1 if no match
|
* @return the last index of any of the Strings, -1 if no match
|
||||||
|
|
|
@ -201,7 +201,7 @@ import org.apache.commons.lang.StringUtils;
|
||||||
* @author Chris Webb
|
* @author Chris Webb
|
||||||
* @author Mike Bowler
|
* @author Mike Bowler
|
||||||
* @since 1.0
|
* @since 1.0
|
||||||
* @version $Id: Enum.java,v 1.12 2003/07/14 22:58:31 scolebourne Exp $
|
* @version $Id: Enum.java,v 1.13 2003/07/16 21:19:21 scolebourne Exp $
|
||||||
*/
|
*/
|
||||||
public abstract class Enum implements Comparable, Serializable {
|
public abstract class Enum implements Comparable, Serializable {
|
||||||
// After discussion, the default size for HashMaps is used, as the
|
// After discussion, the default size for HashMaps is used, as the
|
||||||
|
@ -243,14 +243,15 @@ public abstract class Enum implements Comparable, Serializable {
|
||||||
/**
|
/**
|
||||||
* <p>Constructor to add a new named item to the enumeration.</p>
|
* <p>Constructor to add a new named item to the enumeration.</p>
|
||||||
*
|
*
|
||||||
* @param name the name of the enum object
|
* @param name the name of the enum object,
|
||||||
|
* must not be empty or <code>null</code>
|
||||||
* @throws IllegalArgumentException if the name is <code>null</code>
|
* @throws IllegalArgumentException if the name is <code>null</code>
|
||||||
* or a blank string
|
* or an empty string
|
||||||
*/
|
*/
|
||||||
protected Enum(String name) {
|
protected Enum(String name) {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
if (StringUtils.isEmpty(name)) {
|
if (StringUtils.isEmptyOrNull(name)) {
|
||||||
throw new IllegalArgumentException("The Enum name must not be empty or null");
|
throw new IllegalArgumentException("The Enum name must not be empty or null");
|
||||||
}
|
}
|
||||||
iName = name;
|
iName = name;
|
||||||
|
|
|
@ -65,7 +65,7 @@ import org.apache.commons.lang.StringUtils;
|
||||||
* reflection.</p>
|
* reflection.</p>
|
||||||
*
|
*
|
||||||
* @author <a href="mailto:scolebourne@apache.org">Stephen Colebourne</a>
|
* @author <a href="mailto:scolebourne@apache.org">Stephen Colebourne</a>
|
||||||
* @version $Id: ReflectionUtils.java,v 1.7 2003/07/14 22:28:48 bayard Exp $
|
* @version $Id: ReflectionUtils.java,v 1.8 2003/07/16 21:19:22 scolebourne Exp $
|
||||||
*/
|
*/
|
||||||
public class ReflectionUtils {
|
public class ReflectionUtils {
|
||||||
|
|
||||||
|
@ -167,13 +167,14 @@ public class ReflectionUtils {
|
||||||
/**
|
/**
|
||||||
* <p>Gets a class object for the specified string.</p>
|
* <p>Gets a class object for the specified string.</p>
|
||||||
*
|
*
|
||||||
* @param className fully qualified class name to find, must not be empty
|
* @param className fully qualified class name to find,
|
||||||
|
* must not be empty or <code>null</code>
|
||||||
* @return Class object for class
|
* @return Class object for class
|
||||||
* @throws ReflectionException if an error occurs during reflection
|
* @throws ReflectionException if an error occurs during reflection
|
||||||
* @throws IllegalArgumentException if the class name is empty
|
* @throws IllegalArgumentException if the class name is empty
|
||||||
*/
|
*/
|
||||||
public static Class getClass(String className) throws ReflectionException {
|
public static Class getClass(String className) throws ReflectionException {
|
||||||
if (StringUtils.isEmpty(className)) {
|
if (StringUtils.isEmptyOrNull(className)) {
|
||||||
throw new IllegalArgumentException("The class name must not be null");
|
throw new IllegalArgumentException("The class name must not be null");
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -63,7 +63,7 @@ import junit.textui.TestRunner;
|
||||||
*
|
*
|
||||||
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
|
* @author <a href="mailto:scolebourne@joda.org">Stephen Colebourne</a>
|
||||||
* @author <a href="mailto:ridesmet@users.sourceforge.net">Ringo De Smet</a>
|
* @author <a href="mailto:ridesmet@users.sourceforge.net">Ringo De Smet</a>
|
||||||
* @version $Id: StringUtilsTrimEmptyTest.java,v 1.8 2003/07/14 22:26:22 scolebourne Exp $
|
* @version $Id: StringUtilsTrimEmptyTest.java,v 1.9 2003/07/16 21:19:22 scolebourne Exp $
|
||||||
*/
|
*/
|
||||||
public class StringUtilsTrimEmptyTest extends TestCase {
|
public class StringUtilsTrimEmptyTest extends TestCase {
|
||||||
private static final String FOO = "foo";
|
private static final String FOO = "foo";
|
||||||
|
@ -137,7 +137,7 @@ public class StringUtilsTrimEmptyTest extends TestCase {
|
||||||
assertEquals(false, StringUtils.isEmpty(" foo "));
|
assertEquals(false, StringUtils.isEmpty(" foo "));
|
||||||
assertEquals(false, StringUtils.isEmpty(" "));
|
assertEquals(false, StringUtils.isEmpty(" "));
|
||||||
assertEquals(true, StringUtils.isEmpty(""));
|
assertEquals(true, StringUtils.isEmpty(""));
|
||||||
assertEquals(true, StringUtils.isEmpty(null));
|
assertEquals(false, StringUtils.isEmpty(null));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testIsNotEmpty() {
|
public void testIsNotEmpty() {
|
||||||
|
@ -145,7 +145,23 @@ public class StringUtilsTrimEmptyTest extends TestCase {
|
||||||
assertEquals(true, StringUtils.isNotEmpty(" foo "));
|
assertEquals(true, StringUtils.isNotEmpty(" foo "));
|
||||||
assertEquals(true, StringUtils.isNotEmpty(" "));
|
assertEquals(true, StringUtils.isNotEmpty(" "));
|
||||||
assertEquals(false, StringUtils.isNotEmpty(""));
|
assertEquals(false, StringUtils.isNotEmpty(""));
|
||||||
assertEquals(false, StringUtils.isNotEmpty(null));
|
assertEquals(true, StringUtils.isNotEmpty(null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testIsEmptyOrNull() {
|
||||||
|
assertEquals(false, StringUtils.isEmptyOrNull("foo"));
|
||||||
|
assertEquals(false, StringUtils.isEmptyOrNull(" foo "));
|
||||||
|
assertEquals(false, StringUtils.isEmptyOrNull(" "));
|
||||||
|
assertEquals(true, StringUtils.isEmptyOrNull(""));
|
||||||
|
assertEquals(true, StringUtils.isEmptyOrNull(null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testIsNotEmptyOrNull() {
|
||||||
|
assertEquals(true, StringUtils.isNotEmptyOrNull("foo"));
|
||||||
|
assertEquals(true, StringUtils.isNotEmptyOrNull(" foo "));
|
||||||
|
assertEquals(true, StringUtils.isNotEmptyOrNull(" "));
|
||||||
|
assertEquals(false, StringUtils.isNotEmptyOrNull(""));
|
||||||
|
assertEquals(false, StringUtils.isNotEmptyOrNull(null));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testIsEmptyTrimmed() {
|
public void testIsEmptyTrimmed() {
|
||||||
|
@ -153,7 +169,7 @@ public class StringUtilsTrimEmptyTest extends TestCase {
|
||||||
assertEquals(false, StringUtils.isEmptyTrimmed(" foo "));
|
assertEquals(false, StringUtils.isEmptyTrimmed(" foo "));
|
||||||
assertEquals(true, StringUtils.isEmptyTrimmed(" "));
|
assertEquals(true, StringUtils.isEmptyTrimmed(" "));
|
||||||
assertEquals(true, StringUtils.isEmptyTrimmed(""));
|
assertEquals(true, StringUtils.isEmptyTrimmed(""));
|
||||||
assertEquals(true, StringUtils.isEmptyTrimmed(null));
|
assertEquals(false, StringUtils.isEmptyTrimmed(null));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testIsNotEmptyTrimmed() {
|
public void testIsNotEmptyTrimmed() {
|
||||||
|
@ -161,7 +177,23 @@ public class StringUtilsTrimEmptyTest extends TestCase {
|
||||||
assertEquals(true, StringUtils.isNotEmptyTrimmed(" foo "));
|
assertEquals(true, StringUtils.isNotEmptyTrimmed(" foo "));
|
||||||
assertEquals(false, StringUtils.isNotEmptyTrimmed(" "));
|
assertEquals(false, StringUtils.isNotEmptyTrimmed(" "));
|
||||||
assertEquals(false, StringUtils.isNotEmptyTrimmed(""));
|
assertEquals(false, StringUtils.isNotEmptyTrimmed(""));
|
||||||
assertEquals(false, StringUtils.isNotEmptyTrimmed(null));
|
assertEquals(true, StringUtils.isNotEmptyTrimmed(null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testIsEmptyTrimmedOrNull() {
|
||||||
|
assertEquals(false, StringUtils.isEmptyTrimmedOrNull("foo"));
|
||||||
|
assertEquals(false, StringUtils.isEmptyTrimmedOrNull(" foo "));
|
||||||
|
assertEquals(true, StringUtils.isEmptyTrimmedOrNull(" "));
|
||||||
|
assertEquals(true, StringUtils.isEmptyTrimmedOrNull(""));
|
||||||
|
assertEquals(true, StringUtils.isEmptyTrimmedOrNull(null));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testIsNotEmptyTrimmedOrNull() {
|
||||||
|
assertEquals(true, StringUtils.isNotEmptyTrimmedOrNull("foo"));
|
||||||
|
assertEquals(true, StringUtils.isNotEmptyTrimmedOrNull(" foo "));
|
||||||
|
assertEquals(false, StringUtils.isNotEmptyTrimmedOrNull(" "));
|
||||||
|
assertEquals(false, StringUtils.isNotEmptyTrimmedOrNull(""));
|
||||||
|
assertEquals(false, StringUtils.isNotEmptyTrimmedOrNull(null));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteSpace() {
|
public void testDeleteSpace() {
|
||||||
|
|
Loading…
Reference in New Issue