diff --git a/lucene/CHANGES.txt b/lucene/CHANGES.txt
index e244a3a369f..a4cae493b87 100644
--- a/lucene/CHANGES.txt
+++ b/lucene/CHANGES.txt
@@ -193,6 +193,8 @@ Improvements
* GITHUB#13092: `static final Map` constants have been made immutable (Dmitry Cherniachenko)
+* GITHUB#13041: TokenizedPhraseQueryNode code cleanup (Dmitry Cherniachenko)
+
Optimizations
---------------------
(No changes)
diff --git a/lucene/queryparser/src/java/org/apache/lucene/queryparser/flexible/core/nodes/TokenizedPhraseQueryNode.java b/lucene/queryparser/src/java/org/apache/lucene/queryparser/flexible/core/nodes/TokenizedPhraseQueryNode.java
index f5a7b0acab0..29710dce2af 100644
--- a/lucene/queryparser/src/java/org/apache/lucene/queryparser/flexible/core/nodes/TokenizedPhraseQueryNode.java
+++ b/lucene/queryparser/src/java/org/apache/lucene/queryparser/flexible/core/nodes/TokenizedPhraseQueryNode.java
@@ -32,10 +32,11 @@ public class TokenizedPhraseQueryNode extends QueryNodeImpl implements Fieldable
@Override
public String toString() {
- if (getChildren() == null || getChildren().size() == 0) return "";
+ List children = getChildren();
+ if (children == null || children.isEmpty()) return "";
StringBuilder sb = new StringBuilder();
- sb.append("");
- for (QueryNode child : getChildren()) {
+ sb.append("");
+ for (QueryNode child : children) {
sb.append("\n");
sb.append(child.toString());
}
@@ -46,16 +47,15 @@ public class TokenizedPhraseQueryNode extends QueryNodeImpl implements Fieldable
// This text representation is not re-parseable
@Override
public CharSequence toQueryString(EscapeQuerySyntax escapeSyntaxParser) {
- if (getChildren() == null || getChildren().size() == 0) return "";
-
+ List children = getChildren();
+ if (children == null || children.isEmpty()) return "";
StringBuilder sb = new StringBuilder();
String filler = "";
- for (QueryNode child : getChildren()) {
+ for (QueryNode child : children) {
sb.append(filler).append(child.toQueryString(escapeSyntaxParser));
filler = ",";
}
-
- return "[TP[" + sb.toString() + "]]";
+ return "[TP[" + sb + "]]";
}
@Override
@@ -70,27 +70,25 @@ public class TokenizedPhraseQueryNode extends QueryNodeImpl implements Fieldable
@Override
public CharSequence getField() {
List children = getChildren();
-
- if (children == null || children.size() == 0) {
- return null;
-
- } else {
- return ((FieldableNode) children.get(0)).getField();
+ if (children != null) {
+ for (QueryNode child : children) {
+ if (child instanceof FieldableNode) {
+ return ((FieldableNode) child).getField();
+ }
+ }
}
+ return null;
}
@Override
public void setField(CharSequence fieldName) {
List children = getChildren();
-
if (children != null) {
-
- for (QueryNode child : getChildren()) {
-
+ for (QueryNode child : children) {
if (child instanceof FieldableNode) {
((FieldableNode) child).setField(fieldName);
}
}
}
}
-} // end class MultitermQueryNode
+}