Applying Robert Scholte's patch from LANG-422, adding a appendSeparator with an alternative default separator if the StrBuilder is currently empty

git-svn-id: https://svn.apache.org/repos/asf/commons/proper/lang/trunk@826969 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Henri Yandell 2009-10-20 06:10:10 +00:00
parent dbf4cd5f42
commit 13a0cc63cd
2 changed files with 89 additions and 3 deletions

View File

@ -68,6 +68,7 @@ import org.apache.commons.lang.SystemUtils;
* the interface.
*
* @author Stephen Colebourne
* @author Robert Scholte
* @since 2.2
* @version $Id$
*/
@ -1096,8 +1097,40 @@ public class StrBuilder implements CharSequence, Appendable {
* @since 2.3
*/
public StrBuilder appendSeparator(String separator) {
if (separator != null && size() > 0) {
append(separator);
return appendSeparator(separator, null);
}
/**
* Appends one of both separators to the StrBuilder.
* If the builder is currently empty it will append the defaultIfEmpty-separator
* Otherwise it will append the standard-separator
*
* Appending a null separator will have no effect.
* The separator is appended using {@link #append(String)}.
* <p>
* This method is for example useful for constructing queries
* <pre>
* StrBuilder whereClause = new StrBuilder();
* if(searchCommand.getPriority() != null) {
* whereClause.appendSeparator(" and", " where");
* whereClause.append(" priority = ?")
* }
* if(searchCommand.getComponent() != null) {
* whereClause.appendSeparator(" and", " where");
* whereClause.append(" component = ?")
* }
* selectClause.append(whereClause)
* </pre>
*
* @param standard the separator if builder is not empty, null means no separator
* @param defaultIfEmpty the separator if builder is empty, null means no separator
* @return this, to enable chaining
* @since 3.0
*/
public StrBuilder appendSeparator(String standard, String defaultIfEmpty) {
String str = isEmpty() ? defaultIfEmpty : standard;
if (str != null) {
append(str);
}
return this;
}
@ -1128,6 +1161,26 @@ public class StrBuilder implements CharSequence, Appendable {
return this;
}
/**
* Append one of both separators to the builder
* If the builder is currently empty it will append the defaultIfEmpty-separator
* Otherwise it will append the standard-separator
*
* The separator is appended using {@link #append(char)}.
* @param standard the separator if builder is not empty
* @param defaultIfEmpty the separator if builder is empty
* @return this, to enable chaining
* @since 3.0
*/
public StrBuilder appendSeparator(char standard, char defaultIfEmpty) {
if (size() > 0) {
append(standard);
}
else {
append(defaultIfEmpty);
}
return this;
}
/**
* Appends a separator to the builder if the loop index is greater than zero.
* Appending a null separator will have no effect.

View File

@ -994,6 +994,28 @@ public class StrBuilderAppendInsertTest extends TestCase {
assertEquals("foo,", sb.toString());
}
//-----------------------------------------------------------------------
public void testAppendSeparator_String_String() {
StrBuilder sb = new StrBuilder();
final String startSeparator = "order by ";
final String standardSeparator = ",";
final String foo = "foo";
sb.appendSeparator(null, null);
assertEquals("", sb.toString());
sb.appendSeparator(standardSeparator, null);
assertEquals("", sb.toString());
sb.appendSeparator(standardSeparator, startSeparator);
assertEquals(startSeparator, sb.toString());
sb.appendSeparator(null, null);
assertEquals(startSeparator, sb.toString());
sb.appendSeparator(null, startSeparator);
assertEquals(startSeparator, sb.toString());
sb.append(foo);
assertEquals(startSeparator + foo, sb.toString());
sb.appendSeparator(standardSeparator, startSeparator);
assertEquals(startSeparator + foo + standardSeparator, sb.toString());
}
//-----------------------------------------------------------------------
public void testAppendSeparator_char() {
StrBuilder sb = new StrBuilder();
@ -1004,6 +1026,18 @@ public class StrBuilderAppendInsertTest extends TestCase {
sb.appendSeparator(',');
assertEquals("foo,", sb.toString());
}
public void testAppendSeparator_char_char() {
StrBuilder sb = new StrBuilder();
final char startSeparator = ':';
final char standardSeparator = ',';
final String foo = "foo";
sb.appendSeparator(standardSeparator, startSeparator); // no effect
assertEquals(String.valueOf(startSeparator), sb.toString());
sb.append(foo);
assertEquals(String.valueOf(startSeparator) + foo, sb.toString());
sb.appendSeparator(standardSeparator, startSeparator);
assertEquals(String.valueOf(startSeparator) + foo + standardSeparator, sb.toString());
}
//-----------------------------------------------------------------------
public void testAppendSeparator_String_int() {
@ -1356,5 +1390,4 @@ public class StrBuilderAppendInsertTest extends TestCase {
sb.insert(0, (char[]) null, 0, 0);
assertEquals("nullnullfoonullbarbaz", sb.toString());
}
}