Merge branch 'fix-LANG-1118'
LANG-1118: StringUtils.repeat('z', -1) throws NegativeArraySizeException. Thanks to Loic Guibert.
This commit is contained in:
commit
0799f01df1
|
@ -22,6 +22,7 @@
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<release version="3.5" date="tba" description="tba">
|
<release version="3.5" date="tba" description="tba">
|
||||||
|
<action issue="LANG-1118" type="fix" dev="britter" due-to="Loic Guibert">StringUtils.repeat('z', -1) throws NegativeArraySizeException</action>
|
||||||
<action issue="LANG-1099" type="add" dev="britter" due-to="Adrian Ber">Add swap and shift operations for arrays to ArrayUtils</action>
|
<action issue="LANG-1099" type="add" dev="britter" due-to="Adrian Ber">Add swap and shift operations for arrays to ArrayUtils</action>
|
||||||
<action issue="LANG-979" type="update" dev="britter" due-to="Bruno P. Kinoshita">TypeUtils.parameterizeWithOwner - wrong format descriptor for "invalid number of type parameters".</action>
|
<action issue="LANG-979" type="update" dev="britter" due-to="Bruno P. Kinoshita">TypeUtils.parameterizeWithOwner - wrong format descriptor for "invalid number of type parameters".</action>
|
||||||
<action issue="LANG-1112" type="update" dev="britter">MultilineRecursiveToStringStyle largely unusable due to being package-private.</action>
|
<action issue="LANG-1112" type="update" dev="britter">MultilineRecursiveToStringStyle largely unusable due to being package-private.</action>
|
||||||
|
|
|
@ -5233,6 +5233,9 @@ public class StringUtils {
|
||||||
* @see #repeat(String, int)
|
* @see #repeat(String, int)
|
||||||
*/
|
*/
|
||||||
public static String repeat(final char ch, final int repeat) {
|
public static String repeat(final char ch, final int repeat) {
|
||||||
|
if (repeat <= 0) {
|
||||||
|
return EMPTY;
|
||||||
|
}
|
||||||
final char[] buf = new char[repeat];
|
final char[] buf = new char[repeat];
|
||||||
for (int i = repeat - 1; i >= 0; i--) {
|
for (int i = repeat - 1; i >= 0; i--) {
|
||||||
buf[i] = ch;
|
buf[i] = ch;
|
||||||
|
|
|
@ -1353,6 +1353,7 @@ public class StringUtilsTest {
|
||||||
assertEquals("", StringUtils.repeat("ab", 0));
|
assertEquals("", StringUtils.repeat("ab", 0));
|
||||||
assertEquals("", StringUtils.repeat("", 3));
|
assertEquals("", StringUtils.repeat("", 3));
|
||||||
assertEquals("aaa", StringUtils.repeat("a", 3));
|
assertEquals("aaa", StringUtils.repeat("a", 3));
|
||||||
|
assertEquals("", StringUtils.repeat("a", -2));
|
||||||
assertEquals("ababab", StringUtils.repeat("ab", 3));
|
assertEquals("ababab", StringUtils.repeat("ab", 3));
|
||||||
assertEquals("abcabcabc", StringUtils.repeat("abc", 3));
|
assertEquals("abcabcabc", StringUtils.repeat("abc", 3));
|
||||||
final String str = StringUtils.repeat("a", 10000); // bigger than pad limit
|
final String str = StringUtils.repeat("a", 10000); // bigger than pad limit
|
||||||
|
@ -1374,6 +1375,13 @@ public class StringUtilsTest {
|
||||||
assertEquals("?, ?, ?", StringUtils.repeat("?", ", ", 3));
|
assertEquals("?, ?, ?", StringUtils.repeat("?", ", ", 3));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRepeat_CharInt() {
|
||||||
|
assertEquals("zzz", StringUtils.repeat('z', 3));
|
||||||
|
assertEquals("", StringUtils.repeat('z', 0));
|
||||||
|
assertEquals("", StringUtils.repeat('z', -2));
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testChop() {
|
public void testChop() {
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue