--- /dev/null
+package org.apache.lucene.queryParser.standard.nodes;
+
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import java.text.Collator;
+
+import org.apache.lucene.queryParser.core.nodes.FieldQueryNode;
+import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode;
+import org.apache.lucene.queryParser.core.nodes.ParametricQueryNode.CompareOperator;
+import org.apache.lucene.queryParser.standard.config.StandardQueryConfigHandler.ConfigurationKeys;
+import org.apache.lucene.queryParser.standard.processors.ParametricRangeQueryNodeProcessor;
+
+/**
+ * This query node represents a range query. It also holds which collator will
+ * be used by the range query and if the constant score rewrite is enabled. <br/>
+ *
+ * @see ParametricRangeQueryNodeProcessor
+ * @see ConfigurationKeys#RANGE_COLLATOR
+ * @see org.apache.lucene.search.TermRangeQuery
+ *
+ * @deprecated this class will be removed in future, {@link TermRangeQueryNode} should
+ * be used instead
+ */
+@Deprecated
+public class RangeQueryNode extends TermRangeQueryNode {
+
+ private static final long serialVersionUID = 7400866652044314657L;
+
+ private Collator collator;
+
+ /**
+ * @param lower
+ * @param upper
+ */
+ public RangeQueryNode(ParametricQueryNode lower, ParametricQueryNode upper,
+ Collator collator) {
+
+ super(lower, upper, lower.getOperator() == CompareOperator.LE, upper
+ .getOperator() == CompareOperator.GE);
+
+ this.collator = collator;
+
+ }
+
+ @Override
+ public ParametricQueryNode getLowerBound() {
+ return (ParametricQueryNode) super.getLowerBound();
+ }
+
+ @Override
+ public ParametricQueryNode getUpperBound() {
+ return (ParametricQueryNode) super.getUpperBound();
+ }
+
+ /**
+ * Sets lower and upper bounds. The method signature expects
+ * {@link FieldQueryNode} objects as lower and upper, however,
+ * an {@link IllegalArgumentException} will be thrown at runtime
+ * if a non {@link ParametricQueryNode} is passed as lower and upper.
+ *
+ * @param lower a {@link ParametricQueryNode} object
+ * @param upper a {@link ParametricQueryNode} object
+ * @param lowerInclusive <code>true</code> if lower bound is inclusive, otherwise, <code>false</code>
+ * @param upperInclusive <code>true</code> if upper bound is inclusive, otherwise, <code>false</code>
+ *
+ * @throws IllegalArgumentException if lower or upper are not instance of {@link ParametricQueryNode}
+ *
+ * @see AbstractRangeQueryNode#setBounds
+ */
+ @Override
+ public void setBounds(FieldQueryNode lower, FieldQueryNode upper,
+ boolean lowerInclusive, boolean upperInclusive) {
+
+ if (lower != null && !(lower instanceof ParametricQueryNode)) {
+ throw new IllegalArgumentException("lower should be an instance of "
+ + ParametricQueryNode.class.getCanonicalName() + ", but found "
+ + lower.getClass().getCanonicalName());
+ }
+
+ if (upper != null && !(upper instanceof ParametricQueryNode)) {
+ throw new IllegalArgumentException("upper should be an instance of "
+ + ParametricQueryNode.class.getCanonicalName() + ", but found "
+ + lower.getClass().getCanonicalName());
+ }
+
+ super.setBounds(lower, upper, lowerInclusive, upperInclusive);
+
+ }
+
+ @Override
+ public String toString() {
+ StringBuilder sb = new StringBuilder("<range>\n\t");
+ sb.append(this.getUpperBound()).append("\n\t");
+ sb.append(this.getLowerBound()).append("\n");
+ sb.append("</range>\n");
+
+ return sb.toString();
+
+ }
+
+ /**
+ * @return the collator
+ */
+ public Collator getCollator() {
+ return this.collator;
+ }
+
+}