Remove length check from StringUtils.matchToClosingParenthesis

This commit is contained in:
XiangRongLin 2021-07-31 16:05:24 +02:00
parent 852a65ff18
commit 37df225556

View File

@ -9,10 +9,11 @@ public class StringUtils {
} }
/** /**
* @param string The string to search in * @param string The string to search in.
* @param start A string from which to start searching. * @param start A string from which to start searching.
* @return A substring where each '{' matches a '}' * @return A substring where each '{' matches a '}'.
* @throws IndexOutOfBoundsException If {@code string} does not contain {@code start} * @throws IndexOutOfBoundsException If {@code string} does not contain {@code start}
* or parenthesis could not be matched .
*/ */
@Nonnull @Nonnull
public static String matchToClosingParenthesis(@Nonnull final String string, @Nonnull final String start) { public static String matchToClosingParenthesis(@Nonnull final String string, @Nonnull final String start) {
@ -29,8 +30,7 @@ public class StringUtils {
++endIndex; ++endIndex;
int openParenthesis = 1; int openParenthesis = 1;
int length = string.length(); while (openParenthesis > 0) {
while (openParenthesis > 0 && endIndex < length) {
switch (string.charAt(endIndex)) { switch (string.charAt(endIndex)) {
case '{': case '{':
++openParenthesis; ++openParenthesis;