From cbea492bf0aa989113947adeae41c455679856c1 Mon Sep 17 00:00:00 2001 From: Dmitry Cherniachenko <2sabio@gmail.com> Date: Fri, 23 Feb 2024 11:41:53 +0100 Subject: [PATCH] Avoid allocating redundant Strings (#13085) --- .../gradle/ErrorReportingTestListener.java | 2 +- lucene/CHANGES.txt | 2 ++ .../lucene/analysis/br/BrazilianStemmer.java | 2 +- .../compound/hyphenation/PatternParser.java | 2 +- .../charfilter/TestHTMLStripCharFilter.java | 2 +- .../analysis/miscellaneous/TestTrimFilter.java | 16 +++++----------- .../pattern/TestPatternReplaceCharFilter.java | 4 ++-- .../byTask/feeds/EnwikiContentSource.java | 6 +++--- .../benchmark/byTask/feeds/TrecFBISParser.java | 2 +- .../benchmark/byTask/feeds/TrecFR94Parser.java | 4 ++-- .../benchmark/byTask/feeds/TrecFTParser.java | 2 +- .../byTask/feeds/TrecLATimesParser.java | 6 +++--- .../byTask/tasks/SearchWithSortTask.java | 2 +- .../simpletext/SimpleTextStoredFieldsReader.java | 2 +- .../java/org/apache/lucene/codecs/CodecUtil.java | 2 +- .../org/apache/lucene/index/IndexFileNames.java | 2 +- .../analysis/standard/TestStandardAnalyzer.java | 9 ++------- .../org/apache/lucene/index/TestPayloads.java | 7 ++----- .../apache/lucene/search/TestPrefixRandom.java | 2 +- .../apache/lucene/search/TestRegexpRandom2.java | 2 +- .../util/automaton/TestLevenshteinAutomata.java | 4 ++-- .../apache/lucene/util/automaton/TestRegExp.java | 2 +- .../search/uhighlight/UnifiedHighlighter.java | 2 +- .../surround/query/BooleanQueryTestFacade.java | 2 +- .../prefix/RecursivePrefixTreeStrategy.java | 2 +- .../analyzing/AnalyzingInfixSuggester.java | 2 +- .../analyzing/TestAnalyzingInfixSuggester.java | 2 +- .../org/apache/lucene/tests/util/English.java | 1 - .../apache/lucene/tests/util/LineFileDocs.java | 2 +- 29 files changed, 42 insertions(+), 55 deletions(-) diff --git a/buildSrc/src/main/java/org/apache/lucene/gradle/ErrorReportingTestListener.java b/buildSrc/src/main/java/org/apache/lucene/gradle/ErrorReportingTestListener.java index 9ba150909d83..64abfa5aec8a 100644 --- a/buildSrc/src/main/java/org/apache/lucene/gradle/ErrorReportingTestListener.java +++ b/buildSrc/src/main/java/org/apache/lucene/gradle/ErrorReportingTestListener.java @@ -113,7 +113,7 @@ public void afterSuite(final TestDescriptor suite, TestResult result) { if (echoOutput && !verboseMode) { synchronized (this) { - System.out.println(""); + System.out.println(); System.out.println(suite.getClassName() + " > test suite's output saved to " + outputLog + ", copied below:"); try (BufferedReader reader = Files.newBufferedReader(outputLog, StandardCharsets.UTF_8)) { char[] buf = new char[1024]; diff --git a/lucene/CHANGES.txt b/lucene/CHANGES.txt index a76b65b2f515..e9cf51846094 100644 --- a/lucene/CHANGES.txt +++ b/lucene/CHANGES.txt @@ -25,6 +25,8 @@ Optimizations * GITHUB#13115: Short circuit queued flush check when flush on update is disabled (Prabhat Sharma) +* GITHUB#13085: Remove unnecessary toString() / substring() calls to save some String allocations (Dmitry Cherniachenko) + Bug Fixes --------------------- (No changes) diff --git a/lucene/analysis/common/src/java/org/apache/lucene/analysis/br/BrazilianStemmer.java b/lucene/analysis/common/src/java/org/apache/lucene/analysis/br/BrazilianStemmer.java index 6958cbea155b..218170624663 100644 --- a/lucene/analysis/common/src/java/org/apache/lucene/analysis/br/BrazilianStemmer.java +++ b/lucene/analysis/common/src/java/org/apache/lucene/analysis/br/BrazilianStemmer.java @@ -278,7 +278,7 @@ private boolean suffix(String value, String suffix) { return false; } - return value.substring(value.length() - suffix.length()).equals(suffix); + return value.endsWith(suffix); } /** diff --git a/lucene/analysis/common/src/java/org/apache/lucene/analysis/compound/hyphenation/PatternParser.java b/lucene/analysis/common/src/java/org/apache/lucene/analysis/compound/hyphenation/PatternParser.java index 3f746491da53..7f176cccb305 100644 --- a/lucene/analysis/common/src/java/org/apache/lucene/analysis/compound/hyphenation/PatternParser.java +++ b/lucene/analysis/common/src/java/org/apache/lucene/analysis/compound/hyphenation/PatternParser.java @@ -142,7 +142,7 @@ protected String readToken(StringBuilder chars) { break; } } - token.append(chars.toString().substring(0, i)); + token.append(chars, 0, i); // chars.delete(0,i); for (int countr = i; countr < chars.length(); countr++) { chars.setCharAt(countr - i, chars.charAt(countr)); diff --git a/lucene/analysis/common/src/test/org/apache/lucene/analysis/charfilter/TestHTMLStripCharFilter.java b/lucene/analysis/common/src/test/org/apache/lucene/analysis/charfilter/TestHTMLStripCharFilter.java index 8e786aa59ccb..d5122406261f 100644 --- a/lucene/analysis/common/src/test/org/apache/lucene/analysis/charfilter/TestHTMLStripCharFilter.java +++ b/lucene/analysis/common/src/test/org/apache/lucene/analysis/charfilter/TestHTMLStripCharFilter.java @@ -669,7 +669,7 @@ public static void assertHTMLStripsTo(Reader input, String gold, Set esc builder.append((char) ch); } } catch (Exception e) { - if (gold.equals(builder.toString())) { + if (gold.contentEquals(builder)) { throw e; } throw new Exception( diff --git a/lucene/analysis/common/src/test/org/apache/lucene/analysis/miscellaneous/TestTrimFilter.java b/lucene/analysis/common/src/test/org/apache/lucene/analysis/miscellaneous/TestTrimFilter.java index 5b315cf3ce9d..33348e26d7ae 100644 --- a/lucene/analysis/common/src/test/org/apache/lucene/analysis/miscellaneous/TestTrimFilter.java +++ b/lucene/analysis/common/src/test/org/apache/lucene/analysis/miscellaneous/TestTrimFilter.java @@ -30,19 +30,13 @@ public class TestTrimFilter extends BaseTokenStreamTestCase { public void testTrim() throws Exception { - char[] a = " a ".toCharArray(); - char[] b = "b ".toCharArray(); - char[] ccc = "cCc".toCharArray(); - char[] whitespace = " ".toCharArray(); - char[] empty = "".toCharArray(); - TokenStream ts = new CannedTokenStream( - new Token(new String(a, 0, a.length), 1, 5), - new Token(new String(b, 0, b.length), 6, 10), - new Token(new String(ccc, 0, ccc.length), 11, 15), - new Token(new String(whitespace, 0, whitespace.length), 16, 20), - new Token(new String(empty, 0, empty.length), 21, 21)); + new Token(" a ", 1, 5), + new Token("b ", 6, 10), + new Token("cCc", 11, 15), + new Token(" ", 16, 20), + new Token("", 21, 21)); ts = new TrimFilter(ts); assertTokenStreamContents(ts, new String[] {"a", "b", "cCc", "", ""}); diff --git a/lucene/analysis/common/src/test/org/apache/lucene/analysis/pattern/TestPatternReplaceCharFilter.java b/lucene/analysis/common/src/test/org/apache/lucene/analysis/pattern/TestPatternReplaceCharFilter.java index e39bffb9c64e..06553575e5f4 100644 --- a/lucene/analysis/common/src/test/org/apache/lucene/analysis/pattern/TestPatternReplaceCharFilter.java +++ b/lucene/analysis/common/src/test/org/apache/lucene/analysis/pattern/TestPatternReplaceCharFilter.java @@ -82,8 +82,8 @@ private void checkOutput( indexMatched.append((cs.correctOffset(i) < 0 ? "-" : input.charAt(cs.correctOffset(i)))); } - boolean outputGood = expectedOutput.equals(output.toString()); - boolean indexMatchedGood = expectedIndexMatchedOutput.equals(indexMatched.toString()); + boolean outputGood = expectedOutput.contentEquals(output); + boolean indexMatchedGood = expectedIndexMatchedOutput.contentEquals(indexMatched); if (!outputGood || !indexMatchedGood || false) { System.out.println("Pattern : " + pattern); diff --git a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/EnwikiContentSource.java b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/EnwikiContentSource.java index 8caa25bd8d6a..cd0daa42d4bf 100644 --- a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/EnwikiContentSource.java +++ b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/EnwikiContentSource.java @@ -112,13 +112,13 @@ String[] next() throws NoMoreDataException { String time(String original) { StringBuilder buffer = new StringBuilder(); - buffer.append(original.substring(8, 10)); + buffer.append(original, 8, 10); buffer.append('-'); buffer.append(months[Integer.parseInt(original.substring(5, 7)) - 1]); buffer.append('-'); - buffer.append(original.substring(0, 4)); + buffer.append(original, 0, 4); buffer.append(' '); - buffer.append(original.substring(11, 19)); + buffer.append(original, 11, 19); buffer.append(".000"); return buffer.toString(); diff --git a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFBISParser.java b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFBISParser.java index cdce0b479fb2..f6ebae4158f0 100644 --- a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFBISParser.java +++ b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFBISParser.java @@ -60,7 +60,7 @@ public DocData parse( docData.setName(name); docData.setDate(date); docData.setTitle(title); - docData.setBody(stripTags(docBuf, mark).toString()); + docData.setBody(stripTags(docBuf, mark)); return docData; } } diff --git a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFR94Parser.java b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFR94Parser.java index e2dae3ab7753..06a4f0fbdd1e 100644 --- a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFR94Parser.java +++ b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFR94Parser.java @@ -53,14 +53,14 @@ public DocData parse( // date... String dateStr = extract(docBuf, DATE, DATE_END, h2, DATE_NOISE_PREFIXES); if (dateStr != null) { - dateStr = stripTags(dateStr, 0).toString(); + dateStr = stripTags(dateStr, 0); date = trecSrc.parseDate(dateStr.trim()); } } docData.clear(); docData.setName(name); docData.setDate(date); - docData.setBody(stripTags(docBuf, mark).toString()); + docData.setBody(stripTags(docBuf, mark)); return docData; } } diff --git a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFTParser.java b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFTParser.java index 57762e884f0b..a0d8e570cfac 100644 --- a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFTParser.java +++ b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecFTParser.java @@ -52,7 +52,7 @@ public DocData parse( docData.setName(name); docData.setDate(date); docData.setTitle(title); - docData.setBody(stripTags(docBuf, mark).toString()); + docData.setBody(stripTags(docBuf, mark)); return docData; } } diff --git a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecLATimesParser.java b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecLATimesParser.java index 933859e0ddb7..186465a6a0d3 100644 --- a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecLATimesParser.java +++ b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/feeds/TrecLATimesParser.java @@ -49,7 +49,7 @@ public DocData parse( if (d2a > 0) { dateStr = dateStr.substring(0, d2a + 3); // we need the "day" part } - dateStr = stripTags(dateStr, 0).toString(); + dateStr = stripTags(dateStr, 0); date = trecSrc.parseDate(dateStr.trim()); } @@ -59,14 +59,14 @@ public DocData parse( title = extract(docBuf, HEADLINE, HEADLINE_END, -1, null); } if (title != null) { - title = stripTags(title, 0).toString().trim(); + title = stripTags(title, 0).trim(); } docData.clear(); docData.setName(name); docData.setDate(date); docData.setTitle(title); - docData.setBody(stripTags(docBuf, mark).toString()); + docData.setBody(stripTags(docBuf, mark)); return docData; } } diff --git a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/SearchWithSortTask.java b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/SearchWithSortTask.java index e8eb8f27042a..8dc1ace31770 100644 --- a/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/SearchWithSortTask.java +++ b/lucene/benchmark/src/java/org/apache/lucene/benchmark/byTask/tasks/SearchWithSortTask.java @@ -59,7 +59,7 @@ public void setParams(String sortField) { String typeString; if (index != -1) { fieldName = field.substring(0, index); - typeString = field.substring(1 + index, field.length()); + typeString = field.substring(1 + index); } else { throw new RuntimeException("You must specify the sort type ie page:int,subject:string"); } diff --git a/lucene/codecs/src/java/org/apache/lucene/codecs/simpletext/SimpleTextStoredFieldsReader.java b/lucene/codecs/src/java/org/apache/lucene/codecs/simpletext/SimpleTextStoredFieldsReader.java index b0c19e8526ef..d95e82f62ecc 100644 --- a/lucene/codecs/src/java/org/apache/lucene/codecs/simpletext/SimpleTextStoredFieldsReader.java +++ b/lucene/codecs/src/java/org/apache/lucene/codecs/simpletext/SimpleTextStoredFieldsReader.java @@ -169,7 +169,7 @@ private void readField(BytesRef type, FieldInfo fieldInfo, StoredFieldVisitor vi if (type == TYPE_STRING) { byte[] bytes = new byte[scratch.length() - VALUE.length]; System.arraycopy(scratch.bytes(), VALUE.length, bytes, 0, bytes.length); - visitor.stringField(fieldInfo, new String(bytes, 0, bytes.length, StandardCharsets.UTF_8)); + visitor.stringField(fieldInfo, new String(bytes, StandardCharsets.UTF_8)); } else if (type == TYPE_BINARY) { byte[] copy = new byte[scratch.length() - VALUE.length]; System.arraycopy(scratch.bytes(), VALUE.length, copy, 0, copy.length); diff --git a/lucene/core/src/java/org/apache/lucene/codecs/CodecUtil.java b/lucene/core/src/java/org/apache/lucene/codecs/CodecUtil.java index 525381d60c94..bdfa78af87f1 100644 --- a/lucene/core/src/java/org/apache/lucene/codecs/CodecUtil.java +++ b/lucene/core/src/java/org/apache/lucene/codecs/CodecUtil.java @@ -380,7 +380,7 @@ public static String checkIndexHeaderSuffix(DataInput in, String expectedSuffix) int suffixLength = in.readByte() & 0xFF; byte[] suffixBytes = new byte[suffixLength]; in.readBytes(suffixBytes, 0, suffixBytes.length); - String suffix = new String(suffixBytes, 0, suffixBytes.length, StandardCharsets.UTF_8); + String suffix = new String(suffixBytes, StandardCharsets.UTF_8); if (!suffix.equals(expectedSuffix)) { throw new CorruptIndexException( "file mismatch, expected suffix=" + expectedSuffix + ", got=" + suffix, in); diff --git a/lucene/core/src/java/org/apache/lucene/index/IndexFileNames.java b/lucene/core/src/java/org/apache/lucene/index/IndexFileNames.java index 968900c7f0cc..b8459e42afa8 100644 --- a/lucene/core/src/java/org/apache/lucene/index/IndexFileNames.java +++ b/lucene/core/src/java/org/apache/lucene/index/IndexFileNames.java @@ -191,7 +191,7 @@ public static String getExtension(String filename) { if (idx == -1) { return null; } else { - return filename.substring(idx + 1, filename.length()); + return filename.substring(idx + 1); } } diff --git a/lucene/core/src/test/org/apache/lucene/analysis/standard/TestStandardAnalyzer.java b/lucene/core/src/test/org/apache/lucene/analysis/standard/TestStandardAnalyzer.java index 8fbe03596986..b51cdf863066 100644 --- a/lucene/core/src/test/org/apache/lucene/analysis/standard/TestStandardAnalyzer.java +++ b/lucene/core/src/test/org/apache/lucene/analysis/standard/TestStandardAnalyzer.java @@ -677,16 +677,11 @@ public void testNormalize() { public void testMaxTokenLengthDefault() throws Exception { StandardAnalyzer a = new StandardAnalyzer(); - StringBuilder bToken = new StringBuilder(); // exact max length: - for (int i = 0; i < StandardAnalyzer.DEFAULT_MAX_TOKEN_LENGTH; i++) { - bToken.append('b'); - } - - String bString = bToken.toString(); + String bString = "b".repeat(StandardAnalyzer.DEFAULT_MAX_TOKEN_LENGTH); // first bString is exact max default length; next one is 1 too long String input = "x " + bString + " " + bString + "b"; - assertAnalyzesTo(a, input.toString(), new String[] {"x", bString, bString, "b"}); + assertAnalyzesTo(a, input, new String[] {"x", bString, bString, "b"}); a.close(); } diff --git a/lucene/core/src/test/org/apache/lucene/index/TestPayloads.java b/lucene/core/src/test/org/apache/lucene/index/TestPayloads.java index 4174b77827b7..b7b9a8fbf2ce 100644 --- a/lucene/core/src/test/org/apache/lucene/index/TestPayloads.java +++ b/lucene/core/src/test/org/apache/lucene/index/TestPayloads.java @@ -18,7 +18,6 @@ import java.io.IOException; import java.io.StringReader; -import java.nio.charset.Charset; import java.nio.charset.StandardCharsets; import java.util.ArrayList; import java.util.HashMap; @@ -289,12 +288,10 @@ private void performTest(Directory dir) throws Exception { reader.close(); } - static final Charset utf8 = StandardCharsets.UTF_8; - private void generateRandomData(byte[] data) { // this test needs the random data to be valid unicode String s = TestUtil.randomFixedByteLengthUnicodeString(random(), data.length); - byte[] b = s.getBytes(utf8); + byte[] b = s.getBytes(StandardCharsets.UTF_8); assert b.length == data.length; System.arraycopy(b, 0, data, 0, b.length); } @@ -493,7 +490,7 @@ private class PoolingPayloadTokenStream extends TokenStream { this.pool = pool; payload = pool.get(); generateRandomData(payload); - term = new String(payload, 0, payload.length, utf8); + term = new String(payload, StandardCharsets.UTF_8); first = true; payloadAtt = addAttribute(PayloadAttribute.class); termAtt = addAttribute(CharTermAttribute.class); diff --git a/lucene/core/src/test/org/apache/lucene/search/TestPrefixRandom.java b/lucene/core/src/test/org/apache/lucene/search/TestPrefixRandom.java index 80f61e6d1718..0cb8b0830571 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestPrefixRandom.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestPrefixRandom.java @@ -107,7 +107,7 @@ protected AcceptStatus accept(BytesRef term) throws IOException { @Override public String toString(String field) { - return field.toString() + ":" + prefix.toString(); + return field + ":" + prefix; } @Override diff --git a/lucene/core/src/test/org/apache/lucene/search/TestRegexpRandom2.java b/lucene/core/src/test/org/apache/lucene/search/TestRegexpRandom2.java index f8bddb7f4cbb..2c580e832d3c 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestRegexpRandom2.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestRegexpRandom2.java @@ -139,7 +139,7 @@ protected AcceptStatus accept(BytesRef term) throws IOException { @Override public String toString(String field) { - return field.toString() + automaton.toString(); + return field + automaton; } @Override diff --git a/lucene/core/src/test/org/apache/lucene/util/automaton/TestLevenshteinAutomata.java b/lucene/core/src/test/org/apache/lucene/util/automaton/TestLevenshteinAutomata.java index c112fd3fbc15..be1237480b59 100644 --- a/lucene/core/src/test/org/apache/lucene/util/automaton/TestLevenshteinAutomata.java +++ b/lucene/core/src/test/org/apache/lucene/util/automaton/TestLevenshteinAutomata.java @@ -212,10 +212,10 @@ private Automaton transpositionsOf(String s) { List list = new ArrayList<>(); for (int i = 0; i < s.length() - 1; i++) { StringBuilder sb = new StringBuilder(); - sb.append(s.substring(0, i)); + sb.append(s, 0, i); sb.append(s.charAt(i + 1)); sb.append(s.charAt(i)); - sb.append(s.substring(i + 2, s.length())); + sb.append(s, i + 2, s.length()); String st = sb.toString(); if (!st.equals(s)) { list.add(Automata.makeString(st)); diff --git a/lucene/core/src/test/org/apache/lucene/util/automaton/TestRegExp.java b/lucene/core/src/test/org/apache/lucene/util/automaton/TestRegExp.java index 09f8a38a7019..625530bb3158 100644 --- a/lucene/core/src/test/org/apache/lucene/util/automaton/TestRegExp.java +++ b/lucene/core/src/test/org/apache/lucene/util/automaton/TestRegExp.java @@ -159,7 +159,7 @@ protected String checkRandomExpression(String docValue) { // Add any head to the result, unchanged if (substitutionPoint > 0) { - result.append(docValue.substring(0, substitutionPoint)); + result.append(docValue, 0, substitutionPoint); } // Modify the middle... diff --git a/lucene/highlighter/src/java/org/apache/lucene/search/uhighlight/UnifiedHighlighter.java b/lucene/highlighter/src/java/org/apache/lucene/search/uhighlight/UnifiedHighlighter.java index 615db5ecd5ff..7789e24c66d5 100644 --- a/lucene/highlighter/src/java/org/apache/lucene/search/uhighlight/UnifiedHighlighter.java +++ b/lucene/highlighter/src/java/org/apache/lucene/search/uhighlight/UnifiedHighlighter.java @@ -1398,7 +1398,7 @@ public void stringField(FieldInfo fieldInfo, String value) throws IOException { curValueBuilder.append(curValue); } curValueBuilder.append(valueSeparator); - curValueBuilder.append(value.substring(0, Math.min(lengthBudget - 1, value.length()))); + curValueBuilder.append(value, 0, Math.min(lengthBudget - 1, value.length())); values[currentField] = curValueBuilder; } diff --git a/lucene/queryparser/src/test/org/apache/lucene/queryparser/surround/query/BooleanQueryTestFacade.java b/lucene/queryparser/src/test/org/apache/lucene/queryparser/surround/query/BooleanQueryTestFacade.java index 83b1d78d6856..d5da92c53006 100644 --- a/lucene/queryparser/src/test/org/apache/lucene/queryparser/surround/query/BooleanQueryTestFacade.java +++ b/lucene/queryparser/src/test/org/apache/lucene/queryparser/surround/query/BooleanQueryTestFacade.java @@ -114,7 +114,7 @@ void checkNrHits() { public void doTest() throws Exception { if (verbose) { - System.out.println(""); + System.out.println(); System.out.println("Query: " + queryText); } diff --git a/lucene/spatial-extras/src/java/org/apache/lucene/spatial/prefix/RecursivePrefixTreeStrategy.java b/lucene/spatial-extras/src/java/org/apache/lucene/spatial/prefix/RecursivePrefixTreeStrategy.java index 8fe372feec34..642f466bc03b 100644 --- a/lucene/spatial-extras/src/java/org/apache/lucene/spatial/prefix/RecursivePrefixTreeStrategy.java +++ b/lucene/spatial-extras/src/java/org/apache/lucene/spatial/prefix/RecursivePrefixTreeStrategy.java @@ -113,7 +113,7 @@ public String toString() { if (pointsOnly) str.append(",pointsOnly"); if (pruneLeafyBranches) str.append(",pruneLeafyBranches"); if (prefixGridScanLevel != grid.getMaxLevels() - 4) - str.append(",prefixGridScanLevel:").append("").append(prefixGridScanLevel); + str.append(",prefixGridScanLevel:").append(prefixGridScanLevel); if (!multiOverlappingIndexedShapes) str.append(",!multiOverlappingIndexedShapes"); return str.append(')').toString(); } diff --git a/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java b/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java index e1772102098b..afaf304a4ad9 100644 --- a/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java +++ b/lucene/suggest/src/java/org/apache/lucene/search/suggest/analyzing/AnalyzingInfixSuggester.java @@ -927,7 +927,7 @@ protected void addPrefixMatch( return; } sb.append(""); - sb.append(surface.substring(0, prefixToken.length())); + sb.append(surface, 0, prefixToken.length()); sb.append(""); sb.append(surface.substring(prefixToken.length())); } diff --git a/lucene/suggest/src/test/org/apache/lucene/search/suggest/analyzing/TestAnalyzingInfixSuggester.java b/lucene/suggest/src/test/org/apache/lucene/search/suggest/analyzing/TestAnalyzingInfixSuggester.java index 2361f6b0c310..6983c7eba595 100644 --- a/lucene/suggest/src/test/org/apache/lucene/search/suggest/analyzing/TestAnalyzingInfixSuggester.java +++ b/lucene/suggest/src/test/org/apache/lucene/search/suggest/analyzing/TestAnalyzingInfixSuggester.java @@ -892,7 +892,7 @@ private static String hilite(boolean lastPrefix, String[] inputTerms, String[] q b.append(""); b.append(queryTerm); b.append(""); - b.append(inputTerm.substring(queryTerm.length(), inputTerm.length())); + b.append(inputTerm.substring(queryTerm.length())); matched = true; break; } diff --git a/lucene/test-framework/src/java/org/apache/lucene/tests/util/English.java b/lucene/test-framework/src/java/org/apache/lucene/tests/util/English.java index c78fb7ac3627..5b48b617e721 100644 --- a/lucene/test-framework/src/java/org/apache/lucene/tests/util/English.java +++ b/lucene/test-framework/src/java/org/apache/lucene/tests/util/English.java @@ -166,7 +166,6 @@ public static void longToEnglish(long i, StringBuilder result) { result.append("one "); break; case 0: - result.append(""); break; } } diff --git a/lucene/test-framework/src/java/org/apache/lucene/tests/util/LineFileDocs.java b/lucene/test-framework/src/java/org/apache/lucene/tests/util/LineFileDocs.java index e0158c4c5420..91b897ffb70f 100644 --- a/lucene/test-framework/src/java/org/apache/lucene/tests/util/LineFileDocs.java +++ b/lucene/test-framework/src/java/org/apache/lucene/tests/util/LineFileDocs.java @@ -307,7 +307,7 @@ public Document nextDoc() throws IOException { throw new RuntimeException("line: [" + line + "] is in an invalid format !"); } - docState.body.setStringValue(line.substring(1 + spot2, line.length())); + docState.body.setStringValue(line.substring(1 + spot2)); final String title = line.substring(0, spot); docState.title.setStringValue(title); docState.titleTokenized.setStringValue(title);