mirror of https://github.com/apache/lucene.git
LUCENE-7413: move legacy numeric support to backwards module
This commit is contained in:
parent
ba09fa7a4a
commit
105c7eae87
|
@ -14,9 +14,11 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.document;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
|
import org.apache.lucene.document.Document;
|
||||||
|
import org.apache.lucene.document.DoublePoint;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
|
|
||||||
|
|
||||||
|
@ -49,7 +51,7 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
* LegacyFloatField}.
|
* LegacyFloatField}.
|
||||||
*
|
*
|
||||||
* <p>To perform range querying or filtering against a
|
* <p>To perform range querying or filtering against a
|
||||||
* <code>LegacyDoubleField</code>, use {@link org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* <code>LegacyDoubleField</code>, use {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* To sort according to a
|
* To sort according to a
|
||||||
* <code>LegacyDoubleField</code>, use the normal numeric sort types, eg
|
* <code>LegacyDoubleField</code>, use the normal numeric sort types, eg
|
||||||
* {@link org.apache.lucene.search.SortField.Type#DOUBLE}. <code>LegacyDoubleField</code>
|
* {@link org.apache.lucene.search.SortField.Type#DOUBLE}. <code>LegacyDoubleField</code>
|
||||||
|
@ -79,11 +81,11 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
* but may result in faster range search performance. The
|
* but may result in faster range search performance. The
|
||||||
* default value, 16, was selected for a reasonable tradeoff
|
* default value, 16, was selected for a reasonable tradeoff
|
||||||
* of disk space consumption versus performance. You can
|
* of disk space consumption versus performance. You can
|
||||||
* create a custom {@link FieldType} and invoke the {@link
|
* create a custom {@link LegacyFieldType} and invoke the {@link
|
||||||
* FieldType#setNumericPrecisionStep} method if you'd
|
* LegacyFieldType#setNumericPrecisionStep} method if you'd
|
||||||
* like to change the value. Note that you must also
|
* like to change the value. Note that you must also
|
||||||
* specify a congruent value when creating {@link
|
* specify a congruent value when creating {@link
|
||||||
* org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* For low cardinality fields larger precision steps are good.
|
* For low cardinality fields larger precision steps are good.
|
||||||
* If the cardinality is < 100, it is fair
|
* If the cardinality is < 100, it is fair
|
||||||
* to use {@link Integer#MAX_VALUE}, which produces one
|
* to use {@link Integer#MAX_VALUE}, which produces one
|
||||||
|
@ -91,9 +93,9 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
*
|
*
|
||||||
* <p>For more information on the internals of numeric trie
|
* <p>For more information on the internals of numeric trie
|
||||||
* indexing, including the <a
|
* indexing, including the <a
|
||||||
* href="../search/LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
* href="LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
||||||
* configuration, see {@link org.apache.lucene.search.LegacyNumericRangeQuery}. The format of
|
* configuration, see {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}. The format of
|
||||||
* indexed values is described in {@link org.apache.lucene.util.LegacyNumericUtils}.
|
* indexed values is described in {@link org.apache.lucene.legacy.LegacyNumericUtils}.
|
||||||
*
|
*
|
||||||
* <p>If you only need to sort by numeric value, and never
|
* <p>If you only need to sort by numeric value, and never
|
||||||
* run range querying/filtering, you can index using a
|
* run range querying/filtering, you can index using a
|
||||||
|
@ -101,7 +103,7 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
* This will minimize disk space consumed. </p>
|
* This will minimize disk space consumed. </p>
|
||||||
*
|
*
|
||||||
* <p>More advanced users can instead use {@link
|
* <p>More advanced users can instead use {@link
|
||||||
* org.apache.lucene.analysis.LegacyNumericTokenStream} directly, when indexing numbers. This
|
* org.apache.lucene.legacy.LegacyNumericTokenStream} directly, when indexing numbers. This
|
||||||
* class is a wrapper around this token stream type for
|
* class is a wrapper around this token stream type for
|
||||||
* easier, more intuitive usage.</p>
|
* easier, more intuitive usage.</p>
|
||||||
*
|
*
|
||||||
|
@ -111,18 +113,18 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public final class LegacyDoubleField extends Field {
|
public final class LegacyDoubleField extends LegacyField {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Type for a LegacyDoubleField that is not stored:
|
* Type for a LegacyDoubleField that is not stored:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_NOT_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_NOT_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_NOT_STORED.setTokenized(true);
|
TYPE_NOT_STORED.setTokenized(true);
|
||||||
TYPE_NOT_STORED.setOmitNorms(true);
|
TYPE_NOT_STORED.setOmitNorms(true);
|
||||||
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_NOT_STORED.setNumericType(FieldType.LegacyNumericType.DOUBLE);
|
TYPE_NOT_STORED.setNumericType(LegacyNumericType.DOUBLE);
|
||||||
TYPE_NOT_STORED.freeze();
|
TYPE_NOT_STORED.freeze();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,19 +132,19 @@ public final class LegacyDoubleField extends Field {
|
||||||
* Type for a stored LegacyDoubleField:
|
* Type for a stored LegacyDoubleField:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_STORED.setTokenized(true);
|
TYPE_STORED.setTokenized(true);
|
||||||
TYPE_STORED.setOmitNorms(true);
|
TYPE_STORED.setOmitNorms(true);
|
||||||
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_STORED.setNumericType(FieldType.LegacyNumericType.DOUBLE);
|
TYPE_STORED.setNumericType(LegacyNumericType.DOUBLE);
|
||||||
TYPE_STORED.setStored(true);
|
TYPE_STORED.setStored(true);
|
||||||
TYPE_STORED.freeze();
|
TYPE_STORED.freeze();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Creates a stored or un-stored LegacyDoubleField with the provided value
|
/** Creates a stored or un-stored LegacyDoubleField with the provided value
|
||||||
* and default <code>precisionStep</code> {@link
|
* and default <code>precisionStep</code> {@link
|
||||||
* org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
* org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 64-bit double value
|
* @param value 64-bit double value
|
||||||
* @param stored Store.YES if the content should also be stored
|
* @param stored Store.YES if the content should also be stored
|
||||||
|
@ -154,17 +156,17 @@ public final class LegacyDoubleField extends Field {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Expert: allows you to customize the {@link
|
/** Expert: allows you to customize the {@link
|
||||||
* FieldType}.
|
* LegacyFieldType}.
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 64-bit double value
|
* @param value 64-bit double value
|
||||||
* @param type customized field type: must have {@link FieldType#numericType()}
|
* @param type customized field type: must have {@link LegacyFieldType#numericType()}
|
||||||
* of {@link org.apache.lucene.document.FieldType.LegacyNumericType#DOUBLE}.
|
* of {@link LegacyNumericType#DOUBLE}.
|
||||||
* @throws IllegalArgumentException if the field name or type is null, or
|
* @throws IllegalArgumentException if the field name or type is null, or
|
||||||
* if the field type does not have a DOUBLE numericType()
|
* if the field type does not have a DOUBLE numericType()
|
||||||
*/
|
*/
|
||||||
public LegacyDoubleField(String name, double value, FieldType type) {
|
public LegacyDoubleField(String name, double value, LegacyFieldType type) {
|
||||||
super(name, type);
|
super(name, type);
|
||||||
if (type.numericType() != FieldType.LegacyNumericType.DOUBLE) {
|
if (type.numericType() != LegacyNumericType.DOUBLE) {
|
||||||
throw new IllegalArgumentException("type.numericType() must be DOUBLE but got " + type.numericType());
|
throw new IllegalArgumentException("type.numericType() must be DOUBLE but got " + type.numericType());
|
||||||
}
|
}
|
||||||
fieldsData = Double.valueOf(value);
|
fieldsData = Double.valueOf(value);
|
|
@ -0,0 +1,90 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
import org.apache.lucene.analysis.Analyzer;
|
||||||
|
import org.apache.lucene.analysis.TokenStream;
|
||||||
|
import org.apache.lucene.document.Field;
|
||||||
|
import org.apache.lucene.index.IndexOptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Field extension with support for legacy numerics
|
||||||
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public class LegacyField extends Field {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Expert: creates a field with no initial value.
|
||||||
|
* Intended only for custom LegacyField subclasses.
|
||||||
|
* @param name field name
|
||||||
|
* @param type field type
|
||||||
|
* @throws IllegalArgumentException if either the name or type
|
||||||
|
* is null.
|
||||||
|
*/
|
||||||
|
public LegacyField(String name, LegacyFieldType type) {
|
||||||
|
super(name, type);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TokenStream tokenStream(Analyzer analyzer, TokenStream reuse) {
|
||||||
|
if (fieldType().indexOptions() == IndexOptions.NONE) {
|
||||||
|
// Not indexed
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
final LegacyFieldType fieldType = (LegacyFieldType) fieldType();
|
||||||
|
final LegacyNumericType numericType = fieldType.numericType();
|
||||||
|
if (numericType != null) {
|
||||||
|
if (!(reuse instanceof LegacyNumericTokenStream && ((LegacyNumericTokenStream)reuse).getPrecisionStep() == fieldType.numericPrecisionStep())) {
|
||||||
|
// lazy init the TokenStream as it is heavy to instantiate
|
||||||
|
// (attributes,...) if not needed (stored field loading)
|
||||||
|
reuse = new LegacyNumericTokenStream(fieldType.numericPrecisionStep());
|
||||||
|
}
|
||||||
|
final LegacyNumericTokenStream nts = (LegacyNumericTokenStream) reuse;
|
||||||
|
// initialize value in TokenStream
|
||||||
|
final Number val = (Number) fieldsData;
|
||||||
|
switch (numericType) {
|
||||||
|
case INT:
|
||||||
|
nts.setIntValue(val.intValue());
|
||||||
|
break;
|
||||||
|
case LONG:
|
||||||
|
nts.setLongValue(val.longValue());
|
||||||
|
break;
|
||||||
|
case FLOAT:
|
||||||
|
nts.setFloatValue(val.floatValue());
|
||||||
|
break;
|
||||||
|
case DOUBLE:
|
||||||
|
nts.setDoubleValue(val.doubleValue());
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new AssertionError("Should never get here");
|
||||||
|
}
|
||||||
|
return reuse;
|
||||||
|
}
|
||||||
|
return super.tokenStream(analyzer, reuse);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setTokenStream(TokenStream tokenStream) {
|
||||||
|
final LegacyFieldType fieldType = (LegacyFieldType) fieldType();
|
||||||
|
if (fieldType.numericType() != null) {
|
||||||
|
throw new IllegalArgumentException("cannot set private TokenStream on numeric fields");
|
||||||
|
}
|
||||||
|
super.setTokenStream(tokenStream);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,149 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
import org.apache.lucene.document.FieldType;
|
||||||
|
import org.apache.lucene.index.IndexOptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* FieldType extension with support for legacy numerics
|
||||||
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public final class LegacyFieldType extends FieldType {
|
||||||
|
private LegacyNumericType numericType;
|
||||||
|
private int numericPrecisionStep = LegacyNumericUtils.PRECISION_STEP_DEFAULT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new mutable LegacyFieldType with all of the properties from <code>ref</code>
|
||||||
|
*/
|
||||||
|
public LegacyFieldType(LegacyFieldType ref) {
|
||||||
|
super(ref);
|
||||||
|
this.numericType = ref.numericType;
|
||||||
|
this.numericPrecisionStep = ref.numericPrecisionStep;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new FieldType with default properties.
|
||||||
|
*/
|
||||||
|
public LegacyFieldType() {
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Specifies the field's numeric type.
|
||||||
|
* @param type numeric type, or null if the field has no numeric type.
|
||||||
|
* @throws IllegalStateException if this FieldType is frozen against
|
||||||
|
* future modifications.
|
||||||
|
* @see #numericType()
|
||||||
|
*
|
||||||
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public void setNumericType(LegacyNumericType type) {
|
||||||
|
checkIfFrozen();
|
||||||
|
numericType = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LegacyNumericType: if non-null then the field's value will be indexed
|
||||||
|
* numerically so that {@link org.apache.lucene.legacy.LegacyNumericRangeQuery} can be used at
|
||||||
|
* search time.
|
||||||
|
* <p>
|
||||||
|
* The default is <code>null</code> (no numeric type)
|
||||||
|
* @see #setNumericType(LegacyNumericType)
|
||||||
|
*
|
||||||
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public LegacyNumericType numericType() {
|
||||||
|
return numericType;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the numeric precision step for the field.
|
||||||
|
* @param precisionStep numeric precision step for the field
|
||||||
|
* @throws IllegalArgumentException if precisionStep is less than 1.
|
||||||
|
* @throws IllegalStateException if this FieldType is frozen against
|
||||||
|
* future modifications.
|
||||||
|
* @see #numericPrecisionStep()
|
||||||
|
*
|
||||||
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public void setNumericPrecisionStep(int precisionStep) {
|
||||||
|
checkIfFrozen();
|
||||||
|
if (precisionStep < 1) {
|
||||||
|
throw new IllegalArgumentException("precisionStep must be >= 1 (got " + precisionStep + ")");
|
||||||
|
}
|
||||||
|
this.numericPrecisionStep = precisionStep;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Precision step for numeric field.
|
||||||
|
* <p>
|
||||||
|
* This has no effect if {@link #numericType()} returns null.
|
||||||
|
* <p>
|
||||||
|
* The default is {@link org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT}
|
||||||
|
* @see #setNumericPrecisionStep(int)
|
||||||
|
*
|
||||||
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public int numericPrecisionStep() {
|
||||||
|
return numericPrecisionStep;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
final int prime = 31;
|
||||||
|
int result = super.hashCode();
|
||||||
|
result = prime * result + numericPrecisionStep;
|
||||||
|
result = prime * result + ((numericType == null) ? 0 : numericType.hashCode());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if (!super.equals(obj)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (getClass() != obj.getClass()) return false;
|
||||||
|
LegacyFieldType other = (LegacyFieldType) obj;
|
||||||
|
if (numericPrecisionStep != other.numericPrecisionStep) return false;
|
||||||
|
if (numericType != other.numericType) return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Prints a Field for human consumption. */
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
StringBuilder result = new StringBuilder();
|
||||||
|
result.append(super.toString());
|
||||||
|
if (indexOptions() != IndexOptions.NONE) {
|
||||||
|
if (result.length() > 0) {
|
||||||
|
result.append(",");
|
||||||
|
}
|
||||||
|
if (numericType != null) {
|
||||||
|
result.append(",numericType=");
|
||||||
|
result.append(numericType);
|
||||||
|
result.append(",numericPrecisionStep=");
|
||||||
|
result.append(numericPrecisionStep);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result.toString();
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,11 +14,11 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.document;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
|
import org.apache.lucene.document.Document;
|
||||||
|
import org.apache.lucene.document.FloatPoint;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>
|
* <p>
|
||||||
|
@ -49,7 +49,7 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
* LegacyDoubleField}.
|
* LegacyDoubleField}.
|
||||||
*
|
*
|
||||||
* <p>To perform range querying or filtering against a
|
* <p>To perform range querying or filtering against a
|
||||||
* <code>LegacyFloatField</code>, use {@link org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* <code>LegacyFloatField</code>, use {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* To sort according to a
|
* To sort according to a
|
||||||
* <code>LegacyFloatField</code>, use the normal numeric sort types, eg
|
* <code>LegacyFloatField</code>, use the normal numeric sort types, eg
|
||||||
* {@link org.apache.lucene.search.SortField.Type#FLOAT}. <code>LegacyFloatField</code>
|
* {@link org.apache.lucene.search.SortField.Type#FLOAT}. <code>LegacyFloatField</code>
|
||||||
|
@ -79,11 +79,11 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
* but may result in faster range search performance. The
|
* but may result in faster range search performance. The
|
||||||
* default value, 8, was selected for a reasonable tradeoff
|
* default value, 8, was selected for a reasonable tradeoff
|
||||||
* of disk space consumption versus performance. You can
|
* of disk space consumption versus performance. You can
|
||||||
* create a custom {@link FieldType} and invoke the {@link
|
* create a custom {@link LegacyFieldType} and invoke the {@link
|
||||||
* FieldType#setNumericPrecisionStep} method if you'd
|
* LegacyFieldType#setNumericPrecisionStep} method if you'd
|
||||||
* like to change the value. Note that you must also
|
* like to change the value. Note that you must also
|
||||||
* specify a congruent value when creating {@link
|
* specify a congruent value when creating {@link
|
||||||
* org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* For low cardinality fields larger precision steps are good.
|
* For low cardinality fields larger precision steps are good.
|
||||||
* If the cardinality is < 100, it is fair
|
* If the cardinality is < 100, it is fair
|
||||||
* to use {@link Integer#MAX_VALUE}, which produces one
|
* to use {@link Integer#MAX_VALUE}, which produces one
|
||||||
|
@ -91,9 +91,9 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
*
|
*
|
||||||
* <p>For more information on the internals of numeric trie
|
* <p>For more information on the internals of numeric trie
|
||||||
* indexing, including the <a
|
* indexing, including the <a
|
||||||
* href="../search/LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
* href="LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
||||||
* configuration, see {@link org.apache.lucene.search.LegacyNumericRangeQuery}. The format of
|
* configuration, see {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}. The format of
|
||||||
* indexed values is described in {@link org.apache.lucene.util.LegacyNumericUtils}.
|
* indexed values is described in {@link org.apache.lucene.legacy.LegacyNumericUtils}.
|
||||||
*
|
*
|
||||||
* <p>If you only need to sort by numeric value, and never
|
* <p>If you only need to sort by numeric value, and never
|
||||||
* run range querying/filtering, you can index using a
|
* run range querying/filtering, you can index using a
|
||||||
|
@ -101,7 +101,7 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
* This will minimize disk space consumed. </p>
|
* This will minimize disk space consumed. </p>
|
||||||
*
|
*
|
||||||
* <p>More advanced users can instead use {@link
|
* <p>More advanced users can instead use {@link
|
||||||
* org.apache.lucene.analysis.LegacyNumericTokenStream} directly, when indexing numbers. This
|
* org.apache.lucene.legacy.LegacyNumericTokenStream} directly, when indexing numbers. This
|
||||||
* class is a wrapper around this token stream type for
|
* class is a wrapper around this token stream type for
|
||||||
* easier, more intuitive usage.</p>
|
* easier, more intuitive usage.</p>
|
||||||
*
|
*
|
||||||
|
@ -111,18 +111,18 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public final class LegacyFloatField extends Field {
|
public final class LegacyFloatField extends LegacyField {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Type for a LegacyFloatField that is not stored:
|
* Type for a LegacyFloatField that is not stored:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_NOT_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_NOT_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_NOT_STORED.setTokenized(true);
|
TYPE_NOT_STORED.setTokenized(true);
|
||||||
TYPE_NOT_STORED.setOmitNorms(true);
|
TYPE_NOT_STORED.setOmitNorms(true);
|
||||||
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_NOT_STORED.setNumericType(FieldType.LegacyNumericType.FLOAT);
|
TYPE_NOT_STORED.setNumericType(LegacyNumericType.FLOAT);
|
||||||
TYPE_NOT_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
TYPE_NOT_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
||||||
TYPE_NOT_STORED.freeze();
|
TYPE_NOT_STORED.freeze();
|
||||||
}
|
}
|
||||||
|
@ -131,12 +131,12 @@ public final class LegacyFloatField extends Field {
|
||||||
* Type for a stored LegacyFloatField:
|
* Type for a stored LegacyFloatField:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_STORED.setTokenized(true);
|
TYPE_STORED.setTokenized(true);
|
||||||
TYPE_STORED.setOmitNorms(true);
|
TYPE_STORED.setOmitNorms(true);
|
||||||
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_STORED.setNumericType(FieldType.LegacyNumericType.FLOAT);
|
TYPE_STORED.setNumericType(LegacyNumericType.FLOAT);
|
||||||
TYPE_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
TYPE_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
||||||
TYPE_STORED.setStored(true);
|
TYPE_STORED.setStored(true);
|
||||||
TYPE_STORED.freeze();
|
TYPE_STORED.freeze();
|
||||||
|
@ -144,7 +144,7 @@ public final class LegacyFloatField extends Field {
|
||||||
|
|
||||||
/** Creates a stored or un-stored LegacyFloatField with the provided value
|
/** Creates a stored or un-stored LegacyFloatField with the provided value
|
||||||
* and default <code>precisionStep</code> {@link
|
* and default <code>precisionStep</code> {@link
|
||||||
* org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
* org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 32-bit double value
|
* @param value 32-bit double value
|
||||||
* @param stored Store.YES if the content should also be stored
|
* @param stored Store.YES if the content should also be stored
|
||||||
|
@ -156,17 +156,17 @@ public final class LegacyFloatField extends Field {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Expert: allows you to customize the {@link
|
/** Expert: allows you to customize the {@link
|
||||||
* FieldType}.
|
* LegacyFieldType}.
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 32-bit float value
|
* @param value 32-bit float value
|
||||||
* @param type customized field type: must have {@link FieldType#numericType()}
|
* @param type customized field type: must have {@link LegacyFieldType#numericType()}
|
||||||
* of {@link org.apache.lucene.document.FieldType.LegacyNumericType#FLOAT}.
|
* of {@link LegacyNumericType#FLOAT}.
|
||||||
* @throws IllegalArgumentException if the field name or type is null, or
|
* @throws IllegalArgumentException if the field name or type is null, or
|
||||||
* if the field type does not have a FLOAT numericType()
|
* if the field type does not have a FLOAT numericType()
|
||||||
*/
|
*/
|
||||||
public LegacyFloatField(String name, float value, FieldType type) {
|
public LegacyFloatField(String name, float value, LegacyFieldType type) {
|
||||||
super(name, type);
|
super(name, type);
|
||||||
if (type.numericType() != FieldType.LegacyNumericType.FLOAT) {
|
if (type.numericType() != LegacyNumericType.FLOAT) {
|
||||||
throw new IllegalArgumentException("type.numericType() must be FLOAT but got " + type.numericType());
|
throw new IllegalArgumentException("type.numericType() must be FLOAT but got " + type.numericType());
|
||||||
}
|
}
|
||||||
fieldsData = Float.valueOf(value);
|
fieldsData = Float.valueOf(value);
|
|
@ -14,11 +14,12 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.document;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
|
import org.apache.lucene.document.Document;
|
||||||
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>
|
* <p>
|
||||||
|
@ -49,7 +50,7 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
* LegacyDoubleField}.
|
* LegacyDoubleField}.
|
||||||
*
|
*
|
||||||
* <p>To perform range querying or filtering against a
|
* <p>To perform range querying or filtering against a
|
||||||
* <code>LegacyIntField</code>, use {@link org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* <code>LegacyIntField</code>, use {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* To sort according to a
|
* To sort according to a
|
||||||
* <code>LegacyIntField</code>, use the normal numeric sort types, eg
|
* <code>LegacyIntField</code>, use the normal numeric sort types, eg
|
||||||
* {@link org.apache.lucene.search.SortField.Type#INT}. <code>LegacyIntField</code>
|
* {@link org.apache.lucene.search.SortField.Type#INT}. <code>LegacyIntField</code>
|
||||||
|
@ -79,11 +80,11 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
* but may result in faster range search performance. The
|
* but may result in faster range search performance. The
|
||||||
* default value, 8, was selected for a reasonable tradeoff
|
* default value, 8, was selected for a reasonable tradeoff
|
||||||
* of disk space consumption versus performance. You can
|
* of disk space consumption versus performance. You can
|
||||||
* create a custom {@link FieldType} and invoke the {@link
|
* create a custom {@link LegacyFieldType} and invoke the {@link
|
||||||
* FieldType#setNumericPrecisionStep} method if you'd
|
* LegacyFieldType#setNumericPrecisionStep} method if you'd
|
||||||
* like to change the value. Note that you must also
|
* like to change the value. Note that you must also
|
||||||
* specify a congruent value when creating {@link
|
* specify a congruent value when creating {@link
|
||||||
* org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* For low cardinality fields larger precision steps are good.
|
* For low cardinality fields larger precision steps are good.
|
||||||
* If the cardinality is < 100, it is fair
|
* If the cardinality is < 100, it is fair
|
||||||
* to use {@link Integer#MAX_VALUE}, which produces one
|
* to use {@link Integer#MAX_VALUE}, which produces one
|
||||||
|
@ -91,9 +92,9 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
*
|
*
|
||||||
* <p>For more information on the internals of numeric trie
|
* <p>For more information on the internals of numeric trie
|
||||||
* indexing, including the <a
|
* indexing, including the <a
|
||||||
* href="../search/LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
* href="LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
||||||
* configuration, see {@link org.apache.lucene.search.LegacyNumericRangeQuery}. The format of
|
* configuration, see {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}. The format of
|
||||||
* indexed values is described in {@link org.apache.lucene.util.LegacyNumericUtils}.
|
* indexed values is described in {@link org.apache.lucene.legacy.LegacyNumericUtils}.
|
||||||
*
|
*
|
||||||
* <p>If you only need to sort by numeric value, and never
|
* <p>If you only need to sort by numeric value, and never
|
||||||
* run range querying/filtering, you can index using a
|
* run range querying/filtering, you can index using a
|
||||||
|
@ -101,7 +102,7 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
* This will minimize disk space consumed. </p>
|
* This will minimize disk space consumed. </p>
|
||||||
*
|
*
|
||||||
* <p>More advanced users can instead use {@link
|
* <p>More advanced users can instead use {@link
|
||||||
* org.apache.lucene.analysis.LegacyNumericTokenStream} directly, when indexing numbers. This
|
* org.apache.lucene.legacy.LegacyNumericTokenStream} directly, when indexing numbers. This
|
||||||
* class is a wrapper around this token stream type for
|
* class is a wrapper around this token stream type for
|
||||||
* easier, more intuitive usage.</p>
|
* easier, more intuitive usage.</p>
|
||||||
*
|
*
|
||||||
|
@ -111,18 +112,18 @@ import org.apache.lucene.util.LegacyNumericUtils;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public final class LegacyIntField extends Field {
|
public final class LegacyIntField extends LegacyField {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Type for an LegacyIntField that is not stored:
|
* Type for an LegacyIntField that is not stored:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_NOT_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_NOT_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_NOT_STORED.setTokenized(true);
|
TYPE_NOT_STORED.setTokenized(true);
|
||||||
TYPE_NOT_STORED.setOmitNorms(true);
|
TYPE_NOT_STORED.setOmitNorms(true);
|
||||||
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_NOT_STORED.setNumericType(FieldType.LegacyNumericType.INT);
|
TYPE_NOT_STORED.setNumericType(LegacyNumericType.INT);
|
||||||
TYPE_NOT_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
TYPE_NOT_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
||||||
TYPE_NOT_STORED.freeze();
|
TYPE_NOT_STORED.freeze();
|
||||||
}
|
}
|
||||||
|
@ -131,12 +132,12 @@ public final class LegacyIntField extends Field {
|
||||||
* Type for a stored LegacyIntField:
|
* Type for a stored LegacyIntField:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_STORED.setTokenized(true);
|
TYPE_STORED.setTokenized(true);
|
||||||
TYPE_STORED.setOmitNorms(true);
|
TYPE_STORED.setOmitNorms(true);
|
||||||
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_STORED.setNumericType(FieldType.LegacyNumericType.INT);
|
TYPE_STORED.setNumericType(LegacyNumericType.INT);
|
||||||
TYPE_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
TYPE_STORED.setNumericPrecisionStep(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32);
|
||||||
TYPE_STORED.setStored(true);
|
TYPE_STORED.setStored(true);
|
||||||
TYPE_STORED.freeze();
|
TYPE_STORED.freeze();
|
||||||
|
@ -144,7 +145,7 @@ public final class LegacyIntField extends Field {
|
||||||
|
|
||||||
/** Creates a stored or un-stored LegacyIntField with the provided value
|
/** Creates a stored or un-stored LegacyIntField with the provided value
|
||||||
* and default <code>precisionStep</code> {@link
|
* and default <code>precisionStep</code> {@link
|
||||||
* org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
* org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 32-bit integer value
|
* @param value 32-bit integer value
|
||||||
* @param stored Store.YES if the content should also be stored
|
* @param stored Store.YES if the content should also be stored
|
||||||
|
@ -156,17 +157,17 @@ public final class LegacyIntField extends Field {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Expert: allows you to customize the {@link
|
/** Expert: allows you to customize the {@link
|
||||||
* FieldType}.
|
* LegacyFieldType}.
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 32-bit integer value
|
* @param value 32-bit integer value
|
||||||
* @param type customized field type: must have {@link FieldType#numericType()}
|
* @param type customized field type: must have {@link LegacyFieldType#numericType()}
|
||||||
* of {@link org.apache.lucene.document.FieldType.LegacyNumericType#INT}.
|
* of {@link LegacyNumericType#INT}.
|
||||||
* @throws IllegalArgumentException if the field name or type is null, or
|
* @throws IllegalArgumentException if the field name or type is null, or
|
||||||
* if the field type does not have a INT numericType()
|
* if the field type does not have a INT numericType()
|
||||||
*/
|
*/
|
||||||
public LegacyIntField(String name, int value, FieldType type) {
|
public LegacyIntField(String name, int value, LegacyFieldType type) {
|
||||||
super(name, type);
|
super(name, type);
|
||||||
if (type.numericType() != FieldType.LegacyNumericType.INT) {
|
if (type.numericType() != LegacyNumericType.INT) {
|
||||||
throw new IllegalArgumentException("type.numericType() must be INT but got " + type.numericType());
|
throw new IllegalArgumentException("type.numericType() must be INT but got " + type.numericType());
|
||||||
}
|
}
|
||||||
fieldsData = Integer.valueOf(value);
|
fieldsData = Integer.valueOf(value);
|
|
@ -14,9 +14,11 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.document;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
|
import org.apache.lucene.document.Document;
|
||||||
|
import org.apache.lucene.document.LongPoint;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
|
|
||||||
|
|
||||||
|
@ -59,7 +61,7 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
* <code>long</code> value.
|
* <code>long</code> value.
|
||||||
*
|
*
|
||||||
* <p>To perform range querying or filtering against a
|
* <p>To perform range querying or filtering against a
|
||||||
* <code>LegacyLongField</code>, use {@link org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* <code>LegacyLongField</code>, use {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* To sort according to a
|
* To sort according to a
|
||||||
* <code>LegacyLongField</code>, use the normal numeric sort types, eg
|
* <code>LegacyLongField</code>, use the normal numeric sort types, eg
|
||||||
* {@link org.apache.lucene.search.SortField.Type#LONG}. <code>LegacyLongField</code>
|
* {@link org.apache.lucene.search.SortField.Type#LONG}. <code>LegacyLongField</code>
|
||||||
|
@ -89,11 +91,11 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
* but may result in faster range search performance. The
|
* but may result in faster range search performance. The
|
||||||
* default value, 16, was selected for a reasonable tradeoff
|
* default value, 16, was selected for a reasonable tradeoff
|
||||||
* of disk space consumption versus performance. You can
|
* of disk space consumption versus performance. You can
|
||||||
* create a custom {@link FieldType} and invoke the {@link
|
* create a custom {@link LegacyFieldType} and invoke the {@link
|
||||||
* FieldType#setNumericPrecisionStep} method if you'd
|
* LegacyFieldType#setNumericPrecisionStep} method if you'd
|
||||||
* like to change the value. Note that you must also
|
* like to change the value. Note that you must also
|
||||||
* specify a congruent value when creating {@link
|
* specify a congruent value when creating {@link
|
||||||
* org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
* For low cardinality fields larger precision steps are good.
|
* For low cardinality fields larger precision steps are good.
|
||||||
* If the cardinality is < 100, it is fair
|
* If the cardinality is < 100, it is fair
|
||||||
* to use {@link Integer#MAX_VALUE}, which produces one
|
* to use {@link Integer#MAX_VALUE}, which produces one
|
||||||
|
@ -101,9 +103,9 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
*
|
*
|
||||||
* <p>For more information on the internals of numeric trie
|
* <p>For more information on the internals of numeric trie
|
||||||
* indexing, including the <a
|
* indexing, including the <a
|
||||||
* href="../search/LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
* href="LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
||||||
* configuration, see {@link org.apache.lucene.search.LegacyNumericRangeQuery}. The format of
|
* configuration, see {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}. The format of
|
||||||
* indexed values is described in {@link org.apache.lucene.util.LegacyNumericUtils}.
|
* indexed values is described in {@link org.apache.lucene.legacy.LegacyNumericUtils}.
|
||||||
*
|
*
|
||||||
* <p>If you only need to sort by numeric value, and never
|
* <p>If you only need to sort by numeric value, and never
|
||||||
* run range querying/filtering, you can index using a
|
* run range querying/filtering, you can index using a
|
||||||
|
@ -111,7 +113,7 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
* This will minimize disk space consumed.
|
* This will minimize disk space consumed.
|
||||||
*
|
*
|
||||||
* <p>More advanced users can instead use {@link
|
* <p>More advanced users can instead use {@link
|
||||||
* org.apache.lucene.analysis.LegacyNumericTokenStream} directly, when indexing numbers. This
|
* org.apache.lucene.legacy.LegacyNumericTokenStream} directly, when indexing numbers. This
|
||||||
* class is a wrapper around this token stream type for
|
* class is a wrapper around this token stream type for
|
||||||
* easier, more intuitive usage.</p>
|
* easier, more intuitive usage.</p>
|
||||||
*
|
*
|
||||||
|
@ -121,18 +123,18 @@ import org.apache.lucene.index.IndexOptions;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public final class LegacyLongField extends Field {
|
public final class LegacyLongField extends LegacyField {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Type for a LegacyLongField that is not stored:
|
* Type for a LegacyLongField that is not stored:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_NOT_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_NOT_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_NOT_STORED.setTokenized(true);
|
TYPE_NOT_STORED.setTokenized(true);
|
||||||
TYPE_NOT_STORED.setOmitNorms(true);
|
TYPE_NOT_STORED.setOmitNorms(true);
|
||||||
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_NOT_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_NOT_STORED.setNumericType(FieldType.LegacyNumericType.LONG);
|
TYPE_NOT_STORED.setNumericType(LegacyNumericType.LONG);
|
||||||
TYPE_NOT_STORED.freeze();
|
TYPE_NOT_STORED.freeze();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,19 +142,19 @@ public final class LegacyLongField extends Field {
|
||||||
* Type for a stored LegacyLongField:
|
* Type for a stored LegacyLongField:
|
||||||
* normalization factors, frequencies, and positions are omitted.
|
* normalization factors, frequencies, and positions are omitted.
|
||||||
*/
|
*/
|
||||||
public static final FieldType TYPE_STORED = new FieldType();
|
public static final LegacyFieldType TYPE_STORED = new LegacyFieldType();
|
||||||
static {
|
static {
|
||||||
TYPE_STORED.setTokenized(true);
|
TYPE_STORED.setTokenized(true);
|
||||||
TYPE_STORED.setOmitNorms(true);
|
TYPE_STORED.setOmitNorms(true);
|
||||||
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
TYPE_STORED.setIndexOptions(IndexOptions.DOCS);
|
||||||
TYPE_STORED.setNumericType(FieldType.LegacyNumericType.LONG);
|
TYPE_STORED.setNumericType(LegacyNumericType.LONG);
|
||||||
TYPE_STORED.setStored(true);
|
TYPE_STORED.setStored(true);
|
||||||
TYPE_STORED.freeze();
|
TYPE_STORED.freeze();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Creates a stored or un-stored LegacyLongField with the provided value
|
/** Creates a stored or un-stored LegacyLongField with the provided value
|
||||||
* and default <code>precisionStep</code> {@link
|
* and default <code>precisionStep</code> {@link
|
||||||
* org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
* org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 64-bit long value
|
* @param value 64-bit long value
|
||||||
* @param stored Store.YES if the content should also be stored
|
* @param stored Store.YES if the content should also be stored
|
||||||
|
@ -164,17 +166,17 @@ public final class LegacyLongField extends Field {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Expert: allows you to customize the {@link
|
/** Expert: allows you to customize the {@link
|
||||||
* FieldType}.
|
* LegacyFieldType}.
|
||||||
* @param name field name
|
* @param name field name
|
||||||
* @param value 64-bit long value
|
* @param value 64-bit long value
|
||||||
* @param type customized field type: must have {@link FieldType#numericType()}
|
* @param type customized field type: must have {@link LegacyFieldType#numericType()}
|
||||||
* of {@link org.apache.lucene.document.FieldType.LegacyNumericType#LONG}.
|
* of {@link LegacyNumericType#LONG}.
|
||||||
* @throws IllegalArgumentException if the field name or type is null, or
|
* @throws IllegalArgumentException if the field name or type is null, or
|
||||||
* if the field type does not have a LONG numericType()
|
* if the field type does not have a LONG numericType()
|
||||||
*/
|
*/
|
||||||
public LegacyLongField(String name, long value, FieldType type) {
|
public LegacyLongField(String name, long value, LegacyFieldType type) {
|
||||||
super(name, type);
|
super(name, type);
|
||||||
if (type.numericType() != FieldType.LegacyNumericType.LONG) {
|
if (type.numericType() != LegacyNumericType.LONG) {
|
||||||
throw new IllegalArgumentException("type.numericType() must be LONG but got " + type.numericType());
|
throw new IllegalArgumentException("type.numericType() must be LONG but got " + type.numericType());
|
||||||
}
|
}
|
||||||
fieldsData = Long.valueOf(value);
|
fieldsData = Long.valueOf(value);
|
|
@ -14,7 +14,7 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.search;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -22,8 +22,6 @@ import java.util.LinkedList;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
import org.apache.lucene.document.DoublePoint;
|
import org.apache.lucene.document.DoublePoint;
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.document.FloatPoint;
|
import org.apache.lucene.document.FloatPoint;
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LongPoint;
|
import org.apache.lucene.document.LongPoint;
|
||||||
|
@ -31,18 +29,21 @@ import org.apache.lucene.index.FilteredTermsEnum;
|
||||||
import org.apache.lucene.index.PointValues;
|
import org.apache.lucene.index.PointValues;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.index.TermsEnum;
|
||||||
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
|
import org.apache.lucene.search.MultiTermQuery;
|
||||||
|
import org.apache.lucene.search.Query;
|
||||||
|
import org.apache.lucene.search.TermRangeQuery;
|
||||||
import org.apache.lucene.util.AttributeSource;
|
import org.apache.lucene.util.AttributeSource;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.lucene.index.Term; // for javadocs
|
import org.apache.lucene.index.Term; // for javadocs
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>A {@link Query} that matches numeric values within a
|
* <p>A {@link Query} that matches numeric values within a
|
||||||
* specified range. To use this, you must first index the
|
* specified range. To use this, you must first index the
|
||||||
* numeric values using {@link org.apache.lucene.document.LegacyIntField}, {@link
|
* numeric values using {@link org.apache.lucene.legacy.LegacyIntField}, {@link
|
||||||
* org.apache.lucene.document.LegacyFloatField}, {@link org.apache.lucene.document.LegacyLongField} or {@link org.apache.lucene.document.LegacyDoubleField} (expert: {@link
|
* org.apache.lucene.legacy.LegacyFloatField}, {@link org.apache.lucene.legacy.LegacyLongField} or {@link org.apache.lucene.legacy.LegacyDoubleField} (expert: {@link
|
||||||
* org.apache.lucene.analysis.LegacyNumericTokenStream}). If your terms are instead textual,
|
* org.apache.lucene.legacy.LegacyNumericTokenStream}). If your terms are instead textual,
|
||||||
* you should use {@link TermRangeQuery}.</p>
|
* you should use {@link TermRangeQuery}.</p>
|
||||||
*
|
*
|
||||||
* <p>You create a new LegacyNumericRangeQuery with the static
|
* <p>You create a new LegacyNumericRangeQuery with the static
|
||||||
|
@ -96,7 +97,7 @@ import org.apache.lucene.index.Term; // for javadocs
|
||||||
* (all numerical values like doubles, longs, floats, and ints are converted to
|
* (all numerical values like doubles, longs, floats, and ints are converted to
|
||||||
* lexicographic sortable string representations and stored with different precisions
|
* lexicographic sortable string representations and stored with different precisions
|
||||||
* (for a more detailed description of how the values are stored,
|
* (for a more detailed description of how the values are stored,
|
||||||
* see {@link org.apache.lucene.util.LegacyNumericUtils}). A range is then divided recursively into multiple intervals for searching:
|
* see {@link org.apache.lucene.legacy.LegacyNumericUtils}). A range is then divided recursively into multiple intervals for searching:
|
||||||
* The center of the range is searched only with the lowest possible precision in the <em>trie</em>,
|
* The center of the range is searched only with the lowest possible precision in the <em>trie</em>,
|
||||||
* while the boundaries are matched more exactly. This reduces the number of terms dramatically.</p>
|
* while the boundaries are matched more exactly. This reduces the number of terms dramatically.</p>
|
||||||
*
|
*
|
||||||
|
@ -112,7 +113,7 @@ import org.apache.lucene.index.Term; // for javadocs
|
||||||
* <h3><a name="precisionStepDesc">Precision Step</a></h3>
|
* <h3><a name="precisionStepDesc">Precision Step</a></h3>
|
||||||
* <p>You can choose any <code>precisionStep</code> when encoding values.
|
* <p>You can choose any <code>precisionStep</code> when encoding values.
|
||||||
* Lower step values mean more precisions and so more terms in index (and index gets larger). The number
|
* Lower step values mean more precisions and so more terms in index (and index gets larger). The number
|
||||||
* of indexed terms per value is (those are generated by {@link org.apache.lucene.analysis.LegacyNumericTokenStream}):
|
* of indexed terms per value is (those are generated by {@link org.apache.lucene.legacy.LegacyNumericTokenStream}):
|
||||||
* <p style="font-family:serif">
|
* <p style="font-family:serif">
|
||||||
* indexedTermsPerValue = <b>ceil</b><big>(</big>bitsPerValue / precisionStep<big>)</big>
|
* indexedTermsPerValue = <b>ceil</b><big>(</big>bitsPerValue / precisionStep<big>)</big>
|
||||||
* </p>
|
* </p>
|
||||||
|
@ -148,8 +149,8 @@ import org.apache.lucene.index.Term; // for javadocs
|
||||||
* <li>Steps <b>≥64</b> for <em>long/double</em> and <b>≥32</b> for <em>int/float</em> produces one token
|
* <li>Steps <b>≥64</b> for <em>long/double</em> and <b>≥32</b> for <em>int/float</em> produces one token
|
||||||
* per value in the index and querying is as slow as a conventional {@link TermRangeQuery}. But it can be used
|
* per value in the index and querying is as slow as a conventional {@link TermRangeQuery}. But it can be used
|
||||||
* to produce fields, that are solely used for sorting (in this case simply use {@link Integer#MAX_VALUE} as
|
* to produce fields, that are solely used for sorting (in this case simply use {@link Integer#MAX_VALUE} as
|
||||||
* <code>precisionStep</code>). Using {@link org.apache.lucene.document.LegacyIntField},
|
* <code>precisionStep</code>). Using {@link org.apache.lucene.legacy.LegacyIntField},
|
||||||
* {@link org.apache.lucene.document.LegacyLongField}, {@link org.apache.lucene.document.LegacyFloatField} or {@link org.apache.lucene.document.LegacyDoubleField} for sorting
|
* {@link org.apache.lucene.legacy.LegacyLongField}, {@link org.apache.lucene.legacy.LegacyFloatField} or {@link org.apache.lucene.legacy.LegacyDoubleField} for sorting
|
||||||
* is ideal, because building the field cache is much faster than with text-only numbers.
|
* is ideal, because building the field cache is much faster than with text-only numbers.
|
||||||
* These fields have one term per value and therefore also work with term enumeration for building distinct lists
|
* These fields have one term per value and therefore also work with term enumeration for building distinct lists
|
||||||
* (e.g. facets / preselected values to search for).
|
* (e.g. facets / preselected values to search for).
|
||||||
|
@ -199,12 +200,12 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Long> newLongRange(final String field, final int precisionStep,
|
public static LegacyNumericRangeQuery<Long> newLongRange(final String field, final int precisionStep,
|
||||||
Long min, Long max, final boolean minInclusive, final boolean maxInclusive
|
Long min, Long max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, precisionStep, FieldType.LegacyNumericType.LONG, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, precisionStep, LegacyNumericType.LONG, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>long</code>
|
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>long</code>
|
||||||
* range using the default <code>precisionStep</code> {@link org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
* range using the default <code>precisionStep</code> {@link org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
||||||
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
||||||
* by setting the min or max value to <code>null</code>. By setting inclusive to false, it will
|
* by setting the min or max value to <code>null</code>. By setting inclusive to false, it will
|
||||||
* match all documents excluding the bounds, with inclusive on, the boundaries are hits, too.
|
* match all documents excluding the bounds, with inclusive on, the boundaries are hits, too.
|
||||||
|
@ -212,7 +213,7 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Long> newLongRange(final String field,
|
public static LegacyNumericRangeQuery<Long> newLongRange(final String field,
|
||||||
Long min, Long max, final boolean minInclusive, final boolean maxInclusive
|
Long min, Long max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT, FieldType.LegacyNumericType.LONG, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT, LegacyNumericType.LONG, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -225,12 +226,12 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Integer> newIntRange(final String field, final int precisionStep,
|
public static LegacyNumericRangeQuery<Integer> newIntRange(final String field, final int precisionStep,
|
||||||
Integer min, Integer max, final boolean minInclusive, final boolean maxInclusive
|
Integer min, Integer max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, precisionStep, FieldType.LegacyNumericType.INT, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, precisionStep, LegacyNumericType.INT, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>int</code>
|
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>int</code>
|
||||||
* range using the default <code>precisionStep</code> {@link org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
* range using the default <code>precisionStep</code> {@link org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
||||||
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
||||||
* by setting the min or max value to <code>null</code>. By setting inclusive to false, it will
|
* by setting the min or max value to <code>null</code>. By setting inclusive to false, it will
|
||||||
* match all documents excluding the bounds, with inclusive on, the boundaries are hits, too.
|
* match all documents excluding the bounds, with inclusive on, the boundaries are hits, too.
|
||||||
|
@ -238,7 +239,7 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Integer> newIntRange(final String field,
|
public static LegacyNumericRangeQuery<Integer> newIntRange(final String field,
|
||||||
Integer min, Integer max, final boolean minInclusive, final boolean maxInclusive
|
Integer min, Integer max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT_32, FieldType.LegacyNumericType.INT, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT_32, LegacyNumericType.INT, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -253,12 +254,12 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Double> newDoubleRange(final String field, final int precisionStep,
|
public static LegacyNumericRangeQuery<Double> newDoubleRange(final String field, final int precisionStep,
|
||||||
Double min, Double max, final boolean minInclusive, final boolean maxInclusive
|
Double min, Double max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, precisionStep, FieldType.LegacyNumericType.DOUBLE, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, precisionStep, LegacyNumericType.DOUBLE, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>double</code>
|
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>double</code>
|
||||||
* range using the default <code>precisionStep</code> {@link org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
* range using the default <code>precisionStep</code> {@link org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16).
|
||||||
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
||||||
* by setting the min or max value to <code>null</code>.
|
* by setting the min or max value to <code>null</code>.
|
||||||
* {@link Double#NaN} will never match a half-open range, to hit {@code NaN} use a query
|
* {@link Double#NaN} will never match a half-open range, to hit {@code NaN} use a query
|
||||||
|
@ -268,7 +269,7 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Double> newDoubleRange(final String field,
|
public static LegacyNumericRangeQuery<Double> newDoubleRange(final String field,
|
||||||
Double min, Double max, final boolean minInclusive, final boolean maxInclusive
|
Double min, Double max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT, FieldType.LegacyNumericType.DOUBLE, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT, LegacyNumericType.DOUBLE, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -283,12 +284,12 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Float> newFloatRange(final String field, final int precisionStep,
|
public static LegacyNumericRangeQuery<Float> newFloatRange(final String field, final int precisionStep,
|
||||||
Float min, Float max, final boolean minInclusive, final boolean maxInclusive
|
Float min, Float max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, precisionStep, FieldType.LegacyNumericType.FLOAT, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, precisionStep, LegacyNumericType.FLOAT, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>float</code>
|
* Factory that creates a <code>LegacyNumericRangeQuery</code>, that queries a <code>float</code>
|
||||||
* range using the default <code>precisionStep</code> {@link org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
* range using the default <code>precisionStep</code> {@link org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT_32} (8).
|
||||||
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
* You can have half-open ranges (which are in fact </≤ or >/≥ queries)
|
||||||
* by setting the min or max value to <code>null</code>.
|
* by setting the min or max value to <code>null</code>.
|
||||||
* {@link Float#NaN} will never match a half-open range, to hit {@code NaN} use a query
|
* {@link Float#NaN} will never match a half-open range, to hit {@code NaN} use a query
|
||||||
|
@ -298,7 +299,7 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
public static LegacyNumericRangeQuery<Float> newFloatRange(final String field,
|
public static LegacyNumericRangeQuery<Float> newFloatRange(final String field,
|
||||||
Float min, Float max, final boolean minInclusive, final boolean maxInclusive
|
Float min, Float max, final boolean minInclusive, final boolean maxInclusive
|
||||||
) {
|
) {
|
||||||
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT_32, FieldType.LegacyNumericType.FLOAT, min, max, minInclusive, maxInclusive);
|
return new LegacyNumericRangeQuery<>(field, LegacyNumericUtils.PRECISION_STEP_DEFAULT_32, LegacyNumericType.FLOAT, min, max, minInclusive, maxInclusive);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override @SuppressWarnings("unchecked")
|
@Override @SuppressWarnings("unchecked")
|
||||||
|
@ -369,7 +370,7 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
|
|
||||||
// members (package private, to be also fast accessible by NumericRangeTermEnum)
|
// members (package private, to be also fast accessible by NumericRangeTermEnum)
|
||||||
final int precisionStep;
|
final int precisionStep;
|
||||||
final FieldType.LegacyNumericType dataType;
|
final LegacyNumericType dataType;
|
||||||
final T min, max;
|
final T min, max;
|
||||||
final boolean minInclusive,maxInclusive;
|
final boolean minInclusive,maxInclusive;
|
||||||
|
|
||||||
|
@ -389,8 +390,8 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
* <p>
|
* <p>
|
||||||
* WARNING: This term enumeration is not guaranteed to be always ordered by
|
* WARNING: This term enumeration is not guaranteed to be always ordered by
|
||||||
* {@link Term#compareTo}.
|
* {@link Term#compareTo}.
|
||||||
* The ordering depends on how {@link org.apache.lucene.util.LegacyNumericUtils#splitLongRange} and
|
* The ordering depends on how {@link org.apache.lucene.legacy.LegacyNumericUtils#splitLongRange} and
|
||||||
* {@link org.apache.lucene.util.LegacyNumericUtils#splitIntRange} generates the sub-ranges. For
|
* {@link org.apache.lucene.legacy.LegacyNumericUtils#splitIntRange} generates the sub-ranges. For
|
||||||
* {@link MultiTermQuery} ordering is not relevant.
|
* {@link MultiTermQuery} ordering is not relevant.
|
||||||
*/
|
*/
|
||||||
private final class NumericRangeTermsEnum extends FilteredTermsEnum {
|
private final class NumericRangeTermsEnum extends FilteredTermsEnum {
|
||||||
|
@ -406,10 +407,10 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
case DOUBLE: {
|
case DOUBLE: {
|
||||||
// lower
|
// lower
|
||||||
long minBound;
|
long minBound;
|
||||||
if (dataType == FieldType.LegacyNumericType.LONG) {
|
if (dataType == LegacyNumericType.LONG) {
|
||||||
minBound = (min == null) ? Long.MIN_VALUE : min.longValue();
|
minBound = (min == null) ? Long.MIN_VALUE : min.longValue();
|
||||||
} else {
|
} else {
|
||||||
assert dataType == FieldType.LegacyNumericType.DOUBLE;
|
assert dataType == LegacyNumericType.DOUBLE;
|
||||||
minBound = (min == null) ? LONG_NEGATIVE_INFINITY
|
minBound = (min == null) ? LONG_NEGATIVE_INFINITY
|
||||||
: NumericUtils.doubleToSortableLong(min.doubleValue());
|
: NumericUtils.doubleToSortableLong(min.doubleValue());
|
||||||
}
|
}
|
||||||
|
@ -420,10 +421,10 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
|
|
||||||
// upper
|
// upper
|
||||||
long maxBound;
|
long maxBound;
|
||||||
if (dataType == FieldType.LegacyNumericType.LONG) {
|
if (dataType == LegacyNumericType.LONG) {
|
||||||
maxBound = (max == null) ? Long.MAX_VALUE : max.longValue();
|
maxBound = (max == null) ? Long.MAX_VALUE : max.longValue();
|
||||||
} else {
|
} else {
|
||||||
assert dataType == FieldType.LegacyNumericType.DOUBLE;
|
assert dataType == LegacyNumericType.DOUBLE;
|
||||||
maxBound = (max == null) ? LONG_POSITIVE_INFINITY
|
maxBound = (max == null) ? LONG_POSITIVE_INFINITY
|
||||||
: NumericUtils.doubleToSortableLong(max.doubleValue());
|
: NumericUtils.doubleToSortableLong(max.doubleValue());
|
||||||
}
|
}
|
||||||
|
@ -446,10 +447,10 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
case FLOAT: {
|
case FLOAT: {
|
||||||
// lower
|
// lower
|
||||||
int minBound;
|
int minBound;
|
||||||
if (dataType == FieldType.LegacyNumericType.INT) {
|
if (dataType == LegacyNumericType.INT) {
|
||||||
minBound = (min == null) ? Integer.MIN_VALUE : min.intValue();
|
minBound = (min == null) ? Integer.MIN_VALUE : min.intValue();
|
||||||
} else {
|
} else {
|
||||||
assert dataType == FieldType.LegacyNumericType.FLOAT;
|
assert dataType == LegacyNumericType.FLOAT;
|
||||||
minBound = (min == null) ? INT_NEGATIVE_INFINITY
|
minBound = (min == null) ? INT_NEGATIVE_INFINITY
|
||||||
: NumericUtils.floatToSortableInt(min.floatValue());
|
: NumericUtils.floatToSortableInt(min.floatValue());
|
||||||
}
|
}
|
||||||
|
@ -463,7 +464,7 @@ public final class LegacyNumericRangeQuery<T extends Number> extends MultiTermQu
|
||||||
if (dataType == LegacyNumericType.INT) {
|
if (dataType == LegacyNumericType.INT) {
|
||||||
maxBound = (max == null) ? Integer.MAX_VALUE : max.intValue();
|
maxBound = (max == null) ? Integer.MAX_VALUE : max.intValue();
|
||||||
} else {
|
} else {
|
||||||
assert dataType == FieldType.LegacyNumericType.FLOAT;
|
assert dataType == LegacyNumericType.FLOAT;
|
||||||
maxBound = (max == null) ? INT_POSITIVE_INFINITY
|
maxBound = (max == null) ? INT_POSITIVE_INFINITY
|
||||||
: NumericUtils.floatToSortableInt(max.floatValue());
|
: NumericUtils.floatToSortableInt(max.floatValue());
|
||||||
}
|
}
|
|
@ -14,11 +14,12 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.analysis;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import org.apache.lucene.analysis.TokenStream;
|
||||||
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
|
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
|
||||||
import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute;
|
import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute;
|
||||||
import org.apache.lucene.analysis.tokenattributes.TermToBytesRefAttribute;
|
import org.apache.lucene.analysis.tokenattributes.TermToBytesRefAttribute;
|
||||||
|
@ -29,16 +30,15 @@ import org.apache.lucene.util.AttributeImpl;
|
||||||
import org.apache.lucene.util.AttributeReflector;
|
import org.apache.lucene.util.AttributeReflector;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <b>Expert:</b> This class provides a {@link TokenStream}
|
* <b>Expert:</b> This class provides a {@link TokenStream}
|
||||||
* for indexing numeric values that can be used by {@link
|
* for indexing numeric values that can be used by {@link
|
||||||
* org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
*
|
*
|
||||||
* <p>Note that for simple usage, {@link org.apache.lucene.document.LegacyIntField}, {@link
|
* <p>Note that for simple usage, {@link org.apache.lucene.legacy.LegacyIntField}, {@link
|
||||||
* org.apache.lucene.document.LegacyLongField}, {@link org.apache.lucene.document.LegacyFloatField} or {@link org.apache.lucene.document.LegacyDoubleField} is
|
* org.apache.lucene.legacy.LegacyLongField}, {@link org.apache.lucene.legacy.LegacyFloatField} or {@link org.apache.lucene.legacy.LegacyDoubleField} is
|
||||||
* recommended. These fields disable norms and
|
* recommended. These fields disable norms and
|
||||||
* term freqs, as they are not usually needed during
|
* term freqs, as they are not usually needed during
|
||||||
* searching. If you need to change these settings, you
|
* searching. If you need to change these settings, you
|
||||||
|
@ -81,9 +81,9 @@ import org.apache.lucene.util.NumericUtils;
|
||||||
* than one numeric field, use a separate <code>LegacyNumericTokenStream</code>
|
* than one numeric field, use a separate <code>LegacyNumericTokenStream</code>
|
||||||
* instance for each.</p>
|
* instance for each.</p>
|
||||||
*
|
*
|
||||||
* <p>See {@link org.apache.lucene.search.LegacyNumericRangeQuery} for more details on the
|
* <p>See {@link org.apache.lucene.legacy.LegacyNumericRangeQuery} for more details on the
|
||||||
* <a
|
* <a
|
||||||
* href="../search/LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
* href="LegacyNumericRangeQuery.html#precisionStepDesc"><code>precisionStep</code></a>
|
||||||
* parameter as well as how numeric fields work under the hood.</p>
|
* parameter as well as how numeric fields work under the hood.</p>
|
||||||
*
|
*
|
||||||
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
@ -140,7 +140,7 @@ public final class LegacyNumericTokenStream extends TokenStream {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Implementation of {@link org.apache.lucene.analysis.LegacyNumericTokenStream.LegacyNumericTermAttribute}.
|
/** Implementation of {@link org.apache.lucene.legacy.LegacyNumericTokenStream.LegacyNumericTermAttribute}.
|
||||||
* @lucene.internal
|
* @lucene.internal
|
||||||
* @since 4.0
|
* @since 4.0
|
||||||
*/
|
*/
|
||||||
|
@ -240,7 +240,7 @@ public final class LegacyNumericTokenStream extends TokenStream {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a token stream for numeric values using the default <code>precisionStep</code>
|
* Creates a token stream for numeric values using the default <code>precisionStep</code>
|
||||||
* {@link org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16). The stream is not yet initialized,
|
* {@link org.apache.lucene.legacy.LegacyNumericUtils#PRECISION_STEP_DEFAULT} (16). The stream is not yet initialized,
|
||||||
* before using set a value using the various set<em>???</em>Value() methods.
|
* before using set a value using the various set<em>???</em>Value() methods.
|
||||||
*/
|
*/
|
||||||
public LegacyNumericTokenStream() {
|
public LegacyNumericTokenStream() {
|
|
@ -0,0 +1,34 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
/** Data type of the numeric value
|
||||||
|
* @since 3.2
|
||||||
|
*
|
||||||
|
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
public enum LegacyNumericType {
|
||||||
|
/** 32-bit integer numeric type */
|
||||||
|
INT,
|
||||||
|
/** 64-bit long numeric type */
|
||||||
|
LONG,
|
||||||
|
/** 32-bit float numeric type */
|
||||||
|
FLOAT,
|
||||||
|
/** 64-bit double numeric type */
|
||||||
|
DOUBLE
|
||||||
|
}
|
|
@ -14,7 +14,7 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.util;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -23,6 +23,8 @@ import org.apache.lucene.index.FilterLeafReader;
|
||||||
import org.apache.lucene.index.FilteredTermsEnum;
|
import org.apache.lucene.index.FilteredTermsEnum;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.index.TermsEnum;
|
||||||
|
import org.apache.lucene.util.BytesRef;
|
||||||
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is a helper class to generate prefix-encoded representations for numerical values
|
* This is a helper class to generate prefix-encoded representations for numerical values
|
||||||
|
@ -41,9 +43,9 @@ import org.apache.lucene.index.TermsEnum;
|
||||||
* during encoding.
|
* during encoding.
|
||||||
*
|
*
|
||||||
* <p>For easy usage, the trie algorithm is implemented for indexing inside
|
* <p>For easy usage, the trie algorithm is implemented for indexing inside
|
||||||
* {@link org.apache.lucene.analysis.LegacyNumericTokenStream} that can index <code>int</code>, <code>long</code>,
|
* {@link org.apache.lucene.legacy.LegacyNumericTokenStream} that can index <code>int</code>, <code>long</code>,
|
||||||
* <code>float</code>, and <code>double</code>. For querying,
|
* <code>float</code>, and <code>double</code>. For querying,
|
||||||
* {@link org.apache.lucene.search.LegacyNumericRangeQuery} implements the query part
|
* {@link org.apache.lucene.legacy.LegacyNumericRangeQuery} implements the query part
|
||||||
* for the same data types.
|
* for the same data types.
|
||||||
*
|
*
|
||||||
* @lucene.internal
|
* @lucene.internal
|
||||||
|
@ -59,15 +61,15 @@ public final class LegacyNumericUtils {
|
||||||
private LegacyNumericUtils() {} // no instance!
|
private LegacyNumericUtils() {} // no instance!
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The default precision step used by {@link org.apache.lucene.document.LegacyLongField},
|
* The default precision step used by {@link org.apache.lucene.legacy.LegacyLongField},
|
||||||
* {@link org.apache.lucene.document.LegacyDoubleField}, {@link org.apache.lucene.analysis.LegacyNumericTokenStream}, {@link
|
* {@link org.apache.lucene.legacy.LegacyDoubleField}, {@link org.apache.lucene.legacy.LegacyNumericTokenStream}, {@link
|
||||||
* org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
*/
|
*/
|
||||||
public static final int PRECISION_STEP_DEFAULT = 16;
|
public static final int PRECISION_STEP_DEFAULT = 16;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The default precision step used by {@link org.apache.lucene.document.LegacyIntField} and
|
* The default precision step used by {@link org.apache.lucene.legacy.LegacyIntField} and
|
||||||
* {@link org.apache.lucene.document.LegacyFloatField}.
|
* {@link org.apache.lucene.legacy.LegacyFloatField}.
|
||||||
*/
|
*/
|
||||||
public static final int PRECISION_STEP_DEFAULT_32 = 8;
|
public static final int PRECISION_STEP_DEFAULT_32 = 8;
|
||||||
|
|
||||||
|
@ -99,7 +101,7 @@ public final class LegacyNumericUtils {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns prefix coded bits after reducing the precision by <code>shift</code> bits.
|
* Returns prefix coded bits after reducing the precision by <code>shift</code> bits.
|
||||||
* This is method is used by {@link org.apache.lucene.analysis.LegacyNumericTokenStream}.
|
* This is method is used by {@link org.apache.lucene.legacy.LegacyNumericTokenStream}.
|
||||||
* After encoding, {@code bytes.offset} will always be 0.
|
* After encoding, {@code bytes.offset} will always be 0.
|
||||||
* @param val the numeric value
|
* @param val the numeric value
|
||||||
* @param shift how many bits to strip from the right
|
* @param shift how many bits to strip from the right
|
||||||
|
@ -126,7 +128,7 @@ public final class LegacyNumericUtils {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns prefix coded bits after reducing the precision by <code>shift</code> bits.
|
* Returns prefix coded bits after reducing the precision by <code>shift</code> bits.
|
||||||
* This is method is used by {@link org.apache.lucene.analysis.LegacyNumericTokenStream}.
|
* This is method is used by {@link org.apache.lucene.legacy.LegacyNumericTokenStream}.
|
||||||
* After encoding, {@code bytes.offset} will always be 0.
|
* After encoding, {@code bytes.offset} will always be 0.
|
||||||
* @param val the numeric value
|
* @param val the numeric value
|
||||||
* @param shift how many bits to strip from the right
|
* @param shift how many bits to strip from the right
|
||||||
|
@ -230,7 +232,7 @@ public final class LegacyNumericUtils {
|
||||||
* {@link org.apache.lucene.search.BooleanQuery} for each call to its
|
* {@link org.apache.lucene.search.BooleanQuery} for each call to its
|
||||||
* {@link LongRangeBuilder#addRange(BytesRef,BytesRef)}
|
* {@link LongRangeBuilder#addRange(BytesRef,BytesRef)}
|
||||||
* method.
|
* method.
|
||||||
* <p>This method is used by {@link org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* <p>This method is used by {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
*/
|
*/
|
||||||
public static void splitLongRange(final LongRangeBuilder builder,
|
public static void splitLongRange(final LongRangeBuilder builder,
|
||||||
final int precisionStep, final long minBound, final long maxBound
|
final int precisionStep, final long minBound, final long maxBound
|
||||||
|
@ -244,7 +246,7 @@ public final class LegacyNumericUtils {
|
||||||
* {@link org.apache.lucene.search.BooleanQuery} for each call to its
|
* {@link org.apache.lucene.search.BooleanQuery} for each call to its
|
||||||
* {@link IntRangeBuilder#addRange(BytesRef,BytesRef)}
|
* {@link IntRangeBuilder#addRange(BytesRef,BytesRef)}
|
||||||
* method.
|
* method.
|
||||||
* <p>This method is used by {@link org.apache.lucene.search.LegacyNumericRangeQuery}.
|
* <p>This method is used by {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}.
|
||||||
*/
|
*/
|
||||||
public static void splitIntRange(final IntRangeBuilder builder,
|
public static void splitIntRange(final IntRangeBuilder builder,
|
||||||
final int precisionStep, final int minBound, final int maxBound
|
final int precisionStep, final int minBound, final int maxBound
|
|
@ -0,0 +1,21 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deprecated stuff!
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.legacy;
|
|
@ -47,8 +47,6 @@ import org.apache.lucene.document.FieldType;
|
||||||
import org.apache.lucene.document.FloatDocValuesField;
|
import org.apache.lucene.document.FloatDocValuesField;
|
||||||
import org.apache.lucene.document.FloatPoint;
|
import org.apache.lucene.document.FloatPoint;
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.LongPoint;
|
import org.apache.lucene.document.LongPoint;
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.SortedDocValuesField;
|
import org.apache.lucene.document.SortedDocValuesField;
|
||||||
|
@ -57,9 +55,12 @@ import org.apache.lucene.document.SortedSetDocValuesField;
|
||||||
import org.apache.lucene.document.StringField;
|
import org.apache.lucene.document.StringField;
|
||||||
import org.apache.lucene.document.TextField;
|
import org.apache.lucene.document.TextField;
|
||||||
import org.apache.lucene.index.IndexWriterConfig.OpenMode;
|
import org.apache.lucene.index.IndexWriterConfig.OpenMode;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.search.DocIdSetIterator;
|
import org.apache.lucene.search.DocIdSetIterator;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.ScoreDoc;
|
import org.apache.lucene.search.ScoreDoc;
|
||||||
import org.apache.lucene.search.TermQuery;
|
import org.apache.lucene.search.TermQuery;
|
||||||
import org.apache.lucene.store.BaseDirectoryWrapper;
|
import org.apache.lucene.store.BaseDirectoryWrapper;
|
||||||
|
@ -72,7 +73,6 @@ import org.apache.lucene.util.Bits;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.IOUtils;
|
import org.apache.lucene.util.IOUtils;
|
||||||
import org.apache.lucene.util.InfoStream;
|
import org.apache.lucene.util.InfoStream;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.LineFileDocs;
|
import org.apache.lucene.util.LineFileDocs;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
|
|
|
@ -0,0 +1,196 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
import java.io.StringReader;
|
||||||
|
|
||||||
|
import org.apache.lucene.analysis.CannedTokenStream;
|
||||||
|
import org.apache.lucene.analysis.Token;
|
||||||
|
import org.apache.lucene.document.Field;
|
||||||
|
import org.apache.lucene.util.BytesRef;
|
||||||
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
|
||||||
|
public class TestLegacyField extends LuceneTestCase {
|
||||||
|
|
||||||
|
public void testLegacyDoubleField() throws Exception {
|
||||||
|
Field fields[] = new Field[] {
|
||||||
|
new LegacyDoubleField("foo", 5d, Field.Store.NO),
|
||||||
|
new LegacyDoubleField("foo", 5d, Field.Store.YES)
|
||||||
|
};
|
||||||
|
|
||||||
|
for (Field field : fields) {
|
||||||
|
trySetBoost(field);
|
||||||
|
trySetByteValue(field);
|
||||||
|
trySetBytesValue(field);
|
||||||
|
trySetBytesRefValue(field);
|
||||||
|
field.setDoubleValue(6d); // ok
|
||||||
|
trySetIntValue(field);
|
||||||
|
trySetFloatValue(field);
|
||||||
|
trySetLongValue(field);
|
||||||
|
trySetReaderValue(field);
|
||||||
|
trySetShortValue(field);
|
||||||
|
trySetStringValue(field);
|
||||||
|
trySetTokenStreamValue(field);
|
||||||
|
|
||||||
|
assertEquals(6d, field.numericValue().doubleValue(), 0.0d);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testLegacyFloatField() throws Exception {
|
||||||
|
Field fields[] = new Field[] {
|
||||||
|
new LegacyFloatField("foo", 5f, Field.Store.NO),
|
||||||
|
new LegacyFloatField("foo", 5f, Field.Store.YES)
|
||||||
|
};
|
||||||
|
|
||||||
|
for (Field field : fields) {
|
||||||
|
trySetBoost(field);
|
||||||
|
trySetByteValue(field);
|
||||||
|
trySetBytesValue(field);
|
||||||
|
trySetBytesRefValue(field);
|
||||||
|
trySetDoubleValue(field);
|
||||||
|
trySetIntValue(field);
|
||||||
|
field.setFloatValue(6f); // ok
|
||||||
|
trySetLongValue(field);
|
||||||
|
trySetReaderValue(field);
|
||||||
|
trySetShortValue(field);
|
||||||
|
trySetStringValue(field);
|
||||||
|
trySetTokenStreamValue(field);
|
||||||
|
|
||||||
|
assertEquals(6f, field.numericValue().floatValue(), 0.0f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testLegacyIntField() throws Exception {
|
||||||
|
Field fields[] = new Field[] {
|
||||||
|
new LegacyIntField("foo", 5, Field.Store.NO),
|
||||||
|
new LegacyIntField("foo", 5, Field.Store.YES)
|
||||||
|
};
|
||||||
|
|
||||||
|
for (Field field : fields) {
|
||||||
|
trySetBoost(field);
|
||||||
|
trySetByteValue(field);
|
||||||
|
trySetBytesValue(field);
|
||||||
|
trySetBytesRefValue(field);
|
||||||
|
trySetDoubleValue(field);
|
||||||
|
field.setIntValue(6); // ok
|
||||||
|
trySetFloatValue(field);
|
||||||
|
trySetLongValue(field);
|
||||||
|
trySetReaderValue(field);
|
||||||
|
trySetShortValue(field);
|
||||||
|
trySetStringValue(field);
|
||||||
|
trySetTokenStreamValue(field);
|
||||||
|
|
||||||
|
assertEquals(6, field.numericValue().intValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testLegacyLongField() throws Exception {
|
||||||
|
Field fields[] = new Field[] {
|
||||||
|
new LegacyLongField("foo", 5L, Field.Store.NO),
|
||||||
|
new LegacyLongField("foo", 5L, Field.Store.YES)
|
||||||
|
};
|
||||||
|
|
||||||
|
for (Field field : fields) {
|
||||||
|
trySetBoost(field);
|
||||||
|
trySetByteValue(field);
|
||||||
|
trySetBytesValue(field);
|
||||||
|
trySetBytesRefValue(field);
|
||||||
|
trySetDoubleValue(field);
|
||||||
|
trySetIntValue(field);
|
||||||
|
trySetFloatValue(field);
|
||||||
|
field.setLongValue(6); // ok
|
||||||
|
trySetReaderValue(field);
|
||||||
|
trySetShortValue(field);
|
||||||
|
trySetStringValue(field);
|
||||||
|
trySetTokenStreamValue(field);
|
||||||
|
|
||||||
|
assertEquals(6L, field.numericValue().longValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetByteValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setByteValue((byte) 10);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetBytesValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setBytesValue(new byte[] { 5, 5 });
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetBytesRefValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setBytesValue(new BytesRef("bogus"));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetDoubleValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setDoubleValue(Double.MAX_VALUE);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetIntValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setIntValue(Integer.MAX_VALUE);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetLongValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setLongValue(Long.MAX_VALUE);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetFloatValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setFloatValue(Float.MAX_VALUE);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetReaderValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setReaderValue(new StringReader("BOO!"));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetShortValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setShortValue(Short.MAX_VALUE);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetStringValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setStringValue("BOO!");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetTokenStreamValue(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setTokenStream(new CannedTokenStream(new Token("foo", 0, 3)));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void trySetBoost(Field f) {
|
||||||
|
expectThrows(IllegalArgumentException.class, () -> {
|
||||||
|
f.setBoost(5.0f);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,81 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.apache.lucene.analysis.BaseTokenStreamTestCase;
|
||||||
|
import org.apache.lucene.analysis.CannedTokenStream;
|
||||||
|
import org.apache.lucene.analysis.Token;
|
||||||
|
import org.apache.lucene.analysis.TokenStream;
|
||||||
|
import org.apache.lucene.document.Field;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericTokenStream;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericTokenStream.LegacyNumericTermAttribute;
|
||||||
|
|
||||||
|
/** test tokenstream reuse by DefaultIndexingChain */
|
||||||
|
public class TestLegacyFieldReuse extends BaseTokenStreamTestCase {
|
||||||
|
|
||||||
|
public void testNumericReuse() throws IOException {
|
||||||
|
LegacyIntField legacyIntField = new LegacyIntField("foo", 5, Field.Store.NO);
|
||||||
|
|
||||||
|
// passing null
|
||||||
|
TokenStream ts = legacyIntField.tokenStream(null, null);
|
||||||
|
assertTrue(ts instanceof LegacyNumericTokenStream);
|
||||||
|
assertEquals(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32, ((LegacyNumericTokenStream)ts).getPrecisionStep());
|
||||||
|
assertNumericContents(5, ts);
|
||||||
|
|
||||||
|
// now reuse previous stream
|
||||||
|
legacyIntField = new LegacyIntField("foo", 20, Field.Store.NO);
|
||||||
|
TokenStream ts2 = legacyIntField.tokenStream(null, ts);
|
||||||
|
assertSame(ts, ts2);
|
||||||
|
assertNumericContents(20, ts);
|
||||||
|
|
||||||
|
// pass a bogus stream and ensure it's still ok
|
||||||
|
legacyIntField = new LegacyIntField("foo", 2343, Field.Store.NO);
|
||||||
|
TokenStream bogus = new CannedTokenStream(new Token("bogus", 0, 5));
|
||||||
|
ts = legacyIntField.tokenStream(null, bogus);
|
||||||
|
assertNotSame(bogus, ts);
|
||||||
|
assertNumericContents(2343, ts);
|
||||||
|
|
||||||
|
// pass another bogus stream (numeric, but different precision step!)
|
||||||
|
legacyIntField = new LegacyIntField("foo", 42, Field.Store.NO);
|
||||||
|
assert 3 != LegacyNumericUtils.PRECISION_STEP_DEFAULT;
|
||||||
|
bogus = new LegacyNumericTokenStream(3);
|
||||||
|
ts = legacyIntField.tokenStream(null, bogus);
|
||||||
|
assertNotSame(bogus, ts);
|
||||||
|
assertNumericContents(42, ts);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void assertNumericContents(int value, TokenStream ts) throws IOException {
|
||||||
|
assertTrue(ts instanceof LegacyNumericTokenStream);
|
||||||
|
LegacyNumericTermAttribute numericAtt = ts.getAttribute(LegacyNumericTermAttribute.class);
|
||||||
|
ts.reset();
|
||||||
|
boolean seen = false;
|
||||||
|
while (ts.incrementToken()) {
|
||||||
|
if (numericAtt.getShift() == 0) {
|
||||||
|
assertEquals(value, numericAtt.getRawValue());
|
||||||
|
seen = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ts.end();
|
||||||
|
ts.close();
|
||||||
|
assertTrue(seen);
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,7 +14,7 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.util;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
@ -22,6 +22,13 @@ import java.util.Collections;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
|
import org.apache.lucene.util.FixedBitSet;
|
||||||
|
import org.apache.lucene.util.LongBitSet;
|
||||||
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.NumericUtils;
|
||||||
|
|
||||||
public class TestLegacyNumericUtils extends LuceneTestCase {
|
public class TestLegacyNumericUtils extends LuceneTestCase {
|
||||||
|
|
||||||
public void testLongConversionAndOrdering() throws Exception {
|
public void testLongConversionAndOrdering() throws Exception {
|
|
@ -0,0 +1,164 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
import org.apache.lucene.document.Document;
|
||||||
|
import org.apache.lucene.document.Field;
|
||||||
|
import org.apache.lucene.index.IndexReader;
|
||||||
|
import org.apache.lucene.index.MultiFields;
|
||||||
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
|
import org.apache.lucene.index.Terms;
|
||||||
|
import org.apache.lucene.index.TermsEnum;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFloatField;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
|
import org.apache.lucene.store.Directory;
|
||||||
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.NumericUtils;
|
||||||
|
|
||||||
|
public class TestLegacyTerms extends LuceneTestCase {
|
||||||
|
|
||||||
|
public void testEmptyIntFieldMinMax() throws Exception {
|
||||||
|
assertNull(LegacyNumericUtils.getMinInt(EMPTY_TERMS));
|
||||||
|
assertNull(LegacyNumericUtils.getMaxInt(EMPTY_TERMS));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testIntFieldMinMax() throws Exception {
|
||||||
|
Directory dir = newDirectory();
|
||||||
|
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
||||||
|
int numDocs = atLeast(100);
|
||||||
|
int minValue = Integer.MAX_VALUE;
|
||||||
|
int maxValue = Integer.MIN_VALUE;
|
||||||
|
for(int i=0;i<numDocs;i++ ){
|
||||||
|
Document doc = new Document();
|
||||||
|
int num = random().nextInt();
|
||||||
|
minValue = Math.min(num, minValue);
|
||||||
|
maxValue = Math.max(num, maxValue);
|
||||||
|
doc.add(new LegacyIntField("field", num, Field.Store.NO));
|
||||||
|
w.addDocument(doc);
|
||||||
|
}
|
||||||
|
|
||||||
|
IndexReader r = w.getReader();
|
||||||
|
Terms terms = MultiFields.getTerms(r, "field");
|
||||||
|
assertEquals(new Integer(minValue), LegacyNumericUtils.getMinInt(terms));
|
||||||
|
assertEquals(new Integer(maxValue), LegacyNumericUtils.getMaxInt(terms));
|
||||||
|
|
||||||
|
r.close();
|
||||||
|
w.close();
|
||||||
|
dir.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testEmptyLongFieldMinMax() throws Exception {
|
||||||
|
assertNull(LegacyNumericUtils.getMinLong(EMPTY_TERMS));
|
||||||
|
assertNull(LegacyNumericUtils.getMaxLong(EMPTY_TERMS));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testLongFieldMinMax() throws Exception {
|
||||||
|
Directory dir = newDirectory();
|
||||||
|
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
||||||
|
int numDocs = atLeast(100);
|
||||||
|
long minValue = Long.MAX_VALUE;
|
||||||
|
long maxValue = Long.MIN_VALUE;
|
||||||
|
for(int i=0;i<numDocs;i++ ){
|
||||||
|
Document doc = new Document();
|
||||||
|
long num = random().nextLong();
|
||||||
|
minValue = Math.min(num, minValue);
|
||||||
|
maxValue = Math.max(num, maxValue);
|
||||||
|
doc.add(new LegacyLongField("field", num, Field.Store.NO));
|
||||||
|
w.addDocument(doc);
|
||||||
|
}
|
||||||
|
|
||||||
|
IndexReader r = w.getReader();
|
||||||
|
|
||||||
|
Terms terms = MultiFields.getTerms(r, "field");
|
||||||
|
assertEquals(new Long(minValue), LegacyNumericUtils.getMinLong(terms));
|
||||||
|
assertEquals(new Long(maxValue), LegacyNumericUtils.getMaxLong(terms));
|
||||||
|
|
||||||
|
r.close();
|
||||||
|
w.close();
|
||||||
|
dir.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testFloatFieldMinMax() throws Exception {
|
||||||
|
Directory dir = newDirectory();
|
||||||
|
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
||||||
|
int numDocs = atLeast(100);
|
||||||
|
float minValue = Float.POSITIVE_INFINITY;
|
||||||
|
float maxValue = Float.NEGATIVE_INFINITY;
|
||||||
|
for(int i=0;i<numDocs;i++ ){
|
||||||
|
Document doc = new Document();
|
||||||
|
float num = random().nextFloat();
|
||||||
|
minValue = Math.min(num, minValue);
|
||||||
|
maxValue = Math.max(num, maxValue);
|
||||||
|
doc.add(new LegacyFloatField("field", num, Field.Store.NO));
|
||||||
|
w.addDocument(doc);
|
||||||
|
}
|
||||||
|
|
||||||
|
IndexReader r = w.getReader();
|
||||||
|
Terms terms = MultiFields.getTerms(r, "field");
|
||||||
|
assertEquals(minValue, NumericUtils.sortableIntToFloat(LegacyNumericUtils.getMinInt(terms)), 0.0f);
|
||||||
|
assertEquals(maxValue, NumericUtils.sortableIntToFloat(LegacyNumericUtils.getMaxInt(terms)), 0.0f);
|
||||||
|
|
||||||
|
r.close();
|
||||||
|
w.close();
|
||||||
|
dir.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testDoubleFieldMinMax() throws Exception {
|
||||||
|
Directory dir = newDirectory();
|
||||||
|
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
||||||
|
int numDocs = atLeast(100);
|
||||||
|
double minValue = Double.POSITIVE_INFINITY;
|
||||||
|
double maxValue = Double.NEGATIVE_INFINITY;
|
||||||
|
for(int i=0;i<numDocs;i++ ){
|
||||||
|
Document doc = new Document();
|
||||||
|
double num = random().nextDouble();
|
||||||
|
minValue = Math.min(num, minValue);
|
||||||
|
maxValue = Math.max(num, maxValue);
|
||||||
|
doc.add(new LegacyDoubleField("field", num, Field.Store.NO));
|
||||||
|
w.addDocument(doc);
|
||||||
|
}
|
||||||
|
|
||||||
|
IndexReader r = w.getReader();
|
||||||
|
|
||||||
|
Terms terms = MultiFields.getTerms(r, "field");
|
||||||
|
|
||||||
|
assertEquals(minValue, NumericUtils.sortableLongToDouble(LegacyNumericUtils.getMinLong(terms)), 0.0);
|
||||||
|
assertEquals(maxValue, NumericUtils.sortableLongToDouble(LegacyNumericUtils.getMaxLong(terms)), 0.0);
|
||||||
|
|
||||||
|
r.close();
|
||||||
|
w.close();
|
||||||
|
dir.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A complete empty Terms instance that has no terms in it and supports no optional statistics
|
||||||
|
*/
|
||||||
|
private static Terms EMPTY_TERMS = new Terms() {
|
||||||
|
public TermsEnum iterator() { return TermsEnum.EMPTY; }
|
||||||
|
public long size() { return -1; }
|
||||||
|
public long getSumTotalTermFreq() { return -1; }
|
||||||
|
public long getSumDocFreq() { return -1; }
|
||||||
|
public int getDocCount() { return -1; }
|
||||||
|
public boolean hasFreqs() { return false; }
|
||||||
|
public boolean hasOffsets() { return false; }
|
||||||
|
public boolean hasPositions() { return false; }
|
||||||
|
public boolean hasPayloads() { return false; }
|
||||||
|
};
|
||||||
|
}
|
|
@ -14,7 +14,7 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.search;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
@ -24,9 +24,13 @@ import java.text.DecimalFormatSymbols;
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
|
import org.apache.lucene.search.TermRangeQuery;
|
||||||
|
import org.apache.lucene.search.TopDocs;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
|
@ -14,28 +14,26 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.search;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.index.DirectoryReader;
|
import org.apache.lucene.index.DirectoryReader;
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.MultiFields;
|
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
|
import org.apache.lucene.search.MultiTermQuery;
|
||||||
|
import org.apache.lucene.search.Query;
|
||||||
|
import org.apache.lucene.search.QueryUtils;
|
||||||
|
import org.apache.lucene.search.ScoreDoc;
|
||||||
|
import org.apache.lucene.search.Sort;
|
||||||
|
import org.apache.lucene.search.TopDocs;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.BytesRef;
|
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.lucene.util.TestLegacyNumericUtils; // NaN arrays
|
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
import org.junit.AfterClass;
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
|
@ -63,31 +61,31 @@ public class TestNumericRangeQuery32 extends LuceneTestCase {
|
||||||
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
||||||
.setMergePolicy(newLogMergePolicy()));
|
.setMergePolicy(newLogMergePolicy()));
|
||||||
|
|
||||||
final FieldType storedInt = new FieldType(LegacyIntField.TYPE_NOT_STORED);
|
final LegacyFieldType storedInt = new LegacyFieldType(LegacyIntField.TYPE_NOT_STORED);
|
||||||
storedInt.setStored(true);
|
storedInt.setStored(true);
|
||||||
storedInt.freeze();
|
storedInt.freeze();
|
||||||
|
|
||||||
final FieldType storedInt8 = new FieldType(storedInt);
|
final LegacyFieldType storedInt8 = new LegacyFieldType(storedInt);
|
||||||
storedInt8.setNumericPrecisionStep(8);
|
storedInt8.setNumericPrecisionStep(8);
|
||||||
|
|
||||||
final FieldType storedInt4 = new FieldType(storedInt);
|
final LegacyFieldType storedInt4 = new LegacyFieldType(storedInt);
|
||||||
storedInt4.setNumericPrecisionStep(4);
|
storedInt4.setNumericPrecisionStep(4);
|
||||||
|
|
||||||
final FieldType storedInt2 = new FieldType(storedInt);
|
final LegacyFieldType storedInt2 = new LegacyFieldType(storedInt);
|
||||||
storedInt2.setNumericPrecisionStep(2);
|
storedInt2.setNumericPrecisionStep(2);
|
||||||
|
|
||||||
final FieldType storedIntNone = new FieldType(storedInt);
|
final LegacyFieldType storedIntNone = new LegacyFieldType(storedInt);
|
||||||
storedIntNone.setNumericPrecisionStep(Integer.MAX_VALUE);
|
storedIntNone.setNumericPrecisionStep(Integer.MAX_VALUE);
|
||||||
|
|
||||||
final FieldType unstoredInt = LegacyIntField.TYPE_NOT_STORED;
|
final LegacyFieldType unstoredInt = LegacyIntField.TYPE_NOT_STORED;
|
||||||
|
|
||||||
final FieldType unstoredInt8 = new FieldType(unstoredInt);
|
final LegacyFieldType unstoredInt8 = new LegacyFieldType(unstoredInt);
|
||||||
unstoredInt8.setNumericPrecisionStep(8);
|
unstoredInt8.setNumericPrecisionStep(8);
|
||||||
|
|
||||||
final FieldType unstoredInt4 = new FieldType(unstoredInt);
|
final LegacyFieldType unstoredInt4 = new LegacyFieldType(unstoredInt);
|
||||||
unstoredInt4.setNumericPrecisionStep(4);
|
unstoredInt4.setNumericPrecisionStep(4);
|
||||||
|
|
||||||
final FieldType unstoredInt2 = new FieldType(unstoredInt);
|
final LegacyFieldType unstoredInt2 = new LegacyFieldType(unstoredInt);
|
||||||
unstoredInt2.setNumericPrecisionStep(2);
|
unstoredInt2.setNumericPrecisionStep(2);
|
||||||
|
|
||||||
LegacyIntField
|
LegacyIntField
|
||||||
|
@ -350,132 +348,6 @@ public class TestNumericRangeQuery32 extends LuceneTestCase {
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void testRandomTrieAndClassicRangeQuery(int precisionStep) throws Exception {
|
|
||||||
String field="field"+precisionStep;
|
|
||||||
int totalTermCountT=0,totalTermCountC=0,termCountT,termCountC;
|
|
||||||
int num = TestUtil.nextInt(random(), 10, 20);
|
|
||||||
for (int i = 0; i < num; i++) {
|
|
||||||
int lower=(int)(random().nextDouble()*noDocs*distance)+startOffset;
|
|
||||||
int upper=(int)(random().nextDouble()*noDocs*distance)+startOffset;
|
|
||||||
if (lower>upper) {
|
|
||||||
int a=lower; lower=upper; upper=a;
|
|
||||||
}
|
|
||||||
final BytesRef lowerBytes, upperBytes;
|
|
||||||
BytesRefBuilder b = new BytesRefBuilder();
|
|
||||||
LegacyNumericUtils.intToPrefixCoded(lower, 0, b);
|
|
||||||
lowerBytes = b.toBytesRef();
|
|
||||||
LegacyNumericUtils.intToPrefixCoded(upper, 0, b);
|
|
||||||
upperBytes = b.toBytesRef();
|
|
||||||
|
|
||||||
// test inclusive range
|
|
||||||
LegacyNumericRangeQuery<Integer> tq= LegacyNumericRangeQuery.newIntRange(field, precisionStep, lower, upper, true, true);
|
|
||||||
TermRangeQuery cq=new TermRangeQuery(field, lowerBytes, upperBytes, true, true);
|
|
||||||
TopDocs tTopDocs = searcher.search(tq, 1);
|
|
||||||
TopDocs cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
// test exclusive range
|
|
||||||
tq= LegacyNumericRangeQuery.newIntRange(field, precisionStep, lower, upper, false, false);
|
|
||||||
cq=new TermRangeQuery(field, lowerBytes, upperBytes, false, false);
|
|
||||||
tTopDocs = searcher.search(tq, 1);
|
|
||||||
cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
// test left exclusive range
|
|
||||||
tq= LegacyNumericRangeQuery.newIntRange(field, precisionStep, lower, upper, false, true);
|
|
||||||
cq=new TermRangeQuery(field, lowerBytes, upperBytes, false, true);
|
|
||||||
tTopDocs = searcher.search(tq, 1);
|
|
||||||
cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
// test right exclusive range
|
|
||||||
tq= LegacyNumericRangeQuery.newIntRange(field, precisionStep, lower, upper, true, false);
|
|
||||||
cq=new TermRangeQuery(field, lowerBytes, upperBytes, true, false);
|
|
||||||
tTopDocs = searcher.search(tq, 1);
|
|
||||||
cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
}
|
|
||||||
|
|
||||||
checkTermCounts(precisionStep, totalTermCountT, totalTermCountC);
|
|
||||||
if (VERBOSE && precisionStep != Integer.MAX_VALUE) {
|
|
||||||
System.out.println("Average number of terms during random search on '" + field + "':");
|
|
||||||
System.out.println(" Numeric query: " + (((double)totalTermCountT)/(num * 4)));
|
|
||||||
System.out.println(" Classical query: " + (((double)totalTermCountC)/(num * 4)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testEmptyEnums() throws Exception {
|
|
||||||
int count=3000;
|
|
||||||
int lower=(distance*3/2)+startOffset, upper=lower + count*distance + (distance/3);
|
|
||||||
// test empty enum
|
|
||||||
assert lower < upper;
|
|
||||||
assertTrue(0 < countTerms(LegacyNumericRangeQuery.newIntRange("field4", 4, lower, upper, true, true)));
|
|
||||||
assertEquals(0, countTerms(LegacyNumericRangeQuery.newIntRange("field4", 4, upper, lower, true, true)));
|
|
||||||
// test empty enum outside of bounds
|
|
||||||
lower = distance*noDocs+startOffset;
|
|
||||||
upper = 2 * lower;
|
|
||||||
assert lower < upper;
|
|
||||||
assertEquals(0, countTerms(LegacyNumericRangeQuery.newIntRange("field4", 4, lower, upper, true, true)));
|
|
||||||
}
|
|
||||||
|
|
||||||
private int countTerms(MultiTermQuery q) throws Exception {
|
|
||||||
final Terms terms = MultiFields.getTerms(reader, q.getField());
|
|
||||||
if (terms == null)
|
|
||||||
return 0;
|
|
||||||
final TermsEnum termEnum = q.getTermsEnum(terms);
|
|
||||||
assertNotNull(termEnum);
|
|
||||||
int count = 0;
|
|
||||||
BytesRef cur, last = null;
|
|
||||||
while ((cur = termEnum.next()) != null) {
|
|
||||||
count++;
|
|
||||||
if (last != null) {
|
|
||||||
assertTrue(last.compareTo(cur) < 0);
|
|
||||||
}
|
|
||||||
last = BytesRef.deepCopyOf(cur);
|
|
||||||
}
|
|
||||||
// LUCENE-3314: the results after next() already returned null are undefined,
|
|
||||||
// assertNull(termEnum.next());
|
|
||||||
return count;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void checkTermCounts(int precisionStep, int termCountT, int termCountC) {
|
|
||||||
if (precisionStep == Integer.MAX_VALUE) {
|
|
||||||
assertEquals("Number of terms should be equal for unlimited precStep", termCountC, termCountT);
|
|
||||||
} else {
|
|
||||||
assertTrue("Number of terms for NRQ should be <= compared to classical TRQ", termCountT <= termCountC);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_8bit() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(8);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_4bit() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(4);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_2bit() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(2);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_NoTrie() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(Integer.MAX_VALUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void testRangeSplit(int precisionStep) throws Exception {
|
private void testRangeSplit(int precisionStep) throws Exception {
|
||||||
String field="ascfield"+precisionStep;
|
String field="ascfield"+precisionStep;
|
||||||
// 10 random tests
|
// 10 random tests
|
|
@ -14,28 +14,26 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.search;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.index.DirectoryReader;
|
import org.apache.lucene.index.DirectoryReader;
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.MultiFields;
|
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
|
import org.apache.lucene.search.MultiTermQuery;
|
||||||
|
import org.apache.lucene.search.Query;
|
||||||
|
import org.apache.lucene.search.QueryUtils;
|
||||||
|
import org.apache.lucene.search.ScoreDoc;
|
||||||
|
import org.apache.lucene.search.Sort;
|
||||||
|
import org.apache.lucene.search.TopDocs;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.BytesRef;
|
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.lucene.util.TestLegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
import org.junit.AfterClass;
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
|
@ -63,37 +61,37 @@ public class TestNumericRangeQuery64 extends LuceneTestCase {
|
||||||
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
||||||
.setMergePolicy(newLogMergePolicy()));
|
.setMergePolicy(newLogMergePolicy()));
|
||||||
|
|
||||||
final FieldType storedLong = new FieldType(LegacyLongField.TYPE_NOT_STORED);
|
final LegacyFieldType storedLong = new LegacyFieldType(LegacyLongField.TYPE_NOT_STORED);
|
||||||
storedLong.setStored(true);
|
storedLong.setStored(true);
|
||||||
storedLong.freeze();
|
storedLong.freeze();
|
||||||
|
|
||||||
final FieldType storedLong8 = new FieldType(storedLong);
|
final LegacyFieldType storedLong8 = new LegacyFieldType(storedLong);
|
||||||
storedLong8.setNumericPrecisionStep(8);
|
storedLong8.setNumericPrecisionStep(8);
|
||||||
|
|
||||||
final FieldType storedLong4 = new FieldType(storedLong);
|
final LegacyFieldType storedLong4 = new LegacyFieldType(storedLong);
|
||||||
storedLong4.setNumericPrecisionStep(4);
|
storedLong4.setNumericPrecisionStep(4);
|
||||||
|
|
||||||
final FieldType storedLong6 = new FieldType(storedLong);
|
final LegacyFieldType storedLong6 = new LegacyFieldType(storedLong);
|
||||||
storedLong6.setNumericPrecisionStep(6);
|
storedLong6.setNumericPrecisionStep(6);
|
||||||
|
|
||||||
final FieldType storedLong2 = new FieldType(storedLong);
|
final LegacyFieldType storedLong2 = new LegacyFieldType(storedLong);
|
||||||
storedLong2.setNumericPrecisionStep(2);
|
storedLong2.setNumericPrecisionStep(2);
|
||||||
|
|
||||||
final FieldType storedLongNone = new FieldType(storedLong);
|
final LegacyFieldType storedLongNone = new LegacyFieldType(storedLong);
|
||||||
storedLongNone.setNumericPrecisionStep(Integer.MAX_VALUE);
|
storedLongNone.setNumericPrecisionStep(Integer.MAX_VALUE);
|
||||||
|
|
||||||
final FieldType unstoredLong = LegacyLongField.TYPE_NOT_STORED;
|
final LegacyFieldType unstoredLong = LegacyLongField.TYPE_NOT_STORED;
|
||||||
|
|
||||||
final FieldType unstoredLong8 = new FieldType(unstoredLong);
|
final LegacyFieldType unstoredLong8 = new LegacyFieldType(unstoredLong);
|
||||||
unstoredLong8.setNumericPrecisionStep(8);
|
unstoredLong8.setNumericPrecisionStep(8);
|
||||||
|
|
||||||
final FieldType unstoredLong6 = new FieldType(unstoredLong);
|
final LegacyFieldType unstoredLong6 = new LegacyFieldType(unstoredLong);
|
||||||
unstoredLong6.setNumericPrecisionStep(6);
|
unstoredLong6.setNumericPrecisionStep(6);
|
||||||
|
|
||||||
final FieldType unstoredLong4 = new FieldType(unstoredLong);
|
final LegacyFieldType unstoredLong4 = new LegacyFieldType(unstoredLong);
|
||||||
unstoredLong4.setNumericPrecisionStep(4);
|
unstoredLong4.setNumericPrecisionStep(4);
|
||||||
|
|
||||||
final FieldType unstoredLong2 = new FieldType(unstoredLong);
|
final LegacyFieldType unstoredLong2 = new LegacyFieldType(unstoredLong);
|
||||||
unstoredLong2.setNumericPrecisionStep(2);
|
unstoredLong2.setNumericPrecisionStep(2);
|
||||||
|
|
||||||
LegacyLongField
|
LegacyLongField
|
||||||
|
@ -374,137 +372,6 @@ public class TestNumericRangeQuery64 extends LuceneTestCase {
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void testRandomTrieAndClassicRangeQuery(int precisionStep) throws Exception {
|
|
||||||
String field="field"+precisionStep;
|
|
||||||
int totalTermCountT=0,totalTermCountC=0,termCountT,termCountC;
|
|
||||||
int num = TestUtil.nextInt(random(), 10, 20);
|
|
||||||
for (int i = 0; i < num; i++) {
|
|
||||||
long lower=(long)(random().nextDouble()*noDocs*distance)+startOffset;
|
|
||||||
long upper=(long)(random().nextDouble()*noDocs*distance)+startOffset;
|
|
||||||
if (lower>upper) {
|
|
||||||
long a=lower; lower=upper; upper=a;
|
|
||||||
}
|
|
||||||
final BytesRef lowerBytes, upperBytes;
|
|
||||||
BytesRefBuilder b = new BytesRefBuilder();
|
|
||||||
LegacyNumericUtils.longToPrefixCoded(lower, 0, b);
|
|
||||||
lowerBytes = b.toBytesRef();
|
|
||||||
LegacyNumericUtils.longToPrefixCoded(upper, 0, b);
|
|
||||||
upperBytes = b.toBytesRef();
|
|
||||||
|
|
||||||
// test inclusive range
|
|
||||||
LegacyNumericRangeQuery<Long> tq= LegacyNumericRangeQuery.newLongRange(field, precisionStep, lower, upper, true, true);
|
|
||||||
TermRangeQuery cq=new TermRangeQuery(field, lowerBytes, upperBytes, true, true);
|
|
||||||
TopDocs tTopDocs = searcher.search(tq, 1);
|
|
||||||
TopDocs cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
// test exclusive range
|
|
||||||
tq= LegacyNumericRangeQuery.newLongRange(field, precisionStep, lower, upper, false, false);
|
|
||||||
cq=new TermRangeQuery(field, lowerBytes, upperBytes, false, false);
|
|
||||||
tTopDocs = searcher.search(tq, 1);
|
|
||||||
cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
// test left exclusive range
|
|
||||||
tq= LegacyNumericRangeQuery.newLongRange(field, precisionStep, lower, upper, false, true);
|
|
||||||
cq=new TermRangeQuery(field, lowerBytes, upperBytes, false, true);
|
|
||||||
tTopDocs = searcher.search(tq, 1);
|
|
||||||
cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
// test right exclusive range
|
|
||||||
tq= LegacyNumericRangeQuery.newLongRange(field, precisionStep, lower, upper, true, false);
|
|
||||||
cq=new TermRangeQuery(field, lowerBytes, upperBytes, true, false);
|
|
||||||
tTopDocs = searcher.search(tq, 1);
|
|
||||||
cTopDocs = searcher.search(cq, 1);
|
|
||||||
assertEquals("Returned count for LegacyNumericRangeQuery and TermRangeQuery must be equal", cTopDocs.totalHits, tTopDocs.totalHits );
|
|
||||||
totalTermCountT += termCountT = countTerms(tq);
|
|
||||||
totalTermCountC += termCountC = countTerms(cq);
|
|
||||||
checkTermCounts(precisionStep, termCountT, termCountC);
|
|
||||||
}
|
|
||||||
|
|
||||||
checkTermCounts(precisionStep, totalTermCountT, totalTermCountC);
|
|
||||||
if (VERBOSE && precisionStep != Integer.MAX_VALUE) {
|
|
||||||
System.out.println("Average number of terms during random search on '" + field + "':");
|
|
||||||
System.out.println(" Numeric query: " + (((double)totalTermCountT)/(num * 4)));
|
|
||||||
System.out.println(" Classical query: " + (((double)totalTermCountC)/(num * 4)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testEmptyEnums() throws Exception {
|
|
||||||
int count=3000;
|
|
||||||
long lower=(distance*3/2)+startOffset, upper=lower + count*distance + (distance/3);
|
|
||||||
// test empty enum
|
|
||||||
assert lower < upper;
|
|
||||||
assertTrue(0 < countTerms(LegacyNumericRangeQuery.newLongRange("field4", 4, lower, upper, true, true)));
|
|
||||||
assertEquals(0, countTerms(LegacyNumericRangeQuery.newLongRange("field4", 4, upper, lower, true, true)));
|
|
||||||
// test empty enum outside of bounds
|
|
||||||
lower = distance*noDocs+startOffset;
|
|
||||||
upper = 2L * lower;
|
|
||||||
assert lower < upper;
|
|
||||||
assertEquals(0, countTerms(LegacyNumericRangeQuery.newLongRange("field4", 4, lower, upper, true, true)));
|
|
||||||
}
|
|
||||||
|
|
||||||
private int countTerms(MultiTermQuery q) throws Exception {
|
|
||||||
final Terms terms = MultiFields.getTerms(reader, q.getField());
|
|
||||||
if (terms == null)
|
|
||||||
return 0;
|
|
||||||
final TermsEnum termEnum = q.getTermsEnum(terms);
|
|
||||||
assertNotNull(termEnum);
|
|
||||||
int count = 0;
|
|
||||||
BytesRef cur, last = null;
|
|
||||||
while ((cur = termEnum.next()) != null) {
|
|
||||||
count++;
|
|
||||||
if (last != null) {
|
|
||||||
assertTrue(last.compareTo(cur) < 0);
|
|
||||||
}
|
|
||||||
last = BytesRef.deepCopyOf(cur);
|
|
||||||
}
|
|
||||||
// LUCENE-3314: the results after next() already returned null are undefined,
|
|
||||||
// assertNull(termEnum.next());
|
|
||||||
return count;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void checkTermCounts(int precisionStep, int termCountT, int termCountC) {
|
|
||||||
if (precisionStep == Integer.MAX_VALUE) {
|
|
||||||
assertEquals("Number of terms should be equal for unlimited precStep", termCountC, termCountT);
|
|
||||||
} else {
|
|
||||||
assertTrue("Number of terms for NRQ should be <= compared to classical TRQ", termCountT <= termCountC);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_8bit() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(8);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_6bit() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(6);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_4bit() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(4);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_2bit() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(2);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRandomTrieAndClassicRangeQuery_NoTrie() throws Exception {
|
|
||||||
testRandomTrieAndClassicRangeQuery(Integer.MAX_VALUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void testRangeSplit(int precisionStep) throws Exception {
|
private void testRangeSplit(int precisionStep) throws Exception {
|
||||||
String field="ascfield"+precisionStep;
|
String field="ascfield"+precisionStep;
|
||||||
// 10 random tests
|
// 10 random tests
|
|
@ -14,15 +14,17 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.analysis;
|
package org.apache.lucene.legacy;
|
||||||
|
|
||||||
|
|
||||||
|
import org.apache.lucene.util.AttributeImpl;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.analysis.LegacyNumericTokenStream.LegacyNumericTermAttributeImpl;
|
|
||||||
import org.apache.lucene.analysis.tokenattributes.TermToBytesRefAttribute;
|
import org.apache.lucene.analysis.tokenattributes.TermToBytesRefAttribute;
|
||||||
import org.apache.lucene.analysis.tokenattributes.TestCharTermAttributeImpl;
|
|
||||||
import org.apache.lucene.analysis.tokenattributes.TypeAttribute;
|
import org.apache.lucene.analysis.tokenattributes.TypeAttribute;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericTokenStream;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericTokenStream.LegacyNumericTermAttributeImpl;
|
||||||
|
import org.apache.lucene.analysis.BaseTokenStreamTestCase;
|
||||||
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
|
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
|
||||||
import org.apache.lucene.analysis.tokenattributes.CharTermAttributeImpl;
|
import org.apache.lucene.analysis.tokenattributes.CharTermAttributeImpl;
|
||||||
|
|
||||||
|
@ -150,20 +152,37 @@ public class TestNumericTokenStream extends BaseTokenStreamTestCase {
|
||||||
public void testAttributeClone() throws Exception {
|
public void testAttributeClone() throws Exception {
|
||||||
LegacyNumericTermAttributeImpl att = new LegacyNumericTermAttributeImpl();
|
LegacyNumericTermAttributeImpl att = new LegacyNumericTermAttributeImpl();
|
||||||
att.init(lvalue, 64, 8, 0); // set some value, to make getBytesRef() work
|
att.init(lvalue, 64, 8, 0); // set some value, to make getBytesRef() work
|
||||||
LegacyNumericTermAttributeImpl copy = TestCharTermAttributeImpl.assertCloneIsEqual(att);
|
LegacyNumericTermAttributeImpl copy = assertCloneIsEqual(att);
|
||||||
assertNotSame(att.getBytesRef(), copy.getBytesRef());
|
assertNotSame(att.getBytesRef(), copy.getBytesRef());
|
||||||
LegacyNumericTermAttributeImpl copy2 = TestCharTermAttributeImpl.assertCopyIsEqual(att);
|
LegacyNumericTermAttributeImpl copy2 = assertCopyIsEqual(att);
|
||||||
assertNotSame(att.getBytesRef(), copy2.getBytesRef());
|
assertNotSame(att.getBytesRef(), copy2.getBytesRef());
|
||||||
|
|
||||||
// LUCENE-7027 test
|
// LUCENE-7027 test
|
||||||
att.init(lvalue, 64, 8, 64); // Exhausted TokenStream -> should return empty BytesRef
|
att.init(lvalue, 64, 8, 64); // Exhausted TokenStream -> should return empty BytesRef
|
||||||
assertEquals(new BytesRef(), att.getBytesRef());
|
assertEquals(new BytesRef(), att.getBytesRef());
|
||||||
copy = TestCharTermAttributeImpl.assertCloneIsEqual(att);
|
copy = assertCloneIsEqual(att);
|
||||||
assertEquals(new BytesRef(), copy.getBytesRef());
|
assertEquals(new BytesRef(), copy.getBytesRef());
|
||||||
assertNotSame(att.getBytesRef(), copy.getBytesRef());
|
assertNotSame(att.getBytesRef(), copy.getBytesRef());
|
||||||
copy2 = TestCharTermAttributeImpl.assertCopyIsEqual(att);
|
copy2 = assertCopyIsEqual(att);
|
||||||
assertEquals(new BytesRef(), copy2.getBytesRef());
|
assertEquals(new BytesRef(), copy2.getBytesRef());
|
||||||
assertNotSame(att.getBytesRef(), copy2.getBytesRef());
|
assertNotSame(att.getBytesRef(), copy2.getBytesRef());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static <T extends AttributeImpl> T assertCloneIsEqual(T att) {
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
T clone = (T) att.clone();
|
||||||
|
assertEquals("Clone must be equal", att, clone);
|
||||||
|
assertEquals("Clone's hashcode must be equal", att.hashCode(), clone.hashCode());
|
||||||
|
return clone;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T extends AttributeImpl> T assertCopyIsEqual(T att) throws Exception {
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
T copy = (T) att.getClass().newInstance();
|
||||||
|
att.copyTo(copy);
|
||||||
|
assertEquals("Copied instance must be equal", att, copy);
|
||||||
|
assertEquals("Copied instance's hashcode must be equal", att.hashCode(), copy.hashCode());
|
||||||
|
return copy;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -21,7 +21,6 @@ import java.io.IOException;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
|
|
||||||
import org.apache.lucene.analysis.Analyzer;
|
import org.apache.lucene.analysis.Analyzer;
|
||||||
import org.apache.lucene.analysis.LegacyNumericTokenStream;
|
|
||||||
import org.apache.lucene.analysis.TokenStream;
|
import org.apache.lucene.analysis.TokenStream;
|
||||||
import org.apache.lucene.analysis.tokenattributes.BytesTermAttribute;
|
import org.apache.lucene.analysis.tokenattributes.BytesTermAttribute;
|
||||||
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
|
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
|
||||||
|
@ -426,9 +425,6 @@ public class Field implements IndexableField {
|
||||||
if (type.indexOptions() == IndexOptions.NONE || !type.tokenized()) {
|
if (type.indexOptions() == IndexOptions.NONE || !type.tokenized()) {
|
||||||
throw new IllegalArgumentException("TokenStream fields must be indexed and tokenized");
|
throw new IllegalArgumentException("TokenStream fields must be indexed and tokenized");
|
||||||
}
|
}
|
||||||
if (type.numericType() != null) {
|
|
||||||
throw new IllegalArgumentException("cannot set private TokenStream on numeric fields");
|
|
||||||
}
|
|
||||||
this.tokenStream = tokenStream;
|
this.tokenStream = tokenStream;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -511,35 +507,6 @@ public class Field implements IndexableField {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
final FieldType.LegacyNumericType numericType = fieldType().numericType();
|
|
||||||
if (numericType != null) {
|
|
||||||
if (!(reuse instanceof LegacyNumericTokenStream && ((LegacyNumericTokenStream)reuse).getPrecisionStep() == type.numericPrecisionStep())) {
|
|
||||||
// lazy init the TokenStream as it is heavy to instantiate
|
|
||||||
// (attributes,...) if not needed (stored field loading)
|
|
||||||
reuse = new LegacyNumericTokenStream(type.numericPrecisionStep());
|
|
||||||
}
|
|
||||||
final LegacyNumericTokenStream nts = (LegacyNumericTokenStream) reuse;
|
|
||||||
// initialize value in TokenStream
|
|
||||||
final Number val = (Number) fieldsData;
|
|
||||||
switch (numericType) {
|
|
||||||
case INT:
|
|
||||||
nts.setIntValue(val.intValue());
|
|
||||||
break;
|
|
||||||
case LONG:
|
|
||||||
nts.setLongValue(val.longValue());
|
|
||||||
break;
|
|
||||||
case FLOAT:
|
|
||||||
nts.setFloatValue(val.floatValue());
|
|
||||||
break;
|
|
||||||
case DOUBLE:
|
|
||||||
nts.setDoubleValue(val.doubleValue());
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
throw new AssertionError("Should never get here");
|
|
||||||
}
|
|
||||||
return reuse;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!fieldType().tokenized()) {
|
if (!fieldType().tokenized()) {
|
||||||
if (stringValue() != null) {
|
if (stringValue() != null) {
|
||||||
if (!(reuse instanceof StringTokenStream)) {
|
if (!(reuse instanceof StringTokenStream)) {
|
||||||
|
|
|
@ -22,30 +22,12 @@ import org.apache.lucene.index.DocValuesType;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.index.IndexableFieldType;
|
import org.apache.lucene.index.IndexableFieldType;
|
||||||
import org.apache.lucene.index.PointValues;
|
import org.apache.lucene.index.PointValues;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Describes the properties of a field.
|
* Describes the properties of a field.
|
||||||
*/
|
*/
|
||||||
public class FieldType implements IndexableFieldType {
|
public class FieldType implements IndexableFieldType {
|
||||||
|
|
||||||
/** Data type of the numeric value
|
|
||||||
* @since 3.2
|
|
||||||
*
|
|
||||||
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public enum LegacyNumericType {
|
|
||||||
/** 32-bit integer numeric type */
|
|
||||||
INT,
|
|
||||||
/** 64-bit long numeric type */
|
|
||||||
LONG,
|
|
||||||
/** 32-bit float numeric type */
|
|
||||||
FLOAT,
|
|
||||||
/** 64-bit double numeric type */
|
|
||||||
DOUBLE
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean stored;
|
private boolean stored;
|
||||||
private boolean tokenized = true;
|
private boolean tokenized = true;
|
||||||
private boolean storeTermVectors;
|
private boolean storeTermVectors;
|
||||||
|
@ -54,9 +36,7 @@ public class FieldType implements IndexableFieldType {
|
||||||
private boolean storeTermVectorPayloads;
|
private boolean storeTermVectorPayloads;
|
||||||
private boolean omitNorms;
|
private boolean omitNorms;
|
||||||
private IndexOptions indexOptions = IndexOptions.NONE;
|
private IndexOptions indexOptions = IndexOptions.NONE;
|
||||||
private LegacyNumericType numericType;
|
|
||||||
private boolean frozen;
|
private boolean frozen;
|
||||||
private int numericPrecisionStep = LegacyNumericUtils.PRECISION_STEP_DEFAULT;
|
|
||||||
private DocValuesType docValuesType = DocValuesType.NONE;
|
private DocValuesType docValuesType = DocValuesType.NONE;
|
||||||
private int dimensionCount;
|
private int dimensionCount;
|
||||||
private int dimensionNumBytes;
|
private int dimensionNumBytes;
|
||||||
|
@ -73,8 +53,6 @@ public class FieldType implements IndexableFieldType {
|
||||||
this.storeTermVectorPayloads = ref.storeTermVectorPayloads();
|
this.storeTermVectorPayloads = ref.storeTermVectorPayloads();
|
||||||
this.omitNorms = ref.omitNorms();
|
this.omitNorms = ref.omitNorms();
|
||||||
this.indexOptions = ref.indexOptions();
|
this.indexOptions = ref.indexOptions();
|
||||||
this.numericType = ref.numericType();
|
|
||||||
this.numericPrecisionStep = ref.numericPrecisionStep();
|
|
||||||
this.docValuesType = ref.docValuesType();
|
this.docValuesType = ref.docValuesType();
|
||||||
this.dimensionCount = ref.dimensionCount;
|
this.dimensionCount = ref.dimensionCount;
|
||||||
this.dimensionNumBytes = ref.dimensionNumBytes;
|
this.dimensionNumBytes = ref.dimensionNumBytes;
|
||||||
|
@ -297,70 +275,6 @@ public class FieldType implements IndexableFieldType {
|
||||||
this.indexOptions = value;
|
this.indexOptions = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Specifies the field's numeric type.
|
|
||||||
* @param type numeric type, or null if the field has no numeric type.
|
|
||||||
* @throws IllegalStateException if this FieldType is frozen against
|
|
||||||
* future modifications.
|
|
||||||
* @see #numericType()
|
|
||||||
*
|
|
||||||
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public void setNumericType(LegacyNumericType type) {
|
|
||||||
checkIfFrozen();
|
|
||||||
numericType = type;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* LegacyNumericType: if non-null then the field's value will be indexed
|
|
||||||
* numerically so that {@link org.apache.lucene.search.LegacyNumericRangeQuery} can be used at
|
|
||||||
* search time.
|
|
||||||
* <p>
|
|
||||||
* The default is <code>null</code> (no numeric type)
|
|
||||||
* @see #setNumericType(org.apache.lucene.document.FieldType.LegacyNumericType)
|
|
||||||
*
|
|
||||||
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public LegacyNumericType numericType() {
|
|
||||||
return numericType;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the numeric precision step for the field.
|
|
||||||
* @param precisionStep numeric precision step for the field
|
|
||||||
* @throws IllegalArgumentException if precisionStep is less than 1.
|
|
||||||
* @throws IllegalStateException if this FieldType is frozen against
|
|
||||||
* future modifications.
|
|
||||||
* @see #numericPrecisionStep()
|
|
||||||
*
|
|
||||||
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public void setNumericPrecisionStep(int precisionStep) {
|
|
||||||
checkIfFrozen();
|
|
||||||
if (precisionStep < 1) {
|
|
||||||
throw new IllegalArgumentException("precisionStep must be >= 1 (got " + precisionStep + ")");
|
|
||||||
}
|
|
||||||
this.numericPrecisionStep = precisionStep;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Precision step for numeric field.
|
|
||||||
* <p>
|
|
||||||
* This has no effect if {@link #numericType()} returns null.
|
|
||||||
* <p>
|
|
||||||
* The default is {@link org.apache.lucene.util.LegacyNumericUtils#PRECISION_STEP_DEFAULT}
|
|
||||||
* @see #setNumericPrecisionStep(int)
|
|
||||||
*
|
|
||||||
* @deprecated Please switch to {@link org.apache.lucene.index.PointValues} instead
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public int numericPrecisionStep() {
|
|
||||||
return numericPrecisionStep;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enables points indexing.
|
* Enables points indexing.
|
||||||
*/
|
*/
|
||||||
|
@ -403,7 +317,7 @@ public class FieldType implements IndexableFieldType {
|
||||||
|
|
||||||
/** Prints a Field for human consumption. */
|
/** Prints a Field for human consumption. */
|
||||||
@Override
|
@Override
|
||||||
public final String toString() {
|
public String toString() {
|
||||||
StringBuilder result = new StringBuilder();
|
StringBuilder result = new StringBuilder();
|
||||||
if (stored()) {
|
if (stored()) {
|
||||||
result.append("stored");
|
result.append("stored");
|
||||||
|
@ -434,12 +348,6 @@ public class FieldType implements IndexableFieldType {
|
||||||
result.append(",indexOptions=");
|
result.append(",indexOptions=");
|
||||||
result.append(indexOptions);
|
result.append(indexOptions);
|
||||||
}
|
}
|
||||||
if (numericType != null) {
|
|
||||||
result.append(",numericType=");
|
|
||||||
result.append(numericType);
|
|
||||||
result.append(",numericPrecisionStep=");
|
|
||||||
result.append(numericPrecisionStep);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (dimensionCount != 0) {
|
if (dimensionCount != 0) {
|
||||||
if (result.length() > 0) {
|
if (result.length() > 0) {
|
||||||
|
@ -495,8 +403,6 @@ public class FieldType implements IndexableFieldType {
|
||||||
result = prime * result + dimensionNumBytes;
|
result = prime * result + dimensionNumBytes;
|
||||||
result = prime * result + ((docValuesType == null) ? 0 : docValuesType.hashCode());
|
result = prime * result + ((docValuesType == null) ? 0 : docValuesType.hashCode());
|
||||||
result = prime * result + indexOptions.hashCode();
|
result = prime * result + indexOptions.hashCode();
|
||||||
result = prime * result + numericPrecisionStep;
|
|
||||||
result = prime * result + ((numericType == null) ? 0 : numericType.hashCode());
|
|
||||||
result = prime * result + (omitNorms ? 1231 : 1237);
|
result = prime * result + (omitNorms ? 1231 : 1237);
|
||||||
result = prime * result + (storeTermVectorOffsets ? 1231 : 1237);
|
result = prime * result + (storeTermVectorOffsets ? 1231 : 1237);
|
||||||
result = prime * result + (storeTermVectorPayloads ? 1231 : 1237);
|
result = prime * result + (storeTermVectorPayloads ? 1231 : 1237);
|
||||||
|
@ -517,8 +423,6 @@ public class FieldType implements IndexableFieldType {
|
||||||
if (dimensionNumBytes != other.dimensionNumBytes) return false;
|
if (dimensionNumBytes != other.dimensionNumBytes) return false;
|
||||||
if (docValuesType != other.docValuesType) return false;
|
if (docValuesType != other.docValuesType) return false;
|
||||||
if (indexOptions != other.indexOptions) return false;
|
if (indexOptions != other.indexOptions) return false;
|
||||||
if (numericPrecisionStep != other.numericPrecisionStep) return false;
|
|
||||||
if (numericType != other.numericType) return false;
|
|
||||||
if (omitNorms != other.omitNorms) return false;
|
if (omitNorms != other.omitNorms) return false;
|
||||||
if (storeTermVectorOffsets != other.storeTermVectorOffsets) return false;
|
if (storeTermVectorOffsets != other.storeTermVectorOffsets) return false;
|
||||||
if (storeTermVectorPayloads != other.storeTermVectorPayloads) return false;
|
if (storeTermVectorPayloads != other.storeTermVectorPayloads) return false;
|
||||||
|
|
|
@ -79,29 +79,7 @@ public class TestField extends LuceneTestCase {
|
||||||
assertEquals("DoublePoint <foo:6.0,7.0>", field.toString());
|
assertEquals("DoublePoint <foo:6.0,7.0>", field.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testLegacyDoubleField() throws Exception {
|
|
||||||
Field fields[] = new Field[] {
|
|
||||||
new LegacyDoubleField("foo", 5d, Field.Store.NO),
|
|
||||||
new LegacyDoubleField("foo", 5d, Field.Store.YES)
|
|
||||||
};
|
|
||||||
|
|
||||||
for (Field field : fields) {
|
|
||||||
trySetBoost(field);
|
|
||||||
trySetByteValue(field);
|
|
||||||
trySetBytesValue(field);
|
|
||||||
trySetBytesRefValue(field);
|
|
||||||
field.setDoubleValue(6d); // ok
|
|
||||||
trySetIntValue(field);
|
|
||||||
trySetFloatValue(field);
|
|
||||||
trySetLongValue(field);
|
|
||||||
trySetReaderValue(field);
|
|
||||||
trySetShortValue(field);
|
|
||||||
trySetStringValue(field);
|
|
||||||
trySetTokenStreamValue(field);
|
|
||||||
|
|
||||||
assertEquals(6d, field.numericValue().doubleValue(), 0.0d);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testDoubleDocValuesField() throws Exception {
|
public void testDoubleDocValuesField() throws Exception {
|
||||||
DoubleDocValuesField field = new DoubleDocValuesField("foo", 5d);
|
DoubleDocValuesField field = new DoubleDocValuesField("foo", 5d);
|
||||||
|
@ -185,30 +163,6 @@ public class TestField extends LuceneTestCase {
|
||||||
assertEquals("FloatPoint <foo:6.0,7.0>", field.toString());
|
assertEquals("FloatPoint <foo:6.0,7.0>", field.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testLegacyFloatField() throws Exception {
|
|
||||||
Field fields[] = new Field[] {
|
|
||||||
new LegacyFloatField("foo", 5f, Field.Store.NO),
|
|
||||||
new LegacyFloatField("foo", 5f, Field.Store.YES)
|
|
||||||
};
|
|
||||||
|
|
||||||
for (Field field : fields) {
|
|
||||||
trySetBoost(field);
|
|
||||||
trySetByteValue(field);
|
|
||||||
trySetBytesValue(field);
|
|
||||||
trySetBytesRefValue(field);
|
|
||||||
trySetDoubleValue(field);
|
|
||||||
trySetIntValue(field);
|
|
||||||
field.setFloatValue(6f); // ok
|
|
||||||
trySetLongValue(field);
|
|
||||||
trySetReaderValue(field);
|
|
||||||
trySetShortValue(field);
|
|
||||||
trySetStringValue(field);
|
|
||||||
trySetTokenStreamValue(field);
|
|
||||||
|
|
||||||
assertEquals(6f, field.numericValue().floatValue(), 0.0f);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testIntPoint() throws Exception {
|
public void testIntPoint() throws Exception {
|
||||||
Field field = new IntPoint("foo", 5);
|
Field field = new IntPoint("foo", 5);
|
||||||
|
|
||||||
|
@ -253,30 +207,6 @@ public class TestField extends LuceneTestCase {
|
||||||
assertEquals("IntPoint <foo:6,7>", field.toString());
|
assertEquals("IntPoint <foo:6,7>", field.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testLegacyIntField() throws Exception {
|
|
||||||
Field fields[] = new Field[] {
|
|
||||||
new LegacyIntField("foo", 5, Field.Store.NO),
|
|
||||||
new LegacyIntField("foo", 5, Field.Store.YES)
|
|
||||||
};
|
|
||||||
|
|
||||||
for (Field field : fields) {
|
|
||||||
trySetBoost(field);
|
|
||||||
trySetByteValue(field);
|
|
||||||
trySetBytesValue(field);
|
|
||||||
trySetBytesRefValue(field);
|
|
||||||
trySetDoubleValue(field);
|
|
||||||
field.setIntValue(6); // ok
|
|
||||||
trySetFloatValue(field);
|
|
||||||
trySetLongValue(field);
|
|
||||||
trySetReaderValue(field);
|
|
||||||
trySetShortValue(field);
|
|
||||||
trySetStringValue(field);
|
|
||||||
trySetTokenStreamValue(field);
|
|
||||||
|
|
||||||
assertEquals(6, field.numericValue().intValue());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testNumericDocValuesField() throws Exception {
|
public void testNumericDocValuesField() throws Exception {
|
||||||
NumericDocValuesField field = new NumericDocValuesField("foo", 5L);
|
NumericDocValuesField field = new NumericDocValuesField("foo", 5L);
|
||||||
|
|
||||||
|
@ -340,30 +270,6 @@ public class TestField extends LuceneTestCase {
|
||||||
assertEquals("LongPoint <foo:6,7>", field.toString());
|
assertEquals("LongPoint <foo:6,7>", field.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testLegacyLongField() throws Exception {
|
|
||||||
Field fields[] = new Field[] {
|
|
||||||
new LegacyLongField("foo", 5L, Field.Store.NO),
|
|
||||||
new LegacyLongField("foo", 5L, Field.Store.YES)
|
|
||||||
};
|
|
||||||
|
|
||||||
for (Field field : fields) {
|
|
||||||
trySetBoost(field);
|
|
||||||
trySetByteValue(field);
|
|
||||||
trySetBytesValue(field);
|
|
||||||
trySetBytesRefValue(field);
|
|
||||||
trySetDoubleValue(field);
|
|
||||||
trySetIntValue(field);
|
|
||||||
trySetFloatValue(field);
|
|
||||||
field.setLongValue(6); // ok
|
|
||||||
trySetReaderValue(field);
|
|
||||||
trySetShortValue(field);
|
|
||||||
trySetStringValue(field);
|
|
||||||
trySetTokenStreamValue(field);
|
|
||||||
|
|
||||||
assertEquals(6L, field.numericValue().longValue());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testSortedBytesDocValuesField() throws Exception {
|
public void testSortedBytesDocValuesField() throws Exception {
|
||||||
SortedDocValuesField field = new SortedDocValuesField("foo", new BytesRef("bar"));
|
SortedDocValuesField field = new SortedDocValuesField("foo", new BytesRef("bar"));
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,6 @@ package org.apache.lucene.document;
|
||||||
|
|
||||||
|
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.index.DocValuesType;
|
import org.apache.lucene.index.DocValuesType;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.index.PointValues;
|
import org.apache.lucene.index.PointValues;
|
||||||
|
@ -58,14 +57,6 @@ public class TestFieldType extends LuceneTestCase {
|
||||||
ft7.setOmitNorms(true);
|
ft7.setOmitNorms(true);
|
||||||
assertFalse(ft7.equals(ft));
|
assertFalse(ft7.equals(ft));
|
||||||
|
|
||||||
FieldType ft8 = new FieldType();
|
|
||||||
ft8.setNumericType(LegacyNumericType.DOUBLE);
|
|
||||||
assertFalse(ft8.equals(ft));
|
|
||||||
|
|
||||||
FieldType ft9 = new FieldType();
|
|
||||||
ft9.setNumericPrecisionStep(3);
|
|
||||||
assertFalse(ft9.equals(ft));
|
|
||||||
|
|
||||||
FieldType ft10 = new FieldType();
|
FieldType ft10 = new FieldType();
|
||||||
ft10.setStoreTermVectors(true);
|
ft10.setStoreTermVectors(true);
|
||||||
assertFalse(ft10.equals(ft));
|
assertFalse(ft10.equals(ft));
|
||||||
|
|
|
@ -24,16 +24,12 @@ import java.util.Collections;
|
||||||
import org.apache.lucene.analysis.Analyzer;
|
import org.apache.lucene.analysis.Analyzer;
|
||||||
import org.apache.lucene.analysis.BaseTokenStreamTestCase;
|
import org.apache.lucene.analysis.BaseTokenStreamTestCase;
|
||||||
import org.apache.lucene.analysis.CannedTokenStream;
|
import org.apache.lucene.analysis.CannedTokenStream;
|
||||||
import org.apache.lucene.analysis.LegacyNumericTokenStream.LegacyNumericTermAttribute;
|
|
||||||
import org.apache.lucene.analysis.LegacyNumericTokenStream;
|
|
||||||
import org.apache.lucene.analysis.Token;
|
import org.apache.lucene.analysis.Token;
|
||||||
import org.apache.lucene.analysis.TokenStream;
|
import org.apache.lucene.analysis.TokenStream;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.StringField;
|
import org.apache.lucene.document.StringField;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
|
|
||||||
/** test tokenstream reuse by DefaultIndexingChain */
|
/** test tokenstream reuse by DefaultIndexingChain */
|
||||||
public class TestFieldReuse extends BaseTokenStreamTestCase {
|
public class TestFieldReuse extends BaseTokenStreamTestCase {
|
||||||
|
@ -61,7 +57,7 @@ public class TestFieldReuse extends BaseTokenStreamTestCase {
|
||||||
|
|
||||||
// pass a bogus stream and ensure it's still ok
|
// pass a bogus stream and ensure it's still ok
|
||||||
stringField = new StringField("foo", "beer", Field.Store.NO);
|
stringField = new StringField("foo", "beer", Field.Store.NO);
|
||||||
TokenStream bogus = new LegacyNumericTokenStream();
|
TokenStream bogus = new CannedTokenStream();
|
||||||
ts = stringField.tokenStream(null, bogus);
|
ts = stringField.tokenStream(null, bogus);
|
||||||
assertNotSame(ts, bogus);
|
assertNotSame(ts, bogus);
|
||||||
assertTokenStreamContents(ts,
|
assertTokenStreamContents(ts,
|
||||||
|
@ -71,37 +67,6 @@ public class TestFieldReuse extends BaseTokenStreamTestCase {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testNumericReuse() throws IOException {
|
|
||||||
LegacyIntField legacyIntField = new LegacyIntField("foo", 5, Field.Store.NO);
|
|
||||||
|
|
||||||
// passing null
|
|
||||||
TokenStream ts = legacyIntField.tokenStream(null, null);
|
|
||||||
assertTrue(ts instanceof LegacyNumericTokenStream);
|
|
||||||
assertEquals(LegacyNumericUtils.PRECISION_STEP_DEFAULT_32, ((LegacyNumericTokenStream)ts).getPrecisionStep());
|
|
||||||
assertNumericContents(5, ts);
|
|
||||||
|
|
||||||
// now reuse previous stream
|
|
||||||
legacyIntField = new LegacyIntField("foo", 20, Field.Store.NO);
|
|
||||||
TokenStream ts2 = legacyIntField.tokenStream(null, ts);
|
|
||||||
assertSame(ts, ts2);
|
|
||||||
assertNumericContents(20, ts);
|
|
||||||
|
|
||||||
// pass a bogus stream and ensure it's still ok
|
|
||||||
legacyIntField = new LegacyIntField("foo", 2343, Field.Store.NO);
|
|
||||||
TokenStream bogus = new CannedTokenStream(new Token("bogus", 0, 5));
|
|
||||||
ts = legacyIntField.tokenStream(null, bogus);
|
|
||||||
assertNotSame(bogus, ts);
|
|
||||||
assertNumericContents(2343, ts);
|
|
||||||
|
|
||||||
// pass another bogus stream (numeric, but different precision step!)
|
|
||||||
legacyIntField = new LegacyIntField("foo", 42, Field.Store.NO);
|
|
||||||
assert 3 != LegacyNumericUtils.PRECISION_STEP_DEFAULT;
|
|
||||||
bogus = new LegacyNumericTokenStream(3);
|
|
||||||
ts = legacyIntField.tokenStream(null, bogus);
|
|
||||||
assertNotSame(bogus, ts);
|
|
||||||
assertNumericContents(42, ts);
|
|
||||||
}
|
|
||||||
|
|
||||||
static class MyField implements IndexableField {
|
static class MyField implements IndexableField {
|
||||||
TokenStream lastSeen;
|
TokenStream lastSeen;
|
||||||
TokenStream lastReturned;
|
TokenStream lastReturned;
|
||||||
|
@ -163,20 +128,4 @@ public class TestFieldReuse extends BaseTokenStreamTestCase {
|
||||||
iw.close();
|
iw.close();
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertNumericContents(int value, TokenStream ts) throws IOException {
|
|
||||||
assertTrue(ts instanceof LegacyNumericTokenStream);
|
|
||||||
LegacyNumericTermAttribute numericAtt = ts.getAttribute(LegacyNumericTermAttribute.class);
|
|
||||||
ts.reset();
|
|
||||||
boolean seen = false;
|
|
||||||
while (ts.incrementToken()) {
|
|
||||||
if (numericAtt.getShift() == 0) {
|
|
||||||
assertEquals(value, numericAtt.getRawValue());
|
|
||||||
seen = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ts.end();
|
|
||||||
ts.close();
|
|
||||||
assertTrue(seen);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,17 +18,11 @@ package org.apache.lucene.index;
|
||||||
|
|
||||||
import org.apache.lucene.analysis.CannedBinaryTokenStream;
|
import org.apache.lucene.analysis.CannedBinaryTokenStream;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.TextField;
|
import org.apache.lucene.document.TextField;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.NumericUtils;
|
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
|
|
||||||
public class TestTerms extends LuceneTestCase {
|
public class TestTerms extends LuceneTestCase {
|
||||||
|
@ -88,132 +82,4 @@ public class TestTerms extends LuceneTestCase {
|
||||||
w.close();
|
w.close();
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testEmptyIntFieldMinMax() throws Exception {
|
|
||||||
assertNull(LegacyNumericUtils.getMinInt(EMPTY_TERMS));
|
|
||||||
assertNull(LegacyNumericUtils.getMaxInt(EMPTY_TERMS));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testIntFieldMinMax() throws Exception {
|
|
||||||
Directory dir = newDirectory();
|
|
||||||
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
|
||||||
int numDocs = atLeast(100);
|
|
||||||
int minValue = Integer.MAX_VALUE;
|
|
||||||
int maxValue = Integer.MIN_VALUE;
|
|
||||||
for(int i=0;i<numDocs;i++ ){
|
|
||||||
Document doc = new Document();
|
|
||||||
int num = random().nextInt();
|
|
||||||
minValue = Math.min(num, minValue);
|
|
||||||
maxValue = Math.max(num, maxValue);
|
|
||||||
doc.add(new LegacyIntField("field", num, Field.Store.NO));
|
|
||||||
w.addDocument(doc);
|
|
||||||
}
|
|
||||||
|
|
||||||
IndexReader r = w.getReader();
|
|
||||||
Terms terms = MultiFields.getTerms(r, "field");
|
|
||||||
assertEquals(new Integer(minValue), LegacyNumericUtils.getMinInt(terms));
|
|
||||||
assertEquals(new Integer(maxValue), LegacyNumericUtils.getMaxInt(terms));
|
|
||||||
|
|
||||||
r.close();
|
|
||||||
w.close();
|
|
||||||
dir.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testEmptyLongFieldMinMax() throws Exception {
|
|
||||||
assertNull(LegacyNumericUtils.getMinLong(EMPTY_TERMS));
|
|
||||||
assertNull(LegacyNumericUtils.getMaxLong(EMPTY_TERMS));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testLongFieldMinMax() throws Exception {
|
|
||||||
Directory dir = newDirectory();
|
|
||||||
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
|
||||||
int numDocs = atLeast(100);
|
|
||||||
long minValue = Long.MAX_VALUE;
|
|
||||||
long maxValue = Long.MIN_VALUE;
|
|
||||||
for(int i=0;i<numDocs;i++ ){
|
|
||||||
Document doc = new Document();
|
|
||||||
long num = random().nextLong();
|
|
||||||
minValue = Math.min(num, minValue);
|
|
||||||
maxValue = Math.max(num, maxValue);
|
|
||||||
doc.add(new LegacyLongField("field", num, Field.Store.NO));
|
|
||||||
w.addDocument(doc);
|
|
||||||
}
|
|
||||||
|
|
||||||
IndexReader r = w.getReader();
|
|
||||||
|
|
||||||
Terms terms = MultiFields.getTerms(r, "field");
|
|
||||||
assertEquals(new Long(minValue), LegacyNumericUtils.getMinLong(terms));
|
|
||||||
assertEquals(new Long(maxValue), LegacyNumericUtils.getMaxLong(terms));
|
|
||||||
|
|
||||||
r.close();
|
|
||||||
w.close();
|
|
||||||
dir.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testFloatFieldMinMax() throws Exception {
|
|
||||||
Directory dir = newDirectory();
|
|
||||||
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
|
||||||
int numDocs = atLeast(100);
|
|
||||||
float minValue = Float.POSITIVE_INFINITY;
|
|
||||||
float maxValue = Float.NEGATIVE_INFINITY;
|
|
||||||
for(int i=0;i<numDocs;i++ ){
|
|
||||||
Document doc = new Document();
|
|
||||||
float num = random().nextFloat();
|
|
||||||
minValue = Math.min(num, minValue);
|
|
||||||
maxValue = Math.max(num, maxValue);
|
|
||||||
doc.add(new LegacyFloatField("field", num, Field.Store.NO));
|
|
||||||
w.addDocument(doc);
|
|
||||||
}
|
|
||||||
|
|
||||||
IndexReader r = w.getReader();
|
|
||||||
Terms terms = MultiFields.getTerms(r, "field");
|
|
||||||
assertEquals(minValue, NumericUtils.sortableIntToFloat(LegacyNumericUtils.getMinInt(terms)), 0.0f);
|
|
||||||
assertEquals(maxValue, NumericUtils.sortableIntToFloat(LegacyNumericUtils.getMaxInt(terms)), 0.0f);
|
|
||||||
|
|
||||||
r.close();
|
|
||||||
w.close();
|
|
||||||
dir.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testDoubleFieldMinMax() throws Exception {
|
|
||||||
Directory dir = newDirectory();
|
|
||||||
RandomIndexWriter w = new RandomIndexWriter(random(), dir);
|
|
||||||
int numDocs = atLeast(100);
|
|
||||||
double minValue = Double.POSITIVE_INFINITY;
|
|
||||||
double maxValue = Double.NEGATIVE_INFINITY;
|
|
||||||
for(int i=0;i<numDocs;i++ ){
|
|
||||||
Document doc = new Document();
|
|
||||||
double num = random().nextDouble();
|
|
||||||
minValue = Math.min(num, minValue);
|
|
||||||
maxValue = Math.max(num, maxValue);
|
|
||||||
doc.add(new LegacyDoubleField("field", num, Field.Store.NO));
|
|
||||||
w.addDocument(doc);
|
|
||||||
}
|
|
||||||
|
|
||||||
IndexReader r = w.getReader();
|
|
||||||
|
|
||||||
Terms terms = MultiFields.getTerms(r, "field");
|
|
||||||
|
|
||||||
assertEquals(minValue, NumericUtils.sortableLongToDouble(LegacyNumericUtils.getMinLong(terms)), 0.0);
|
|
||||||
assertEquals(maxValue, NumericUtils.sortableLongToDouble(LegacyNumericUtils.getMaxLong(terms)), 0.0);
|
|
||||||
|
|
||||||
r.close();
|
|
||||||
w.close();
|
|
||||||
dir.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A complete empty Terms instance that has no terms in it and supports no optional statistics
|
|
||||||
*/
|
|
||||||
private static Terms EMPTY_TERMS = new Terms() {
|
|
||||||
public TermsEnum iterator() { return TermsEnum.EMPTY; }
|
|
||||||
public long size() { return -1; }
|
|
||||||
public long getSumTotalTermFreq() { return -1; }
|
|
||||||
public long getSumDocFreq() { return -1; }
|
|
||||||
public int getDocCount() { return -1; }
|
|
||||||
public boolean hasFreqs() { return false; }
|
|
||||||
public boolean hasOffsets() { return false; }
|
|
||||||
public boolean hasPositions() { return false; }
|
|
||||||
public boolean hasPayloads() { return false; }
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
|
|
||||||
<path id="classpath">
|
<path id="classpath">
|
||||||
<pathelement path="${grouping.jar}"/>
|
<pathelement path="${grouping.jar}"/>
|
||||||
|
<pathelement path="${backward-codecs.jar}"/>
|
||||||
<path refid="base.classpath"/>
|
<path refid="base.classpath"/>
|
||||||
</path>
|
</path>
|
||||||
|
|
||||||
|
@ -34,13 +35,14 @@
|
||||||
<pathelement location="${build.dir}/classes/java"/>
|
<pathelement location="${build.dir}/classes/java"/>
|
||||||
</path>
|
</path>
|
||||||
|
|
||||||
<target name="init" depends="module-build.init,jar-grouping"/>
|
<target name="init" depends="module-build.init,jar-grouping,jar-backward-codecs"/>
|
||||||
|
|
||||||
<target name="javadocs" depends="javadocs-grouping,compile-core,check-javadocs-uptodate"
|
<target name="javadocs" depends="javadocs-grouping,javadocs-backward-codecs,compile-core,check-javadocs-uptodate"
|
||||||
unless="javadocs-uptodate-${name}">
|
unless="javadocs-uptodate-${name}">
|
||||||
<invoke-module-javadoc>
|
<invoke-module-javadoc>
|
||||||
<links>
|
<links>
|
||||||
<link href="../grouping"/>
|
<link href="../grouping"/>
|
||||||
|
<link href="../backward-codecs"/>
|
||||||
</links>
|
</links>
|
||||||
</invoke-module-javadoc>
|
</invoke-module-javadoc>
|
||||||
</target>
|
</target>
|
||||||
|
|
|
@ -19,8 +19,6 @@ package org.apache.lucene.search.join;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.function.LongConsumer;
|
import java.util.function.LongConsumer;
|
||||||
|
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.index.BinaryDocValues;
|
import org.apache.lucene.index.BinaryDocValues;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.LeafReader;
|
import org.apache.lucene.index.LeafReader;
|
||||||
|
@ -28,10 +26,11 @@ import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.NumericDocValues;
|
import org.apache.lucene.index.NumericDocValues;
|
||||||
import org.apache.lucene.index.SortedNumericDocValues;
|
import org.apache.lucene.index.SortedNumericDocValues;
|
||||||
import org.apache.lucene.index.SortedSetDocValues;
|
import org.apache.lucene.index.SortedSetDocValues;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.search.SimpleCollector;
|
import org.apache.lucene.search.SimpleCollector;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
|
|
||||||
abstract class DocValuesTermsCollector<DV> extends SimpleCollector {
|
abstract class DocValuesTermsCollector<DV> extends SimpleCollector {
|
||||||
|
|
||||||
|
@ -85,13 +84,13 @@ abstract class DocValuesTermsCollector<DV> extends SimpleCollector {
|
||||||
return (l) -> LegacyNumericUtils.longToPrefixCoded(l, 0, bytes);
|
return (l) -> LegacyNumericUtils.longToPrefixCoded(l, 0, bytes);
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("Unsupported "+type+
|
throw new IllegalArgumentException("Unsupported "+type+
|
||||||
". Only "+ LegacyNumericType.INT+" and "+ FieldType.LegacyNumericType.LONG+" are supported."
|
". Only "+ LegacyNumericType.INT+" and "+ LegacyNumericType.LONG+" are supported."
|
||||||
+ "Field "+fieldName );
|
+ "Field "+fieldName );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** this adapter is quite weird. ords are per doc index, don't use ords across different docs*/
|
/** this adapter is quite weird. ords are per doc index, don't use ords across different docs*/
|
||||||
static Function<SortedSetDocValues> sortedNumericAsSortedSetDocValues(String field, FieldType.LegacyNumericType numTyp) {
|
static Function<SortedSetDocValues> sortedNumericAsSortedSetDocValues(String field, LegacyNumericType numTyp) {
|
||||||
return (ctx) -> {
|
return (ctx) -> {
|
||||||
final SortedNumericDocValues numerics = DocValues.getSortedNumeric(ctx, field);
|
final SortedNumericDocValues numerics = DocValues.getSortedNumeric(ctx, field);
|
||||||
final BytesRefBuilder bytes = new BytesRefBuilder();
|
final BytesRefBuilder bytes = new BytesRefBuilder();
|
||||||
|
|
|
@ -26,7 +26,7 @@ import java.util.function.BiConsumer;
|
||||||
import java.util.function.LongFunction;
|
import java.util.function.LongFunction;
|
||||||
|
|
||||||
import org.apache.lucene.document.DoublePoint;
|
import org.apache.lucene.document.DoublePoint;
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.document.FloatPoint;
|
import org.apache.lucene.document.FloatPoint;
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LongPoint;
|
import org.apache.lucene.document.LongPoint;
|
||||||
|
@ -123,8 +123,8 @@ public final class JoinUtil {
|
||||||
* @param multipleValuesPerDocument Whether the from field has multiple terms per document
|
* @param multipleValuesPerDocument Whether the from field has multiple terms per document
|
||||||
* when true fromField might be {@link DocValuesType#SORTED_NUMERIC},
|
* when true fromField might be {@link DocValuesType#SORTED_NUMERIC},
|
||||||
* otherwise fromField should be {@link DocValuesType#NUMERIC}
|
* otherwise fromField should be {@link DocValuesType#NUMERIC}
|
||||||
* @param toField The to field to join to, should be {@link org.apache.lucene.document.LegacyIntField} or {@link org.apache.lucene.document.LegacyLongField}
|
* @param toField The to field to join to, should be {@link org.apache.lucene.legacy.LegacyIntField} or {@link org.apache.lucene.legacy.LegacyLongField}
|
||||||
* @param numericType either {@link org.apache.lucene.document.FieldType.LegacyNumericType#INT} or {@link org.apache.lucene.document.FieldType.LegacyNumericType#LONG}, it should correspond to fromField and toField types
|
* @param numericType either {@link LegacyNumericType#INT} or {@link LegacyNumericType#LONG}, it should correspond to fromField and toField types
|
||||||
* @param fromQuery The query to match documents on the from side
|
* @param fromQuery The query to match documents on the from side
|
||||||
* @param fromSearcher The searcher that executed the specified fromQuery
|
* @param fromSearcher The searcher that executed the specified fromQuery
|
||||||
* @param scoreMode Instructs how scores from the fromQuery are mapped to the returned query
|
* @param scoreMode Instructs how scores from the fromQuery are mapped to the returned query
|
||||||
|
|
|
@ -27,6 +27,7 @@ import org.apache.lucene.index.PostingsEnum;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.index.TermsEnum;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.search.DocIdSetIterator;
|
import org.apache.lucene.search.DocIdSetIterator;
|
||||||
import org.apache.lucene.search.Explanation;
|
import org.apache.lucene.search.Explanation;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
|
@ -37,7 +38,6 @@ import org.apache.lucene.util.BitSetIterator;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.BytesRefHash;
|
import org.apache.lucene.util.BytesRefHash;
|
||||||
import org.apache.lucene.util.FixedBitSet;
|
import org.apache.lucene.util.FixedBitSet;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
|
|
||||||
class TermsIncludingScoreQuery extends Query {
|
class TermsIncludingScoreQuery extends Query {
|
||||||
|
|
||||||
|
|
|
@ -37,12 +37,9 @@ import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.DoubleDocValuesField;
|
import org.apache.lucene.document.DoubleDocValuesField;
|
||||||
import org.apache.lucene.document.DoublePoint;
|
import org.apache.lucene.document.DoublePoint;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.document.FloatDocValuesField;
|
import org.apache.lucene.document.FloatDocValuesField;
|
||||||
import org.apache.lucene.document.FloatPoint;
|
import org.apache.lucene.document.FloatPoint;
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.LongPoint;
|
import org.apache.lucene.document.LongPoint;
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.SortedDocValuesField;
|
import org.apache.lucene.document.SortedDocValuesField;
|
||||||
|
@ -59,6 +56,9 @@ import org.apache.lucene.index.LeafReader;
|
||||||
import org.apache.lucene.index.LeafReaderContext;
|
import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.MultiDocValues;
|
import org.apache.lucene.index.MultiDocValues;
|
||||||
import org.apache.lucene.index.MultiDocValues.OrdinalMap;
|
import org.apache.lucene.index.MultiDocValues.OrdinalMap;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.index.MultiFields;
|
import org.apache.lucene.index.MultiFields;
|
||||||
import org.apache.lucene.index.NoMergePolicy;
|
import org.apache.lucene.index.NoMergePolicy;
|
||||||
import org.apache.lucene.index.NumericDocValues;
|
import org.apache.lucene.index.NumericDocValues;
|
||||||
|
|
|
@ -45,7 +45,6 @@ import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.document.FieldType;
|
||||||
import org.apache.lucene.document.FloatPoint;
|
import org.apache.lucene.document.FloatPoint;
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.LongPoint;
|
import org.apache.lucene.document.LongPoint;
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.SortedDocValuesField;
|
import org.apache.lucene.document.SortedDocValuesField;
|
||||||
|
@ -457,9 +456,6 @@ public class TestMemoryIndexAgainstRAMDir extends BaseTokenStreamTestCase {
|
||||||
Document doc = new Document();
|
Document doc = new Document();
|
||||||
long randomLong = random().nextLong();
|
long randomLong = random().nextLong();
|
||||||
doc.add(new NumericDocValuesField("numeric", randomLong));
|
doc.add(new NumericDocValuesField("numeric", randomLong));
|
||||||
if (random().nextBoolean()) {
|
|
||||||
doc.add(new LegacyLongField("numeric", randomLong, Field.Store.NO));
|
|
||||||
}
|
|
||||||
int numValues = atLeast(5);
|
int numValues = atLeast(5);
|
||||||
for (int i = 0; i < numValues; i++) {
|
for (int i = 0; i < numValues; i++) {
|
||||||
randomLong = random().nextLong();
|
randomLong = random().nextLong();
|
||||||
|
@ -468,9 +464,6 @@ public class TestMemoryIndexAgainstRAMDir extends BaseTokenStreamTestCase {
|
||||||
// randomly duplicate field/value
|
// randomly duplicate field/value
|
||||||
doc.add(new SortedNumericDocValuesField("sorted_numeric", randomLong));
|
doc.add(new SortedNumericDocValuesField("sorted_numeric", randomLong));
|
||||||
}
|
}
|
||||||
if (random().nextBoolean()) {
|
|
||||||
doc.add(new LegacyLongField("numeric", randomLong, Field.Store.NO));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
BytesRef randomTerm = new BytesRef(randomTerm());
|
BytesRef randomTerm = new BytesRef(randomTerm());
|
||||||
doc.add(new BinaryDocValuesField("binary", randomTerm));
|
doc.add(new BinaryDocValuesField("binary", randomTerm));
|
||||||
|
|
|
@ -21,11 +21,10 @@ import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field.Store;
|
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FloatDocValuesField;
|
import org.apache.lucene.document.FloatDocValuesField;
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.SortedDocValuesField;
|
import org.apache.lucene.document.SortedDocValuesField;
|
||||||
|
import org.apache.lucene.document.StoredField;
|
||||||
import org.apache.lucene.index.BinaryDocValues;
|
import org.apache.lucene.index.BinaryDocValues;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.FieldInvertState;
|
import org.apache.lucene.index.FieldInvertState;
|
||||||
|
@ -331,7 +330,7 @@ public class TestDiversifiedTopDocsCollector extends LuceneTestCase {
|
||||||
new BytesRef(""));
|
new BytesRef(""));
|
||||||
Field weeksAtNumberOneField = new FloatDocValuesField("weeksAtNumberOne",
|
Field weeksAtNumberOneField = new FloatDocValuesField("weeksAtNumberOne",
|
||||||
0.0F);
|
0.0F);
|
||||||
Field weeksStoredField = new LegacyFloatField("weeks", 0.0F, Store.YES);
|
Field weeksStoredField = new StoredField("weeks", 0.0F);
|
||||||
Field idField = newStringField("id", "", Field.Store.YES);
|
Field idField = newStringField("id", "", Field.Store.YES);
|
||||||
Field songField = newTextField("song", "", Field.Store.NO);
|
Field songField = newTextField("song", "", Field.Store.NO);
|
||||||
Field storedArtistField = newTextField("artistName", "", Field.Store.NO);
|
Field storedArtistField = newTextField("artistName", "", Field.Store.NO);
|
||||||
|
|
|
@ -25,15 +25,17 @@
|
||||||
<path id="classpath">
|
<path id="classpath">
|
||||||
<pathelement path="${queries.jar}"/>
|
<pathelement path="${queries.jar}"/>
|
||||||
<pathelement path="${sandbox.jar}"/>
|
<pathelement path="${sandbox.jar}"/>
|
||||||
|
<pathelement path="${backward-codecs.jar}"/>
|
||||||
<path refid="base.classpath"/>
|
<path refid="base.classpath"/>
|
||||||
</path>
|
</path>
|
||||||
|
|
||||||
<target name="compile-core" depends="jar-queries,jar-sandbox,common.compile-core"/>
|
<target name="compile-core" depends="jar-backward-codecs,jar-queries,jar-sandbox,common.compile-core"/>
|
||||||
|
|
||||||
<target name="javadocs" depends="javadocs-queries,javadocs-sandbox,compile-core,check-javadocs-uptodate"
|
<target name="javadocs" depends="javadocs-backward-codecs,javadocs-queries,javadocs-sandbox,compile-core,check-javadocs-uptodate"
|
||||||
unless="javadocs-uptodate-${name}">
|
unless="javadocs-uptodate-${name}">
|
||||||
<invoke-module-javadoc>
|
<invoke-module-javadoc>
|
||||||
<links>
|
<links>
|
||||||
|
<link href="../backward-codecs"/>
|
||||||
<link href="../queries"/>
|
<link href="../queries"/>
|
||||||
<link href="../sandbox"/>
|
<link href="../sandbox"/>
|
||||||
</links>
|
</links>
|
||||||
|
|
|
@ -16,7 +16,8 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.queryparser.flexible.standard.builders;
|
package org.apache.lucene.queryparser.flexible.standard.builders;
|
||||||
|
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.queryparser.flexible.core.QueryNodeException;
|
import org.apache.lucene.queryparser.flexible.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryparser.flexible.core.messages.QueryParserMessages;
|
import org.apache.lucene.queryparser.flexible.core.messages.QueryParserMessages;
|
||||||
import org.apache.lucene.queryparser.flexible.core.nodes.QueryNode;
|
import org.apache.lucene.queryparser.flexible.core.nodes.QueryNode;
|
||||||
|
@ -25,12 +26,11 @@ import org.apache.lucene.queryparser.flexible.messages.MessageImpl;
|
||||||
import org.apache.lucene.queryparser.flexible.standard.config.LegacyNumericConfig;
|
import org.apache.lucene.queryparser.flexible.standard.config.LegacyNumericConfig;
|
||||||
import org.apache.lucene.queryparser.flexible.standard.nodes.LegacyNumericQueryNode;
|
import org.apache.lucene.queryparser.flexible.standard.nodes.LegacyNumericQueryNode;
|
||||||
import org.apache.lucene.queryparser.flexible.standard.nodes.LegacyNumericRangeQueryNode;
|
import org.apache.lucene.queryparser.flexible.standard.nodes.LegacyNumericRangeQueryNode;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builds {@link org.apache.lucene.search.LegacyNumericRangeQuery}s out of {@link LegacyNumericRangeQueryNode}s.
|
* Builds {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}s out of {@link LegacyNumericRangeQueryNode}s.
|
||||||
*
|
*
|
||||||
* @see org.apache.lucene.search.LegacyNumericRangeQuery
|
* @see org.apache.lucene.legacy.LegacyNumericRangeQuery
|
||||||
* @see LegacyNumericRangeQueryNode
|
* @see LegacyNumericRangeQueryNode
|
||||||
* @deprecated Index with points and use {@link PointRangeQueryNodeBuilder} instead.
|
* @deprecated Index with points and use {@link PointRangeQueryNodeBuilder} instead.
|
||||||
*/
|
*/
|
||||||
|
@ -56,7 +56,7 @@ public class LegacyNumericRangeQueryNodeBuilder implements StandardQueryBuilder
|
||||||
Number upperNumber = upperNumericNode.getValue();
|
Number upperNumber = upperNumericNode.getValue();
|
||||||
|
|
||||||
LegacyNumericConfig numericConfig = numericRangeNode.getNumericConfig();
|
LegacyNumericConfig numericConfig = numericRangeNode.getNumericConfig();
|
||||||
FieldType.LegacyNumericType numberType = numericConfig.getType();
|
LegacyNumericType numberType = numericConfig.getType();
|
||||||
String field = StringUtils.toString(numericRangeNode.getField());
|
String field = StringUtils.toString(numericRangeNode.getField());
|
||||||
boolean minInclusive = numericRangeNode.isLowerInclusive();
|
boolean minInclusive = numericRangeNode.isLowerInclusive();
|
||||||
boolean maxInclusive = numericRangeNode.isUpperInclusive();
|
boolean maxInclusive = numericRangeNode.isUpperInclusive();
|
||||||
|
|
|
@ -19,14 +19,13 @@ package org.apache.lucene.queryparser.flexible.standard.config;
|
||||||
import java.text.NumberFormat;
|
import java.text.NumberFormat;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class holds the configuration used to parse numeric queries and create
|
* This class holds the configuration used to parse numeric queries and create
|
||||||
* {@link org.apache.lucene.search.LegacyNumericRangeQuery}s.
|
* {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}s.
|
||||||
*
|
*
|
||||||
* @see org.apache.lucene.search.LegacyNumericRangeQuery
|
* @see org.apache.lucene.legacy.LegacyNumericRangeQuery
|
||||||
* @see NumberFormat
|
* @see NumberFormat
|
||||||
* @deprecated Index with Points instead and use {@link PointsConfig}
|
* @deprecated Index with Points instead and use {@link PointsConfig}
|
||||||
*/
|
*/
|
||||||
|
@ -37,7 +36,7 @@ public class LegacyNumericConfig {
|
||||||
|
|
||||||
private NumberFormat format;
|
private NumberFormat format;
|
||||||
|
|
||||||
private FieldType.LegacyNumericType type;
|
private LegacyNumericType type;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a {@link LegacyNumericConfig} object.
|
* Constructs a {@link LegacyNumericConfig} object.
|
||||||
|
@ -52,7 +51,7 @@ public class LegacyNumericConfig {
|
||||||
*
|
*
|
||||||
* @see LegacyNumericConfig#setPrecisionStep(int)
|
* @see LegacyNumericConfig#setPrecisionStep(int)
|
||||||
* @see LegacyNumericConfig#setNumberFormat(NumberFormat)
|
* @see LegacyNumericConfig#setNumberFormat(NumberFormat)
|
||||||
* @see #setType(org.apache.lucene.document.FieldType.LegacyNumericType)
|
* @see #setType(LegacyNumericType)
|
||||||
*/
|
*/
|
||||||
public LegacyNumericConfig(int precisionStep, NumberFormat format,
|
public LegacyNumericConfig(int precisionStep, NumberFormat format,
|
||||||
LegacyNumericType type) {
|
LegacyNumericType type) {
|
||||||
|
@ -67,7 +66,7 @@ public class LegacyNumericConfig {
|
||||||
*
|
*
|
||||||
* @return the precision used to index the numeric values
|
* @return the precision used to index the numeric values
|
||||||
*
|
*
|
||||||
* @see org.apache.lucene.search.LegacyNumericRangeQuery#getPrecisionStep()
|
* @see org.apache.lucene.legacy.LegacyNumericRangeQuery#getPrecisionStep()
|
||||||
*/
|
*/
|
||||||
public int getPrecisionStep() {
|
public int getPrecisionStep() {
|
||||||
return precisionStep;
|
return precisionStep;
|
||||||
|
@ -79,7 +78,7 @@ public class LegacyNumericConfig {
|
||||||
* @param precisionStep
|
* @param precisionStep
|
||||||
* the precision used to index the numeric values
|
* the precision used to index the numeric values
|
||||||
*
|
*
|
||||||
* @see org.apache.lucene.search.LegacyNumericRangeQuery#getPrecisionStep()
|
* @see org.apache.lucene.legacy.LegacyNumericRangeQuery#getPrecisionStep()
|
||||||
*/
|
*/
|
||||||
public void setPrecisionStep(int precisionStep) {
|
public void setPrecisionStep(int precisionStep) {
|
||||||
this.precisionStep = precisionStep;
|
this.precisionStep = precisionStep;
|
||||||
|
|
|
@ -16,8 +16,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.queryparser.flexible.standard.nodes;
|
package org.apache.lucene.queryparser.flexible.standard.nodes;
|
||||||
|
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.queryparser.flexible.core.QueryNodeException;
|
import org.apache.lucene.queryparser.flexible.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryparser.flexible.core.messages.QueryParserMessages;
|
import org.apache.lucene.queryparser.flexible.core.messages.QueryParserMessages;
|
||||||
import org.apache.lucene.queryparser.flexible.messages.MessageImpl;
|
import org.apache.lucene.queryparser.flexible.messages.MessageImpl;
|
||||||
|
@ -57,13 +56,13 @@ public class LegacyNumericRangeQueryNode extends
|
||||||
private static LegacyNumericType getNumericDataType(Number number) throws QueryNodeException {
|
private static LegacyNumericType getNumericDataType(Number number) throws QueryNodeException {
|
||||||
|
|
||||||
if (number instanceof Long) {
|
if (number instanceof Long) {
|
||||||
return FieldType.LegacyNumericType.LONG;
|
return LegacyNumericType.LONG;
|
||||||
} else if (number instanceof Integer) {
|
} else if (number instanceof Integer) {
|
||||||
return FieldType.LegacyNumericType.INT;
|
return LegacyNumericType.INT;
|
||||||
} else if (number instanceof Double) {
|
} else if (number instanceof Double) {
|
||||||
return LegacyNumericType.DOUBLE;
|
return LegacyNumericType.DOUBLE;
|
||||||
} else if (number instanceof Float) {
|
} else if (number instanceof Float) {
|
||||||
return FieldType.LegacyNumericType.FLOAT;
|
return LegacyNumericType.FLOAT;
|
||||||
} else {
|
} else {
|
||||||
throw new QueryNodeException(
|
throw new QueryNodeException(
|
||||||
new MessageImpl(
|
new MessageImpl(
|
||||||
|
|
|
@ -16,19 +16,19 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.queryparser.xml.builders;
|
package org.apache.lucene.queryparser.xml.builders;
|
||||||
|
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queryparser.xml.DOMUtils;
|
import org.apache.lucene.queryparser.xml.DOMUtils;
|
||||||
import org.apache.lucene.queryparser.xml.ParserException;
|
import org.apache.lucene.queryparser.xml.ParserException;
|
||||||
import org.apache.lucene.queryparser.xml.QueryBuilder;
|
import org.apache.lucene.queryparser.xml.QueryBuilder;
|
||||||
import org.w3c.dom.Element;
|
import org.w3c.dom.Element;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a {@link org.apache.lucene.search.LegacyNumericRangeQuery}. The table below specifies the required
|
* Creates a {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}. The table below specifies the required
|
||||||
* attributes and the defaults if optional attributes are omitted. For more
|
* attributes and the defaults if optional attributes are omitted. For more
|
||||||
* detail on what each of the attributes actually do, consult the documentation
|
* detail on what each of the attributes actually do, consult the documentation
|
||||||
* for {@link org.apache.lucene.search.LegacyNumericRangeQuery}:
|
* for {@link org.apache.lucene.legacy.LegacyNumericRangeQuery}:
|
||||||
* <table summary="supported attributes">
|
* <table summary="supported attributes">
|
||||||
* <tr>
|
* <tr>
|
||||||
* <th>Attribute name</th>
|
* <th>Attribute name</th>
|
||||||
|
|
|
@ -32,15 +32,15 @@ import java.util.TimeZone;
|
||||||
import org.apache.lucene.analysis.Analyzer;
|
import org.apache.lucene.analysis.Analyzer;
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyFloatField;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.queryparser.flexible.core.QueryNodeException;
|
import org.apache.lucene.queryparser.flexible.core.QueryNodeException;
|
||||||
import org.apache.lucene.queryparser.flexible.core.parser.EscapeQuerySyntax;
|
import org.apache.lucene.queryparser.flexible.core.parser.EscapeQuerySyntax;
|
||||||
import org.apache.lucene.queryparser.flexible.standard.config.NumberDateFormat;
|
import org.apache.lucene.queryparser.flexible.standard.config.NumberDateFormat;
|
||||||
|
@ -179,7 +179,7 @@ public class TestLegacyNumericQueryParser extends LuceneTestCase {
|
||||||
;
|
;
|
||||||
|
|
||||||
randomNumberMap.put(LegacyNumericType.LONG.name(), randomLong);
|
randomNumberMap.put(LegacyNumericType.LONG.name(), randomLong);
|
||||||
randomNumberMap.put(FieldType.LegacyNumericType.INT.name(), randomInt);
|
randomNumberMap.put(LegacyNumericType.INT.name(), randomInt);
|
||||||
randomNumberMap.put(LegacyNumericType.FLOAT.name(), randomFloat);
|
randomNumberMap.put(LegacyNumericType.FLOAT.name(), randomFloat);
|
||||||
randomNumberMap.put(LegacyNumericType.DOUBLE.name(), randomDouble);
|
randomNumberMap.put(LegacyNumericType.DOUBLE.name(), randomDouble);
|
||||||
randomNumberMap.put(DATE_FIELD_NAME, randomDate);
|
randomNumberMap.put(DATE_FIELD_NAME, randomDate);
|
||||||
|
@ -201,7 +201,7 @@ public class TestLegacyNumericQueryParser extends LuceneTestCase {
|
||||||
numericConfigMap.put(type.name(), new LegacyNumericConfig(PRECISION_STEP,
|
numericConfigMap.put(type.name(), new LegacyNumericConfig(PRECISION_STEP,
|
||||||
NUMBER_FORMAT, type));
|
NUMBER_FORMAT, type));
|
||||||
|
|
||||||
FieldType ft = new FieldType(LegacyIntField.TYPE_NOT_STORED);
|
LegacyFieldType ft = new LegacyFieldType(LegacyIntField.TYPE_NOT_STORED);
|
||||||
ft.setNumericType(type);
|
ft.setNumericType(type);
|
||||||
ft.setStored(true);
|
ft.setStored(true);
|
||||||
ft.setNumericPrecisionStep(PRECISION_STEP);
|
ft.setNumericPrecisionStep(PRECISION_STEP);
|
||||||
|
@ -231,7 +231,7 @@ public class TestLegacyNumericQueryParser extends LuceneTestCase {
|
||||||
|
|
||||||
numericConfigMap.put(DATE_FIELD_NAME, new LegacyNumericConfig(PRECISION_STEP,
|
numericConfigMap.put(DATE_FIELD_NAME, new LegacyNumericConfig(PRECISION_STEP,
|
||||||
DATE_FORMAT, LegacyNumericType.LONG));
|
DATE_FORMAT, LegacyNumericType.LONG));
|
||||||
FieldType ft = new FieldType(LegacyLongField.TYPE_NOT_STORED);
|
LegacyFieldType ft = new LegacyFieldType(LegacyLongField.TYPE_NOT_STORED);
|
||||||
ft.setStored(true);
|
ft.setStored(true);
|
||||||
ft.setNumericPrecisionStep(PRECISION_STEP);
|
ft.setNumericPrecisionStep(PRECISION_STEP);
|
||||||
LegacyLongField dateField = new LegacyLongField(DATE_FIELD_NAME, 0l, ft);
|
LegacyLongField dateField = new LegacyLongField(DATE_FIELD_NAME, 0l, ft);
|
||||||
|
@ -268,10 +268,10 @@ public class TestLegacyNumericQueryParser extends LuceneTestCase {
|
||||||
|| DATE_FIELD_NAME.equals(fieldName)) {
|
|| DATE_FIELD_NAME.equals(fieldName)) {
|
||||||
number = -number.longValue();
|
number = -number.longValue();
|
||||||
|
|
||||||
} else if (FieldType.LegacyNumericType.DOUBLE.name().equals(fieldName)) {
|
} else if (LegacyNumericType.DOUBLE.name().equals(fieldName)) {
|
||||||
number = -number.doubleValue();
|
number = -number.doubleValue();
|
||||||
|
|
||||||
} else if (FieldType.LegacyNumericType.FLOAT.name().equals(fieldName)) {
|
} else if (LegacyNumericType.FLOAT.name().equals(fieldName)) {
|
||||||
number = -number.floatValue();
|
number = -number.floatValue();
|
||||||
|
|
||||||
} else if (LegacyNumericType.INT.name().equals(fieldName)) {
|
} else if (LegacyNumericType.INT.name().equals(fieldName)) {
|
||||||
|
@ -299,16 +299,16 @@ public class TestLegacyNumericQueryParser extends LuceneTestCase {
|
||||||
numericFieldMap.get(LegacyNumericType.DOUBLE.name()).setDoubleValue(
|
numericFieldMap.get(LegacyNumericType.DOUBLE.name()).setDoubleValue(
|
||||||
number.doubleValue());
|
number.doubleValue());
|
||||||
|
|
||||||
number = getNumberType(numberType, FieldType.LegacyNumericType.INT.name());
|
number = getNumberType(numberType, LegacyNumericType.INT.name());
|
||||||
numericFieldMap.get(FieldType.LegacyNumericType.INT.name()).setIntValue(
|
numericFieldMap.get(LegacyNumericType.INT.name()).setIntValue(
|
||||||
number.intValue());
|
number.intValue());
|
||||||
|
|
||||||
number = getNumberType(numberType, LegacyNumericType.LONG.name());
|
number = getNumberType(numberType, LegacyNumericType.LONG.name());
|
||||||
numericFieldMap.get(FieldType.LegacyNumericType.LONG.name()).setLongValue(
|
numericFieldMap.get(LegacyNumericType.LONG.name()).setLongValue(
|
||||||
number.longValue());
|
number.longValue());
|
||||||
|
|
||||||
number = getNumberType(numberType, FieldType.LegacyNumericType.FLOAT.name());
|
number = getNumberType(numberType, LegacyNumericType.FLOAT.name());
|
||||||
numericFieldMap.get(FieldType.LegacyNumericType.FLOAT.name()).setFloatValue(
|
numericFieldMap.get(LegacyNumericType.FLOAT.name()).setFloatValue(
|
||||||
number.floatValue());
|
number.floatValue());
|
||||||
|
|
||||||
number = getNumberType(numberType, DATE_FIELD_NAME);
|
number = getNumberType(numberType, DATE_FIELD_NAME);
|
||||||
|
@ -456,7 +456,7 @@ public class TestLegacyNumericQueryParser extends LuceneTestCase {
|
||||||
|
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
|
|
||||||
for (LegacyNumericType type : FieldType.LegacyNumericType.values()) {
|
for (LegacyNumericType type : LegacyNumericType.values()) {
|
||||||
String boundStr = numberToString(getNumberType(boundType, type.name()));
|
String boundStr = numberToString(getNumberType(boundType, type.name()));
|
||||||
|
|
||||||
sb.append("+").append(type.name()).append(operator).append('"').append(boundStr).append('"').append(' ');
|
sb.append("+").append(type.name()).append(operator).append('"').append(boundStr).append('"').append(' ');
|
||||||
|
|
|
@ -20,10 +20,10 @@ import org.apache.lucene.analysis.Analyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.index.DirectoryReader;
|
import org.apache.lucene.index.DirectoryReader;
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.IndexWriter;
|
import org.apache.lucene.index.IndexWriter;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
|
|
@ -16,9 +16,9 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.lucene.queryparser.xml.builders;
|
package org.apache.lucene.queryparser.xml.builders;
|
||||||
|
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
import org.apache.lucene.queryparser.xml.ParserException;
|
import org.apache.lucene.queryparser.xml.ParserException;
|
||||||
import org.w3c.dom.Document;
|
import org.w3c.dom.Document;
|
||||||
import org.xml.sax.SAXException;
|
import org.xml.sax.SAXException;
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
<path id="classpath">
|
<path id="classpath">
|
||||||
<path refid="base.classpath"/>
|
<path refid="base.classpath"/>
|
||||||
<path refid="spatialjar"/>
|
<path refid="spatialjar"/>
|
||||||
|
<pathelement path="${backward-codecs.jar}" />
|
||||||
<pathelement path="${queries.jar}" />
|
<pathelement path="${queries.jar}" />
|
||||||
<pathelement path="${misc.jar}" />
|
<pathelement path="${misc.jar}" />
|
||||||
<pathelement path="${spatial3d.jar}" />
|
<pathelement path="${spatial3d.jar}" />
|
||||||
|
@ -42,12 +43,13 @@
|
||||||
<pathelement path="src/test-files" />
|
<pathelement path="src/test-files" />
|
||||||
</path>
|
</path>
|
||||||
|
|
||||||
<target name="compile-core" depends="jar-queries,jar-misc,jar-spatial3d,common.compile-core" />
|
<target name="compile-core" depends="jar-backward-codecs,jar-queries,jar-misc,jar-spatial3d,common.compile-core" />
|
||||||
|
|
||||||
<target name="javadocs" depends="javadocs-queries,javadocs-misc,javadocs-spatial3d,compile-core,check-javadocs-uptodate"
|
<target name="javadocs" depends="javadocs-backward-codecs,javadocs-queries,javadocs-misc,javadocs-spatial3d,compile-core,check-javadocs-uptodate"
|
||||||
unless="javadocs-uptodate-${name}">
|
unless="javadocs-uptodate-${name}">
|
||||||
<invoke-module-javadoc>
|
<invoke-module-javadoc>
|
||||||
<links>
|
<links>
|
||||||
|
<link href="../backward-codecs"/>
|
||||||
<link href="../queries"/>
|
<link href="../queries"/>
|
||||||
<link href="../misc"/>
|
<link href="../misc"/>
|
||||||
<link href="../spatial3d"/>
|
<link href="../spatial3d"/>
|
||||||
|
|
|
@ -20,17 +20,20 @@ import org.apache.lucene.document.DoubleDocValuesField;
|
||||||
import org.apache.lucene.document.DoublePoint;
|
import org.apache.lucene.document.DoublePoint;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.document.FieldType;
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.StoredField;
|
import org.apache.lucene.document.StoredField;
|
||||||
import org.apache.lucene.document.StringField;
|
import org.apache.lucene.document.StringField;
|
||||||
import org.apache.lucene.index.DocValuesType;
|
import org.apache.lucene.index.DocValuesType;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.search.BooleanClause;
|
import org.apache.lucene.search.BooleanClause;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.search.ConstantScoreQuery;
|
import org.apache.lucene.search.ConstantScoreQuery;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.search.TermQuery;
|
import org.apache.lucene.search.TermQuery;
|
||||||
import org.apache.lucene.spatial.SpatialStrategy;
|
import org.apache.lucene.spatial.SpatialStrategy;
|
||||||
|
@ -39,7 +42,6 @@ import org.apache.lucene.spatial.query.SpatialOperation;
|
||||||
import org.apache.lucene.spatial.query.UnsupportedSpatialOperation;
|
import org.apache.lucene.spatial.query.UnsupportedSpatialOperation;
|
||||||
import org.apache.lucene.spatial.util.DistanceToShapeValueSource;
|
import org.apache.lucene.spatial.util.DistanceToShapeValueSource;
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.locationtech.spatial4j.context.SpatialContext;
|
import org.locationtech.spatial4j.context.SpatialContext;
|
||||||
import org.locationtech.spatial4j.shape.Point;
|
import org.locationtech.spatial4j.shape.Point;
|
||||||
|
@ -87,7 +89,7 @@ public class BBoxStrategy extends SpatialStrategy {
|
||||||
public static FieldType DEFAULT_FIELDTYPE;
|
public static FieldType DEFAULT_FIELDTYPE;
|
||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public static FieldType LEGACY_FIELDTYPE;
|
public static LegacyFieldType LEGACY_FIELDTYPE;
|
||||||
static {
|
static {
|
||||||
// Default: pointValues + docValues
|
// Default: pointValues + docValues
|
||||||
FieldType type = new FieldType();
|
FieldType type = new FieldType();
|
||||||
|
@ -97,14 +99,14 @@ public class BBoxStrategy extends SpatialStrategy {
|
||||||
type.freeze();
|
type.freeze();
|
||||||
DEFAULT_FIELDTYPE = type;
|
DEFAULT_FIELDTYPE = type;
|
||||||
// Legacy default: legacyNumerics + docValues
|
// Legacy default: legacyNumerics + docValues
|
||||||
type = new FieldType();
|
LegacyFieldType legacyType = new LegacyFieldType();
|
||||||
type.setIndexOptions(IndexOptions.DOCS);
|
legacyType.setIndexOptions(IndexOptions.DOCS);
|
||||||
type.setNumericType(FieldType.LegacyNumericType.DOUBLE);
|
legacyType.setNumericType(LegacyNumericType.DOUBLE);
|
||||||
type.setNumericPrecisionStep(8);// same as solr default
|
legacyType.setNumericPrecisionStep(8);// same as solr default
|
||||||
type.setDocValuesType(DocValuesType.NUMERIC);//docValues
|
legacyType.setDocValuesType(DocValuesType.NUMERIC);//docValues
|
||||||
type.setStored(false);
|
legacyType.setStored(false);
|
||||||
type.freeze();
|
legacyType.freeze();
|
||||||
LEGACY_FIELDTYPE = type;
|
LEGACY_FIELDTYPE = legacyType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final String SUFFIX_MINX = "__minX";
|
public static final String SUFFIX_MINX = "__minX";
|
||||||
|
@ -130,7 +132,7 @@ public class BBoxStrategy extends SpatialStrategy {
|
||||||
private final boolean hasDocVals;
|
private final boolean hasDocVals;
|
||||||
private final boolean hasPointVals;
|
private final boolean hasPointVals;
|
||||||
// equiv to "hasLegacyNumerics":
|
// equiv to "hasLegacyNumerics":
|
||||||
private final FieldType legacyNumericFieldType; // not stored; holds precision step.
|
private final LegacyFieldType legacyNumericFieldType; // not stored; holds precision step.
|
||||||
private final FieldType xdlFieldType;
|
private final FieldType xdlFieldType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -177,16 +179,17 @@ public class BBoxStrategy extends SpatialStrategy {
|
||||||
if ((this.hasPointVals = fieldType.pointDimensionCount() > 0)) {
|
if ((this.hasPointVals = fieldType.pointDimensionCount() > 0)) {
|
||||||
numQuads++;
|
numQuads++;
|
||||||
}
|
}
|
||||||
if (fieldType.indexOptions() != IndexOptions.NONE && fieldType.numericType() != null) {
|
if (fieldType.indexOptions() != IndexOptions.NONE && fieldType instanceof LegacyFieldType && ((LegacyFieldType)fieldType).numericType() != null) {
|
||||||
if (hasPointVals) {
|
if (hasPointVals) {
|
||||||
throw new IllegalArgumentException("pointValues and LegacyNumericType are mutually exclusive");
|
throw new IllegalArgumentException("pointValues and LegacyNumericType are mutually exclusive");
|
||||||
}
|
}
|
||||||
if (fieldType.numericType() != FieldType.LegacyNumericType.DOUBLE) {
|
final LegacyFieldType legacyType = (LegacyFieldType) fieldType;
|
||||||
throw new IllegalArgumentException(getClass() + " does not support " + fieldType.numericType());
|
if (legacyType.numericType() != LegacyNumericType.DOUBLE) {
|
||||||
|
throw new IllegalArgumentException(getClass() + " does not support " + legacyType.numericType());
|
||||||
}
|
}
|
||||||
numQuads++;
|
numQuads++;
|
||||||
legacyNumericFieldType = new FieldType(LegacyDoubleField.TYPE_NOT_STORED);
|
legacyNumericFieldType = new LegacyFieldType(LegacyDoubleField.TYPE_NOT_STORED);
|
||||||
legacyNumericFieldType.setNumericPrecisionStep(fieldType.numericPrecisionStep());
|
legacyNumericFieldType.setNumericPrecisionStep(legacyType.numericPrecisionStep());
|
||||||
legacyNumericFieldType.freeze();
|
legacyNumericFieldType.freeze();
|
||||||
} else {
|
} else {
|
||||||
legacyNumericFieldType = null;
|
legacyNumericFieldType = null;
|
||||||
|
|
|
@ -26,7 +26,7 @@ import org.apache.lucene.util.BytesRefIterator;
|
||||||
/**
|
/**
|
||||||
* A TokenStream used internally by {@link org.apache.lucene.spatial.prefix.PrefixTreeStrategy}.
|
* A TokenStream used internally by {@link org.apache.lucene.spatial.prefix.PrefixTreeStrategy}.
|
||||||
*
|
*
|
||||||
* This is modelled after {@link org.apache.lucene.analysis.LegacyNumericTokenStream}.
|
* This is modelled after {@link org.apache.lucene.legacy.LegacyNumericTokenStream}.
|
||||||
*
|
*
|
||||||
* @lucene.internal
|
* @lucene.internal
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -20,16 +20,18 @@ import org.apache.lucene.document.DoubleDocValuesField;
|
||||||
import org.apache.lucene.document.DoublePoint;
|
import org.apache.lucene.document.DoublePoint;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.document.FieldType;
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.StoredField;
|
import org.apache.lucene.document.StoredField;
|
||||||
import org.apache.lucene.index.DocValuesType;
|
import org.apache.lucene.index.DocValuesType;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.queries.function.FunctionRangeQuery;
|
import org.apache.lucene.queries.function.FunctionRangeQuery;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.search.BooleanClause;
|
import org.apache.lucene.search.BooleanClause;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.search.ConstantScoreQuery;
|
import org.apache.lucene.search.ConstantScoreQuery;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.spatial.SpatialStrategy;
|
import org.apache.lucene.spatial.SpatialStrategy;
|
||||||
import org.apache.lucene.spatial.query.SpatialArgs;
|
import org.apache.lucene.spatial.query.SpatialArgs;
|
||||||
|
@ -85,7 +87,7 @@ public class PointVectorStrategy extends SpatialStrategy {
|
||||||
public static FieldType DEFAULT_FIELDTYPE;
|
public static FieldType DEFAULT_FIELDTYPE;
|
||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public static FieldType LEGACY_FIELDTYPE;
|
public static LegacyFieldType LEGACY_FIELDTYPE;
|
||||||
static {
|
static {
|
||||||
// Default: pointValues + docValues
|
// Default: pointValues + docValues
|
||||||
FieldType type = new FieldType();
|
FieldType type = new FieldType();
|
||||||
|
@ -95,14 +97,14 @@ public class PointVectorStrategy extends SpatialStrategy {
|
||||||
type.freeze();
|
type.freeze();
|
||||||
DEFAULT_FIELDTYPE = type;
|
DEFAULT_FIELDTYPE = type;
|
||||||
// Legacy default: legacyNumerics
|
// Legacy default: legacyNumerics
|
||||||
type = new FieldType();
|
LegacyFieldType legacyType = new LegacyFieldType();
|
||||||
type.setIndexOptions(IndexOptions.DOCS);
|
legacyType.setIndexOptions(IndexOptions.DOCS);
|
||||||
type.setNumericType(FieldType.LegacyNumericType.DOUBLE);
|
legacyType.setNumericType(LegacyNumericType.DOUBLE);
|
||||||
type.setNumericPrecisionStep(8);// same as solr default
|
legacyType.setNumericPrecisionStep(8);// same as solr default
|
||||||
type.setDocValuesType(DocValuesType.NONE);//no docValues!
|
legacyType.setDocValuesType(DocValuesType.NONE);//no docValues!
|
||||||
type.setStored(false);
|
legacyType.setStored(false);
|
||||||
type.freeze();
|
legacyType.freeze();
|
||||||
LEGACY_FIELDTYPE = type;
|
LEGACY_FIELDTYPE = legacyType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final String SUFFIX_X = "__x";
|
public static final String SUFFIX_X = "__x";
|
||||||
|
@ -116,7 +118,7 @@ public class PointVectorStrategy extends SpatialStrategy {
|
||||||
private final boolean hasDocVals;
|
private final boolean hasDocVals;
|
||||||
private final boolean hasPointVals;
|
private final boolean hasPointVals;
|
||||||
// equiv to "hasLegacyNumerics":
|
// equiv to "hasLegacyNumerics":
|
||||||
private final FieldType legacyNumericFieldType; // not stored; holds precision step.
|
private final LegacyFieldType legacyNumericFieldType; // not stored; holds precision step.
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new {@link PointVectorStrategy} instance that uses {@link DoublePoint} and {@link DoublePoint#newRangeQuery}
|
* Create a new {@link PointVectorStrategy} instance that uses {@link DoublePoint} and {@link DoublePoint#newRangeQuery}
|
||||||
|
@ -157,16 +159,17 @@ public class PointVectorStrategy extends SpatialStrategy {
|
||||||
if ((this.hasPointVals = fieldType.pointDimensionCount() > 0)) {
|
if ((this.hasPointVals = fieldType.pointDimensionCount() > 0)) {
|
||||||
numPairs++;
|
numPairs++;
|
||||||
}
|
}
|
||||||
if (fieldType.indexOptions() != IndexOptions.NONE && fieldType.numericType() != null) {
|
if (fieldType.indexOptions() != IndexOptions.NONE && fieldType instanceof LegacyFieldType && ((LegacyFieldType)fieldType).numericType() != null) {
|
||||||
if (hasPointVals) {
|
if (hasPointVals) {
|
||||||
throw new IllegalArgumentException("pointValues and LegacyNumericType are mutually exclusive");
|
throw new IllegalArgumentException("pointValues and LegacyNumericType are mutually exclusive");
|
||||||
}
|
}
|
||||||
if (fieldType.numericType() != FieldType.LegacyNumericType.DOUBLE) {
|
final LegacyFieldType legacyType = (LegacyFieldType) fieldType;
|
||||||
throw new IllegalArgumentException(getClass() + " does not support " + fieldType.numericType());
|
if (legacyType.numericType() != LegacyNumericType.DOUBLE) {
|
||||||
|
throw new IllegalArgumentException(getClass() + " does not support " + legacyType.numericType());
|
||||||
}
|
}
|
||||||
numPairs++;
|
numPairs++;
|
||||||
legacyNumericFieldType = new FieldType(LegacyDoubleField.TYPE_NOT_STORED);
|
legacyNumericFieldType = new LegacyFieldType(LegacyDoubleField.TYPE_NOT_STORED);
|
||||||
legacyNumericFieldType.setNumericPrecisionStep(fieldType.numericPrecisionStep());
|
legacyNumericFieldType.setNumericPrecisionStep(legacyType.numericPrecisionStep());
|
||||||
legacyNumericFieldType.freeze();
|
legacyNumericFieldType.freeze();
|
||||||
} else {
|
} else {
|
||||||
legacyNumericFieldType = null;
|
legacyNumericFieldType = null;
|
||||||
|
|
|
@ -22,6 +22,7 @@ import com.carrotsearch.randomizedtesting.annotations.Repeat;
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.document.FieldType;
|
||||||
import org.apache.lucene.index.DocValuesType;
|
import org.apache.lucene.index.DocValuesType;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.spatial.SpatialMatchConcern;
|
import org.apache.lucene.spatial.SpatialMatchConcern;
|
||||||
import org.apache.lucene.spatial.prefix.RandomSpatialOpStrategyTestCase;
|
import org.apache.lucene.spatial.prefix.RandomSpatialOpStrategyTestCase;
|
||||||
|
@ -100,7 +101,12 @@ public class TestBBoxStrategy extends RandomSpatialOpStrategyTestCase {
|
||||||
}
|
}
|
||||||
//test we can disable docValues for predicate tests
|
//test we can disable docValues for predicate tests
|
||||||
if (random().nextBoolean()) {
|
if (random().nextBoolean()) {
|
||||||
FieldType fieldType = new FieldType(((BBoxStrategy)strategy).getFieldType());
|
FieldType fieldType = ((BBoxStrategy)strategy).getFieldType();
|
||||||
|
if (fieldType instanceof LegacyFieldType) {
|
||||||
|
fieldType = new LegacyFieldType((LegacyFieldType)fieldType);
|
||||||
|
} else {
|
||||||
|
fieldType = new FieldType(fieldType);
|
||||||
|
}
|
||||||
fieldType.setDocValuesType(DocValuesType.NONE);
|
fieldType.setDocValuesType(DocValuesType.NONE);
|
||||||
strategy = new BBoxStrategy(ctx, strategy.getFieldName(), fieldType);
|
strategy = new BBoxStrategy(ctx, strategy.getFieldName(), fieldType);
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,8 +20,8 @@ import java.io.IOException;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.solr.schema.FieldType;
|
import org.apache.solr.schema.FieldType;
|
||||||
import org.apache.solr.schema.TrieDateField;
|
import org.apache.solr.schema.TrieDateField;
|
||||||
|
|
|
@ -24,12 +24,12 @@ import java.util.Map;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.LeafReaderContext;
|
import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.NumericDocValues;
|
import org.apache.lucene.index.NumericDocValues;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.FunctionValues;
|
import org.apache.lucene.queries.function.FunctionValues;
|
||||||
import org.apache.lucene.queries.function.docvalues.LongDocValues;
|
import org.apache.lucene.queries.function.docvalues.LongDocValues;
|
||||||
import org.apache.lucene.queries.function.valuesource.LongFieldSource;
|
import org.apache.lucene.queries.function.valuesource.LongFieldSource;
|
||||||
import org.apache.lucene.util.Bits;
|
import org.apache.lucene.util.Bits;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.mutable.MutableValue;
|
import org.apache.lucene.util.mutable.MutableValue;
|
||||||
import org.apache.lucene.util.mutable.MutableValueDate;
|
import org.apache.lucene.util.mutable.MutableValueDate;
|
||||||
|
|
||||||
|
|
|
@ -29,8 +29,7 @@ import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.index.LeafReaderContext;
|
import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.queries.function.FunctionQuery;
|
import org.apache.lucene.queries.function.FunctionQuery;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
|
@ -637,13 +636,13 @@ public class StatsField {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
final FieldType.LegacyNumericType hashableNumType = getHashableNumericType(field);
|
final LegacyNumericType hashableNumType = getHashableNumericType(field);
|
||||||
|
|
||||||
// some sane defaults
|
// some sane defaults
|
||||||
int log2m = 13; // roughly equivilent to "cardinality='0.33'"
|
int log2m = 13; // roughly equivilent to "cardinality='0.33'"
|
||||||
int regwidth = 6; // with decent hash, this is plenty for all valid long hashes
|
int regwidth = 6; // with decent hash, this is plenty for all valid long hashes
|
||||||
|
|
||||||
if (LegacyNumericType.FLOAT.equals(hashableNumType) || FieldType.LegacyNumericType.INT.equals(hashableNumType)) {
|
if (LegacyNumericType.FLOAT.equals(hashableNumType) || LegacyNumericType.INT.equals(hashableNumType)) {
|
||||||
// for 32bit values, we can adjust our default regwidth down a bit
|
// for 32bit values, we can adjust our default regwidth down a bit
|
||||||
regwidth--;
|
regwidth--;
|
||||||
|
|
||||||
|
@ -707,7 +706,7 @@ public class StatsField {
|
||||||
if (null == hasher) {
|
if (null == hasher) {
|
||||||
// if this is a function, or a non Long field, pre-hashed is invalid
|
// if this is a function, or a non Long field, pre-hashed is invalid
|
||||||
// NOTE: we ignore hashableNumType - it's LONG for non numerics like Strings
|
// NOTE: we ignore hashableNumType - it's LONG for non numerics like Strings
|
||||||
if (null == field || !FieldType.LegacyNumericType.LONG.equals(field.getType().getNumericType())) {
|
if (null == field || !LegacyNumericType.LONG.equals(field.getType().getNumericType())) {
|
||||||
throw new SolrException(ErrorCode.BAD_REQUEST, "hllPreHashed is only supported with Long based fields");
|
throw new SolrException(ErrorCode.BAD_REQUEST, "hllPreHashed is only supported with Long based fields");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -740,16 +739,16 @@ public class StatsField {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the effective {@link org.apache.lucene.document.FieldType.LegacyNumericType} for the field for the purposes of hash values.
|
* Returns the effective {@link LegacyNumericType} for the field for the purposes of hash values.
|
||||||
* ie: If the field has an explict LegacyNumericType that is returned; If the field has no explicit
|
* ie: If the field has an explict LegacyNumericType that is returned; If the field has no explicit
|
||||||
* LegacyNumericType then {@link org.apache.lucene.document.FieldType.LegacyNumericType#LONG} is returned; If field is null, then
|
* LegacyNumericType then {@link LegacyNumericType#LONG} is returned; If field is null, then
|
||||||
* {@link org.apache.lucene.document.FieldType.LegacyNumericType#FLOAT} is assumed for ValueSource.
|
* {@link LegacyNumericType#FLOAT} is assumed for ValueSource.
|
||||||
*/
|
*/
|
||||||
private static LegacyNumericType getHashableNumericType(SchemaField field) {
|
private static LegacyNumericType getHashableNumericType(SchemaField field) {
|
||||||
if (null == field) {
|
if (null == field) {
|
||||||
return LegacyNumericType.FLOAT;
|
return LegacyNumericType.FLOAT;
|
||||||
}
|
}
|
||||||
final LegacyNumericType result = field.getType().getNumericType();
|
final LegacyNumericType result = field.getType().getNumericType();
|
||||||
return null == result ? FieldType.LegacyNumericType.LONG : result;
|
return null == result ? LegacyNumericType.LONG : result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@ import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.index.LeafReaderContext;
|
import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.NumericDocValues;
|
import org.apache.lucene.index.NumericDocValues;
|
||||||
|
|
|
@ -33,6 +33,7 @@ import org.apache.lucene.index.NumericDocValues;
|
||||||
import org.apache.lucene.index.ReaderUtil;
|
import org.apache.lucene.index.ReaderUtil;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.index.TermsEnum;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.queries.function.FunctionValues;
|
import org.apache.lucene.queries.function.FunctionValues;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.util.Bits;
|
import org.apache.lucene.util.Bits;
|
||||||
|
@ -132,7 +133,7 @@ final class NumericFacets {
|
||||||
mincount = Math.max(mincount, 1);
|
mincount = Math.max(mincount, 1);
|
||||||
final SchemaField sf = searcher.getSchema().getField(fieldName);
|
final SchemaField sf = searcher.getSchema().getField(fieldName);
|
||||||
final FieldType ft = sf.getType();
|
final FieldType ft = sf.getType();
|
||||||
final org.apache.lucene.document.FieldType.LegacyNumericType numericType = ft.getNumericType();
|
final LegacyNumericType numericType = ft.getNumericType();
|
||||||
if (numericType == null) {
|
if (numericType == null) {
|
||||||
throw new IllegalStateException();
|
throw new IllegalStateException();
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.lucene.index.DocValuesType;
|
import org.apache.lucene.index.DocValuesType;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.spatial.bbox.BBoxOverlapRatioValueSource;
|
import org.apache.lucene.spatial.bbox.BBoxOverlapRatioValueSource;
|
||||||
import org.apache.lucene.spatial.bbox.BBoxStrategy;
|
import org.apache.lucene.spatial.bbox.BBoxStrategy;
|
||||||
|
@ -141,7 +142,11 @@ public class BBoxField extends AbstractSpatialFieldType<BBoxStrategy> implements
|
||||||
|
|
||||||
//and annoyingly this Field isn't going to have a docValues format because Solr uses a separate Field for that
|
//and annoyingly this Field isn't going to have a docValues format because Solr uses a separate Field for that
|
||||||
if (solrNumField.hasDocValues()) {
|
if (solrNumField.hasDocValues()) {
|
||||||
|
if (luceneType instanceof LegacyFieldType) {
|
||||||
|
luceneType = new LegacyFieldType((LegacyFieldType)luceneType);
|
||||||
|
} else {
|
||||||
luceneType = new org.apache.lucene.document.FieldType(luceneType);
|
luceneType = new org.apache.lucene.document.FieldType(luceneType);
|
||||||
|
}
|
||||||
luceneType.setDocValuesType(DocValuesType.NUMERIC);
|
luceneType.setDocValuesType(DocValuesType.NUMERIC);
|
||||||
}
|
}
|
||||||
return new BBoxStrategy(ctx, fieldName, luceneType);
|
return new BBoxStrategy(ctx, fieldName, luceneType);
|
||||||
|
|
|
@ -32,24 +32,25 @@ import javax.xml.xpath.XPathConstants;
|
||||||
import javax.xml.xpath.XPathExpressionException;
|
import javax.xml.xpath.XPathExpressionException;
|
||||||
import javax.xml.xpath.XPathFactory;
|
import javax.xml.xpath.XPathFactory;
|
||||||
|
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.SortedSetDocValuesField;
|
import org.apache.lucene.document.SortedSetDocValuesField;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.index.IndexableField;
|
import org.apache.lucene.index.IndexableField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.valuesource.EnumFieldSource;
|
import org.apache.lucene.queries.function.valuesource.EnumFieldSource;
|
||||||
import org.apache.lucene.search.ConstantScoreQuery;
|
import org.apache.lucene.search.ConstantScoreQuery;
|
||||||
import org.apache.lucene.search.DocValuesRangeQuery;
|
import org.apache.lucene.search.DocValuesRangeQuery;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.search.SortField;
|
import org.apache.lucene.search.SortField;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
import org.apache.lucene.util.CharsRef;
|
import org.apache.lucene.util.CharsRef;
|
||||||
import org.apache.lucene.util.CharsRefBuilder;
|
import org.apache.lucene.util.CharsRefBuilder;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.solr.common.EnumFieldValue;
|
import org.apache.solr.common.EnumFieldValue;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.response.TextResponseWriter;
|
import org.apache.solr.response.TextResponseWriter;
|
||||||
|
@ -234,8 +235,8 @@ public class EnumField extends PrimitiveFieldType {
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public FieldType.LegacyNumericType getNumericType() {
|
public LegacyNumericType getNumericType() {
|
||||||
return FieldType.LegacyNumericType.INT;
|
return LegacyNumericType.INT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -387,7 +388,7 @@ public class EnumField extends PrimitiveFieldType {
|
||||||
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, "Unknown value for enum field: " + value.toString());
|
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, "Unknown value for enum field: " + value.toString());
|
||||||
|
|
||||||
String intAsString = intValue.toString();
|
String intAsString = intValue.toString();
|
||||||
final FieldType newType = new FieldType();
|
final LegacyFieldType newType = new LegacyFieldType();
|
||||||
|
|
||||||
newType.setTokenized(field.isTokenized());
|
newType.setTokenized(field.isTokenized());
|
||||||
newType.setStored(field.stored());
|
newType.setStored(field.stored());
|
||||||
|
@ -397,7 +398,7 @@ public class EnumField extends PrimitiveFieldType {
|
||||||
newType.setStoreTermVectorOffsets(field.storeTermOffsets());
|
newType.setStoreTermVectorOffsets(field.storeTermOffsets());
|
||||||
newType.setStoreTermVectorPositions(field.storeTermPositions());
|
newType.setStoreTermVectorPositions(field.storeTermPositions());
|
||||||
newType.setStoreTermVectorPayloads(field.storeTermPayloads());
|
newType.setStoreTermVectorPayloads(field.storeTermPayloads());
|
||||||
newType.setNumericType(FieldType.LegacyNumericType.INT);
|
newType.setNumericType(LegacyNumericType.INT);
|
||||||
newType.setNumericPrecisionStep(DEFAULT_PRECISION_STEP);
|
newType.setNumericPrecisionStep(DEFAULT_PRECISION_STEP);
|
||||||
|
|
||||||
final org.apache.lucene.document.Field f;
|
final org.apache.lucene.document.Field f;
|
||||||
|
|
|
@ -38,6 +38,7 @@ import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.index.IndexableField;
|
import org.apache.lucene.index.IndexableField;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.search.DocValuesRangeQuery;
|
import org.apache.lucene.search.DocValuesRangeQuery;
|
||||||
import org.apache.lucene.search.DocValuesRewriteMethod;
|
import org.apache.lucene.search.DocValuesRewriteMethod;
|
||||||
|
@ -621,7 +622,7 @@ public abstract class FieldType extends FieldProperties {
|
||||||
|
|
||||||
/** Return the numeric type of this field, or null if this field is not a
|
/** Return the numeric type of this field, or null if this field is not a
|
||||||
* numeric field. */
|
* numeric field. */
|
||||||
public org.apache.lucene.document.FieldType.LegacyNumericType getNumericType() {
|
public LegacyNumericType getNumericType() {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,8 @@ import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.lucene.spatial.vector.PointVectorStrategy;
|
import org.apache.lucene.spatial.vector.PointVectorStrategy;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -78,8 +80,8 @@ public class SpatialPointVectorFieldType extends AbstractSpatialFieldType<PointV
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public org.apache.lucene.document.FieldType.LegacyNumericType getNumericType() {
|
public LegacyNumericType getNumericType() {
|
||||||
return org.apache.lucene.document.FieldType.LegacyNumericType.DOUBLE;
|
return LegacyNumericType.DOUBLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -88,8 +90,7 @@ public class SpatialPointVectorFieldType extends AbstractSpatialFieldType<PointV
|
||||||
if (this.getNumericType() != null) {
|
if (this.getNumericType() != null) {
|
||||||
// create strategy based on legacy numerics
|
// create strategy based on legacy numerics
|
||||||
// todo remove in 7.0
|
// todo remove in 7.0
|
||||||
org.apache.lucene.document.FieldType fieldType =
|
LegacyFieldType fieldType = new LegacyFieldType(PointVectorStrategy.LEGACY_FIELDTYPE);
|
||||||
new org.apache.lucene.document.FieldType(PointVectorStrategy.LEGACY_FIELDTYPE);
|
|
||||||
fieldType.setNumericPrecisionStep(precisionStep);
|
fieldType.setNumericPrecisionStep(precisionStep);
|
||||||
return new PointVectorStrategy(ctx, fieldName, fieldType);
|
return new PointVectorStrategy(ctx, fieldName, fieldType);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -23,13 +23,13 @@ import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.SortedDocValues;
|
import org.apache.lucene.index.SortedDocValues;
|
||||||
import org.apache.lucene.index.SortedSetDocValues;
|
import org.apache.lucene.index.SortedSetDocValues;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.FunctionValues;
|
import org.apache.lucene.queries.function.FunctionValues;
|
||||||
import org.apache.lucene.queries.function.docvalues.DoubleDocValues;
|
import org.apache.lucene.queries.function.docvalues.DoubleDocValues;
|
||||||
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
||||||
import org.apache.lucene.search.SortedSetSelector;
|
import org.apache.lucene.search.SortedSetSelector;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.lucene.util.mutable.MutableValue;
|
import org.apache.lucene.util.mutable.MutableValue;
|
||||||
import org.apache.lucene.util.mutable.MutableValueDouble;
|
import org.apache.lucene.util.mutable.MutableValueDouble;
|
||||||
|
|
|
@ -26,24 +26,25 @@ import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.lucene.document.FieldType.LegacyNumericType;
|
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.SortedSetDocValuesField;
|
import org.apache.lucene.document.SortedSetDocValuesField;
|
||||||
import org.apache.lucene.index.DocValuesType;
|
import org.apache.lucene.index.DocValuesType;
|
||||||
import org.apache.lucene.index.IndexOptions;
|
import org.apache.lucene.index.IndexOptions;
|
||||||
import org.apache.lucene.index.IndexableField;
|
import org.apache.lucene.index.IndexableField;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyFloatField;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.valuesource.DoubleFieldSource;
|
import org.apache.lucene.queries.function.valuesource.DoubleFieldSource;
|
||||||
import org.apache.lucene.queries.function.valuesource.FloatFieldSource;
|
import org.apache.lucene.queries.function.valuesource.FloatFieldSource;
|
||||||
import org.apache.lucene.queries.function.valuesource.IntFieldSource;
|
import org.apache.lucene.queries.function.valuesource.IntFieldSource;
|
||||||
import org.apache.lucene.queries.function.valuesource.LongFieldSource;
|
import org.apache.lucene.queries.function.valuesource.LongFieldSource;
|
||||||
import org.apache.lucene.search.DocValuesRangeQuery;
|
import org.apache.lucene.search.DocValuesRangeQuery;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.search.SortField;
|
import org.apache.lucene.search.SortField;
|
||||||
import org.apache.lucene.search.SortedSetSelector;
|
import org.apache.lucene.search.SortedSetSelector;
|
||||||
|
@ -51,7 +52,6 @@ import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
import org.apache.lucene.util.CharsRef;
|
import org.apache.lucene.util.CharsRef;
|
||||||
import org.apache.lucene.util.CharsRefBuilder;
|
import org.apache.lucene.util.CharsRefBuilder;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.lucene.util.mutable.MutableValueDate;
|
import org.apache.lucene.util.mutable.MutableValueDate;
|
||||||
import org.apache.lucene.util.mutable.MutableValueLong;
|
import org.apache.lucene.util.mutable.MutableValueLong;
|
||||||
|
@ -67,9 +67,9 @@ import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides field types to support for Lucene's {@link
|
* Provides field types to support for Lucene's {@link
|
||||||
* org.apache.lucene.document.LegacyIntField}, {@link org.apache.lucene.document.LegacyLongField}, {@link org.apache.lucene.document.LegacyFloatField} and
|
* org.apache.lucene.legacy.LegacyIntField}, {@link org.apache.lucene.legacy.LegacyLongField}, {@link org.apache.lucene.legacy.LegacyFloatField} and
|
||||||
* {@link org.apache.lucene.document.LegacyDoubleField}.
|
* {@link org.apache.lucene.legacy.LegacyDoubleField}.
|
||||||
* See {@link org.apache.lucene.search.LegacyNumericRangeQuery} for more details.
|
* See {@link org.apache.lucene.legacy.LegacyNumericRangeQuery} for more details.
|
||||||
* It supports integer, float, long, double and date types.
|
* It supports integer, float, long, double and date types.
|
||||||
* <p>
|
* <p>
|
||||||
* For each number being added to this field, multiple terms are generated as per the algorithm described in the above
|
* For each number being added to this field, multiple terms are generated as per the algorithm described in the above
|
||||||
|
@ -82,7 +82,7 @@ import org.slf4j.LoggerFactory;
|
||||||
* generated, range search will be no faster than any other number field, but sorting will still be possible.
|
* generated, range search will be no faster than any other number field, but sorting will still be possible.
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @see org.apache.lucene.search.LegacyNumericRangeQuery
|
* @see org.apache.lucene.legacy.LegacyNumericRangeQuery
|
||||||
* @since solr 1.4
|
* @since solr 1.4
|
||||||
*/
|
*/
|
||||||
public class TrieField extends PrimitiveFieldType {
|
public class TrieField extends PrimitiveFieldType {
|
||||||
|
@ -349,17 +349,17 @@ public class TrieField extends PrimitiveFieldType {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public FieldType.LegacyNumericType getNumericType() {
|
public LegacyNumericType getNumericType() {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case INTEGER:
|
case INTEGER:
|
||||||
return FieldType.LegacyNumericType.INT;
|
return LegacyNumericType.INT;
|
||||||
case LONG:
|
case LONG:
|
||||||
case DATE:
|
case DATE:
|
||||||
return FieldType.LegacyNumericType.LONG;
|
return LegacyNumericType.LONG;
|
||||||
case FLOAT:
|
case FLOAT:
|
||||||
return FieldType.LegacyNumericType.FLOAT;
|
return LegacyNumericType.FLOAT;
|
||||||
case DOUBLE:
|
case DOUBLE:
|
||||||
return FieldType.LegacyNumericType.DOUBLE;
|
return LegacyNumericType.DOUBLE;
|
||||||
default:
|
default:
|
||||||
throw new AssertionError();
|
throw new AssertionError();
|
||||||
}
|
}
|
||||||
|
@ -666,7 +666,7 @@ public class TrieField extends PrimitiveFieldType {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
FieldType ft = new FieldType();
|
LegacyFieldType ft = new LegacyFieldType();
|
||||||
ft.setStored(stored);
|
ft.setStored(stored);
|
||||||
ft.setTokenized(true);
|
ft.setTokenized(true);
|
||||||
ft.setOmitNorms(field.omitNorms());
|
ft.setOmitNorms(field.omitNorms());
|
||||||
|
@ -677,16 +677,16 @@ public class TrieField extends PrimitiveFieldType {
|
||||||
ft.setNumericType(LegacyNumericType.INT);
|
ft.setNumericType(LegacyNumericType.INT);
|
||||||
break;
|
break;
|
||||||
case FLOAT:
|
case FLOAT:
|
||||||
ft.setNumericType(FieldType.LegacyNumericType.FLOAT);
|
ft.setNumericType(LegacyNumericType.FLOAT);
|
||||||
break;
|
break;
|
||||||
case LONG:
|
case LONG:
|
||||||
ft.setNumericType(FieldType.LegacyNumericType.LONG);
|
ft.setNumericType(LegacyNumericType.LONG);
|
||||||
break;
|
break;
|
||||||
case DOUBLE:
|
case DOUBLE:
|
||||||
ft.setNumericType(FieldType.LegacyNumericType.DOUBLE);
|
ft.setNumericType(LegacyNumericType.DOUBLE);
|
||||||
break;
|
break;
|
||||||
case DATE:
|
case DATE:
|
||||||
ft.setNumericType(FieldType.LegacyNumericType.LONG);
|
ft.setNumericType(LegacyNumericType.LONG);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, "Unknown type for trie field: " + type);
|
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, "Unknown type for trie field: " + type);
|
||||||
|
|
|
@ -23,13 +23,13 @@ import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.SortedDocValues;
|
import org.apache.lucene.index.SortedDocValues;
|
||||||
import org.apache.lucene.index.SortedSetDocValues;
|
import org.apache.lucene.index.SortedSetDocValues;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.FunctionValues;
|
import org.apache.lucene.queries.function.FunctionValues;
|
||||||
import org.apache.lucene.queries.function.docvalues.FloatDocValues;
|
import org.apache.lucene.queries.function.docvalues.FloatDocValues;
|
||||||
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
||||||
import org.apache.lucene.search.SortedSetSelector;
|
import org.apache.lucene.search.SortedSetSelector;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.lucene.util.mutable.MutableValue;
|
import org.apache.lucene.util.mutable.MutableValue;
|
||||||
import org.apache.lucene.util.mutable.MutableValueFloat;
|
import org.apache.lucene.util.mutable.MutableValueFloat;
|
||||||
|
|
|
@ -23,13 +23,13 @@ import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.SortedDocValues;
|
import org.apache.lucene.index.SortedDocValues;
|
||||||
import org.apache.lucene.index.SortedSetDocValues;
|
import org.apache.lucene.index.SortedSetDocValues;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.FunctionValues;
|
import org.apache.lucene.queries.function.FunctionValues;
|
||||||
import org.apache.lucene.queries.function.docvalues.IntDocValues;
|
import org.apache.lucene.queries.function.docvalues.IntDocValues;
|
||||||
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
||||||
import org.apache.lucene.search.SortedSetSelector;
|
import org.apache.lucene.search.SortedSetSelector;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.mutable.MutableValue;
|
import org.apache.lucene.util.mutable.MutableValue;
|
||||||
import org.apache.lucene.util.mutable.MutableValueInt;
|
import org.apache.lucene.util.mutable.MutableValueInt;
|
||||||
|
|
||||||
|
|
|
@ -23,13 +23,13 @@ import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
import org.apache.lucene.index.SortedDocValues;
|
import org.apache.lucene.index.SortedDocValues;
|
||||||
import org.apache.lucene.index.SortedSetDocValues;
|
import org.apache.lucene.index.SortedSetDocValues;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.FunctionValues;
|
import org.apache.lucene.queries.function.FunctionValues;
|
||||||
import org.apache.lucene.queries.function.docvalues.LongDocValues;
|
import org.apache.lucene.queries.function.docvalues.LongDocValues;
|
||||||
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
import org.apache.lucene.queries.function.valuesource.SortedSetFieldSource;
|
||||||
import org.apache.lucene.search.SortedSetSelector;
|
import org.apache.lucene.search.SortedSetSelector;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.mutable.MutableValue;
|
import org.apache.lucene.util.mutable.MutableValue;
|
||||||
import org.apache.lucene.util.mutable.MutableValueLong;
|
import org.apache.lucene.util.mutable.MutableValueLong;
|
||||||
|
|
||||||
|
|
|
@ -17,12 +17,12 @@
|
||||||
package org.apache.solr.search;
|
package org.apache.solr.search;
|
||||||
|
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
import org.apache.lucene.search.BooleanClause;
|
import org.apache.lucene.search.BooleanClause;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.search.BoostQuery;
|
import org.apache.lucene.search.BoostQuery;
|
||||||
import org.apache.lucene.search.ConstantScoreQuery;
|
import org.apache.lucene.search.ConstantScoreQuery;
|
||||||
import org.apache.lucene.search.FuzzyQuery;
|
import org.apache.lucene.search.FuzzyQuery;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.PrefixQuery;
|
import org.apache.lucene.search.PrefixQuery;
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.search.TermQuery;
|
import org.apache.lucene.search.TermQuery;
|
||||||
|
|
|
@ -34,7 +34,7 @@ import org.apache.lucene.util.Bits;
|
||||||
* Constrains search results to only match those which also match a provided
|
* Constrains search results to only match those which also match a provided
|
||||||
* query.
|
* query.
|
||||||
*
|
*
|
||||||
* <p> This could be used, for example, with a {@link org.apache.lucene.search.LegacyNumericRangeQuery} on a suitably
|
* <p> This could be used, for example, with a {@link org.apache.lucene.legacy.LegacyNumericRangeQuery} on a suitably
|
||||||
* formatted date field to implement date filtering. One could re-use a single
|
* formatted date field to implement date filtering. One could re-use a single
|
||||||
* CachingWrapperFilter(QueryWrapperFilter) that matches, e.g., only documents modified
|
* CachingWrapperFilter(QueryWrapperFilter) that matches, e.g., only documents modified
|
||||||
* within the last week. This would only need to be reconstructed once per day.
|
* within the last week. This would only need to be reconstructed once per day.
|
||||||
|
|
|
@ -19,6 +19,7 @@ package org.apache.solr.search.facet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericType;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.schema.FieldType;
|
import org.apache.solr.schema.FieldType;
|
||||||
import org.apache.solr.schema.SchemaField;
|
import org.apache.solr.schema.SchemaField;
|
||||||
|
@ -94,7 +95,7 @@ public class FacetField extends FacetRequest {
|
||||||
return new FacetFieldProcessorByEnumTermsStream(fcontext, this, sf);
|
return new FacetFieldProcessorByEnumTermsStream(fcontext, this, sf);
|
||||||
}
|
}
|
||||||
|
|
||||||
org.apache.lucene.document.FieldType.LegacyNumericType ntype = ft.getNumericType();
|
LegacyNumericType ntype = ft.getNumericType();
|
||||||
|
|
||||||
if (!multiToken) {
|
if (!multiToken) {
|
||||||
if (ntype != null) {
|
if (ntype != null) {
|
||||||
|
|
|
@ -23,6 +23,7 @@ import java.util.Map;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.mlt.MoreLikeThis;
|
import org.apache.lucene.queries.mlt.MoreLikeThis;
|
||||||
import org.apache.lucene.search.BooleanClause;
|
import org.apache.lucene.search.BooleanClause;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
|
@ -30,7 +31,6 @@ import org.apache.lucene.search.BoostQuery;
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.search.TermQuery;
|
import org.apache.lucene.search.TermQuery;
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.solr.common.SolrDocument;
|
import org.apache.solr.common.SolrDocument;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.StringUtils;
|
import org.apache.solr.common.StringUtils;
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.search.mlt;
|
package org.apache.solr.search.mlt;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.mlt.MoreLikeThis;
|
import org.apache.lucene.queries.mlt.MoreLikeThis;
|
||||||
import org.apache.lucene.search.BooleanClause;
|
import org.apache.lucene.search.BooleanClause;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
|
@ -25,7 +26,6 @@ import org.apache.lucene.search.ScoreDoc;
|
||||||
import org.apache.lucene.search.TermQuery;
|
import org.apache.lucene.search.TermQuery;
|
||||||
import org.apache.lucene.search.TopDocs;
|
import org.apache.lucene.search.TopDocs;
|
||||||
import org.apache.lucene.util.BytesRefBuilder;
|
import org.apache.lucene.util.BytesRefBuilder;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.StringUtils;
|
import org.apache.solr.common.StringUtils;
|
||||||
import org.apache.solr.common.params.SolrParams;
|
import org.apache.solr.common.params.SolrParams;
|
||||||
|
|
|
@ -28,10 +28,10 @@ import org.apache.lucene.index.SortedDocValues;
|
||||||
import org.apache.lucene.index.SortedSetDocValues;
|
import org.apache.lucene.index.SortedSetDocValues;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.index.TermsEnum;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.util.Accountable;
|
import org.apache.lucene.util.Accountable;
|
||||||
import org.apache.lucene.util.Bits;
|
import org.apache.lucene.util.Bits;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.NumericUtils;
|
import org.apache.lucene.util.NumericUtils;
|
||||||
import org.apache.lucene.util.RamUsageEstimator;
|
import org.apache.lucene.util.RamUsageEstimator;
|
||||||
|
|
||||||
|
@ -161,8 +161,8 @@ interface FieldCache {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A parser instance for int values encoded by {@link org.apache.lucene.util.LegacyNumericUtils}, e.g. when indexed
|
* A parser instance for int values encoded by {@link org.apache.lucene.legacy.LegacyNumericUtils}, e.g. when indexed
|
||||||
* via {@link org.apache.lucene.document.LegacyIntField}/{@link org.apache.lucene.analysis.LegacyNumericTokenStream}.
|
* via {@link org.apache.lucene.legacy.LegacyIntField}/{@link org.apache.lucene.legacy.LegacyNumericTokenStream}.
|
||||||
* @deprecated Index with points and use {@link #INT_POINT_PARSER} instead.
|
* @deprecated Index with points and use {@link #INT_POINT_PARSER} instead.
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@ -184,8 +184,8 @@ interface FieldCache {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A parser instance for float values encoded with {@link org.apache.lucene.util.LegacyNumericUtils}, e.g. when indexed
|
* A parser instance for float values encoded with {@link org.apache.lucene.legacy.LegacyNumericUtils}, e.g. when indexed
|
||||||
* via {@link org.apache.lucene.document.LegacyFloatField}/{@link org.apache.lucene.analysis.LegacyNumericTokenStream}.
|
* via {@link org.apache.lucene.legacy.LegacyFloatField}/{@link org.apache.lucene.legacy.LegacyNumericTokenStream}.
|
||||||
* @deprecated Index with points and use {@link #FLOAT_POINT_PARSER} instead.
|
* @deprecated Index with points and use {@link #FLOAT_POINT_PARSER} instead.
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@ -209,8 +209,8 @@ interface FieldCache {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A parser instance for long values encoded by {@link org.apache.lucene.util.LegacyNumericUtils}, e.g. when indexed
|
* A parser instance for long values encoded by {@link org.apache.lucene.legacy.LegacyNumericUtils}, e.g. when indexed
|
||||||
* via {@link org.apache.lucene.document.LegacyLongField}/{@link org.apache.lucene.analysis.LegacyNumericTokenStream}.
|
* via {@link org.apache.lucene.legacy.LegacyLongField}/{@link org.apache.lucene.legacy.LegacyNumericTokenStream}.
|
||||||
* @deprecated Index with points and use {@link #LONG_POINT_PARSER} instead.
|
* @deprecated Index with points and use {@link #LONG_POINT_PARSER} instead.
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@ -231,8 +231,8 @@ interface FieldCache {
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A parser instance for double values encoded with {@link org.apache.lucene.util.LegacyNumericUtils}, e.g. when indexed
|
* A parser instance for double values encoded with {@link org.apache.lucene.legacy.LegacyNumericUtils}, e.g. when indexed
|
||||||
* via {@link org.apache.lucene.document.LegacyDoubleField}/{@link org.apache.lucene.analysis.LegacyNumericTokenStream}.
|
* via {@link org.apache.lucene.legacy.LegacyDoubleField}/{@link org.apache.lucene.legacy.LegacyNumericTokenStream}.
|
||||||
* @deprecated Index with points and use {@link #DOUBLE_POINT_PARSER} instead.
|
* @deprecated Index with points and use {@link #DOUBLE_POINT_PARSER} instead.
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@ -279,7 +279,7 @@ interface FieldCache {
|
||||||
* @param parser
|
* @param parser
|
||||||
* Computes long for string values. May be {@code null} if the
|
* Computes long for string values. May be {@code null} if the
|
||||||
* requested field was indexed as {@link NumericDocValuesField} or
|
* requested field was indexed as {@link NumericDocValuesField} or
|
||||||
* {@link org.apache.lucene.document.LegacyLongField}.
|
* {@link org.apache.lucene.legacy.LegacyLongField}.
|
||||||
* @param setDocsWithField
|
* @param setDocsWithField
|
||||||
* If true then {@link #getDocsWithField} will also be computed and
|
* If true then {@link #getDocsWithField} will also be computed and
|
||||||
* stored in the FieldCache.
|
* stored in the FieldCache.
|
||||||
|
|
|
@ -86,7 +86,7 @@ public class UninvertingReader extends FilterLeafReader {
|
||||||
*/
|
*/
|
||||||
DOUBLE_POINT,
|
DOUBLE_POINT,
|
||||||
/**
|
/**
|
||||||
* Single-valued Integer, (e.g. indexed with {@link org.apache.lucene.document.LegacyIntField})
|
* Single-valued Integer, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyIntField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link NumericDocValuesField}.
|
* {@link NumericDocValuesField}.
|
||||||
|
@ -95,7 +95,7 @@ public class UninvertingReader extends FilterLeafReader {
|
||||||
@Deprecated
|
@Deprecated
|
||||||
LEGACY_INTEGER,
|
LEGACY_INTEGER,
|
||||||
/**
|
/**
|
||||||
* Single-valued Long, (e.g. indexed with {@link org.apache.lucene.document.LegacyLongField})
|
* Single-valued Long, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyLongField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link NumericDocValuesField}.
|
* {@link NumericDocValuesField}.
|
||||||
|
@ -104,7 +104,7 @@ public class UninvertingReader extends FilterLeafReader {
|
||||||
@Deprecated
|
@Deprecated
|
||||||
LEGACY_LONG,
|
LEGACY_LONG,
|
||||||
/**
|
/**
|
||||||
* Single-valued Float, (e.g. indexed with {@link org.apache.lucene.document.LegacyFloatField})
|
* Single-valued Float, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyFloatField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link NumericDocValuesField}.
|
* {@link NumericDocValuesField}.
|
||||||
|
@ -113,7 +113,7 @@ public class UninvertingReader extends FilterLeafReader {
|
||||||
@Deprecated
|
@Deprecated
|
||||||
LEGACY_FLOAT,
|
LEGACY_FLOAT,
|
||||||
/**
|
/**
|
||||||
* Single-valued Double, (e.g. indexed with {@link org.apache.lucene.document.LegacyDoubleField})
|
* Single-valued Double, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyDoubleField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link NumericDocValuesField}.
|
* {@link NumericDocValuesField}.
|
||||||
|
@ -143,28 +143,28 @@ public class UninvertingReader extends FilterLeafReader {
|
||||||
*/
|
*/
|
||||||
SORTED_SET_BINARY,
|
SORTED_SET_BINARY,
|
||||||
/**
|
/**
|
||||||
* Multi-valued Integer, (e.g. indexed with {@link org.apache.lucene.document.LegacyIntField})
|
* Multi-valued Integer, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyIntField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link SortedSetDocValuesField}.
|
* {@link SortedSetDocValuesField}.
|
||||||
*/
|
*/
|
||||||
SORTED_SET_INTEGER,
|
SORTED_SET_INTEGER,
|
||||||
/**
|
/**
|
||||||
* Multi-valued Float, (e.g. indexed with {@link org.apache.lucene.document.LegacyFloatField})
|
* Multi-valued Float, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyFloatField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link SortedSetDocValuesField}.
|
* {@link SortedSetDocValuesField}.
|
||||||
*/
|
*/
|
||||||
SORTED_SET_FLOAT,
|
SORTED_SET_FLOAT,
|
||||||
/**
|
/**
|
||||||
* Multi-valued Long, (e.g. indexed with {@link org.apache.lucene.document.LegacyLongField})
|
* Multi-valued Long, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyLongField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link SortedSetDocValuesField}.
|
* {@link SortedSetDocValuesField}.
|
||||||
*/
|
*/
|
||||||
SORTED_SET_LONG,
|
SORTED_SET_LONG,
|
||||||
/**
|
/**
|
||||||
* Multi-valued Double, (e.g. indexed with {@link org.apache.lucene.document.LegacyDoubleField})
|
* Multi-valued Double, (e.g. indexed with {@link org.apache.lucene.legacy.LegacyDoubleField})
|
||||||
* <p>
|
* <p>
|
||||||
* Fields with this type act as if they were indexed with
|
* Fields with this type act as if they were indexed with
|
||||||
* {@link SortedSetDocValuesField}.
|
* {@link SortedSetDocValuesField}.
|
||||||
|
|
|
@ -25,12 +25,12 @@ import java.util.concurrent.locks.ReentrantReadWriteLock;
|
||||||
import org.apache.lucene.index.LeafReader;
|
import org.apache.lucene.index.LeafReader;
|
||||||
import org.apache.lucene.index.LeafReaderContext;
|
import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.queries.function.FunctionValues;
|
import org.apache.lucene.queries.function.FunctionValues;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
import org.apache.lucene.util.BitUtil;
|
import org.apache.lucene.util.BitUtil;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.util.SuppressForbidden;
|
import org.apache.solr.common.util.SuppressForbidden;
|
||||||
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package org.apache.solr.search;
|
package org.apache.solr.search;
|
||||||
|
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
import org.apache.lucene.search.*;
|
import org.apache.lucene.search.*;
|
||||||
import org.apache.solr.common.params.ModifiableSolrParams;
|
import org.apache.solr.common.params.ModifiableSolrParams;
|
||||||
import org.apache.solr.util.AbstractSolrTestCase;
|
import org.apache.solr.util.AbstractSolrTestCase;
|
||||||
|
|
|
@ -21,8 +21,6 @@ import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType;
|
import org.apache.lucene.document.FieldType;
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.SortedDocValuesField;
|
import org.apache.lucene.document.SortedDocValuesField;
|
||||||
import org.apache.lucene.document.TextField;
|
import org.apache.lucene.document.TextField;
|
||||||
|
@ -31,6 +29,8 @@ import org.apache.lucene.index.DirectoryReader;
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.IndexWriterConfig;
|
import org.apache.lucene.index.IndexWriterConfig;
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
|
import org.apache.lucene.legacy.LegacyFloatField;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
import org.apache.lucene.queries.function.FunctionQuery;
|
import org.apache.lucene.queries.function.FunctionQuery;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.valuesource.FloatFieldSource;
|
import org.apache.lucene.queries.function.valuesource.FloatFieldSource;
|
||||||
|
|
|
@ -28,8 +28,6 @@ import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.codecs.Codec;
|
import org.apache.lucene.codecs.Codec;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.StringField;
|
import org.apache.lucene.document.StringField;
|
||||||
import org.apache.lucene.index.DirectoryReader;
|
import org.apache.lucene.index.DirectoryReader;
|
||||||
import org.apache.lucene.index.DocValues;
|
import org.apache.lucene.index.DocValues;
|
||||||
|
@ -45,10 +43,12 @@ import org.apache.lucene.index.SortedSetDocValues;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
import org.apache.lucene.index.TermsEnum.SeekStatus;
|
import org.apache.lucene.index.TermsEnum.SeekStatus;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.index.TermsEnum;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.StringHelper;
|
import org.apache.lucene.util.StringHelper;
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
|
|
|
@ -21,14 +21,14 @@ import java.io.IOException;
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.index.DirectoryReader;
|
import org.apache.lucene.index.DirectoryReader;
|
||||||
import org.apache.lucene.index.IndexWriter;
|
import org.apache.lucene.index.IndexWriter;
|
||||||
import org.apache.lucene.index.LeafReader;
|
import org.apache.lucene.index.LeafReader;
|
||||||
import org.apache.lucene.index.MultiReader;
|
import org.apache.lucene.index.MultiReader;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFloatField;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
||||||
|
|
|
@ -24,13 +24,9 @@ import java.util.Map;
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.DoublePoint;
|
import org.apache.lucene.document.DoublePoint;
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FloatPoint;
|
import org.apache.lucene.document.FloatPoint;
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.LongPoint;
|
import org.apache.lucene.document.LongPoint;
|
||||||
import org.apache.lucene.document.StoredField;
|
import org.apache.lucene.document.StoredField;
|
||||||
import org.apache.lucene.document.StringField;
|
import org.apache.lucene.document.StringField;
|
||||||
|
@ -41,6 +37,10 @@ import org.apache.lucene.index.IndexWriterConfig;
|
||||||
import org.apache.lucene.index.MultiReader;
|
import org.apache.lucene.index.MultiReader;
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
import org.apache.lucene.index.Term;
|
import org.apache.lucene.index.Term;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFloatField;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
import org.apache.lucene.search.BooleanClause.Occur;
|
import org.apache.lucene.search.BooleanClause.Occur;
|
||||||
import org.apache.lucene.search.BooleanQuery;
|
import org.apache.lucene.search.BooleanQuery;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
|
|
|
@ -28,10 +28,6 @@ import org.apache.lucene.document.BinaryDocValuesField;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field.Store;
|
import org.apache.lucene.document.Field.Store;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.LegacyDoubleField;
|
|
||||||
import org.apache.lucene.document.LegacyFloatField;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.SortedDocValuesField;
|
import org.apache.lucene.document.SortedDocValuesField;
|
||||||
import org.apache.lucene.document.SortedSetDocValuesField;
|
import org.apache.lucene.document.SortedSetDocValuesField;
|
||||||
|
@ -45,11 +41,15 @@ import org.apache.lucene.index.NumericDocValues;
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
import org.apache.lucene.index.Terms;
|
import org.apache.lucene.index.Terms;
|
||||||
import org.apache.lucene.index.TermsEnum;
|
import org.apache.lucene.index.TermsEnum;
|
||||||
|
import org.apache.lucene.legacy.LegacyDoubleField;
|
||||||
|
import org.apache.lucene.legacy.LegacyFloatField;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.Bits;
|
import org.apache.lucene.util.Bits;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.IOUtils;
|
import org.apache.lucene.util.IOUtils;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
||||||
|
|
|
@ -21,12 +21,12 @@ import java.util.Map;
|
||||||
|
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.search.ScoreDoc;
|
import org.apache.lucene.search.ScoreDoc;
|
||||||
import org.apache.lucene.search.Sort;
|
import org.apache.lucene.search.Sort;
|
||||||
|
@ -62,17 +62,17 @@ public class TestNumericTerms32 extends LuceneTestCase {
|
||||||
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
||||||
.setMergePolicy(newLogMergePolicy()));
|
.setMergePolicy(newLogMergePolicy()));
|
||||||
|
|
||||||
final FieldType storedInt = new FieldType(LegacyIntField.TYPE_NOT_STORED);
|
final LegacyFieldType storedInt = new LegacyFieldType(LegacyIntField.TYPE_NOT_STORED);
|
||||||
storedInt.setStored(true);
|
storedInt.setStored(true);
|
||||||
storedInt.freeze();
|
storedInt.freeze();
|
||||||
|
|
||||||
final FieldType storedInt8 = new FieldType(storedInt);
|
final LegacyFieldType storedInt8 = new LegacyFieldType(storedInt);
|
||||||
storedInt8.setNumericPrecisionStep(8);
|
storedInt8.setNumericPrecisionStep(8);
|
||||||
|
|
||||||
final FieldType storedInt4 = new FieldType(storedInt);
|
final LegacyFieldType storedInt4 = new LegacyFieldType(storedInt);
|
||||||
storedInt4.setNumericPrecisionStep(4);
|
storedInt4.setNumericPrecisionStep(4);
|
||||||
|
|
||||||
final FieldType storedInt2 = new FieldType(storedInt);
|
final LegacyFieldType storedInt2 = new LegacyFieldType(storedInt);
|
||||||
storedInt2.setNumericPrecisionStep(2);
|
storedInt2.setNumericPrecisionStep(2);
|
||||||
|
|
||||||
LegacyIntField
|
LegacyIntField
|
||||||
|
|
|
@ -21,12 +21,12 @@ import java.util.Map;
|
||||||
|
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.index.RandomIndexWriter;
|
import org.apache.lucene.index.RandomIndexWriter;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericRangeQuery;
|
||||||
import org.apache.lucene.search.IndexSearcher;
|
import org.apache.lucene.search.IndexSearcher;
|
||||||
import org.apache.lucene.search.LegacyNumericRangeQuery;
|
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.search.ScoreDoc;
|
import org.apache.lucene.search.ScoreDoc;
|
||||||
import org.apache.lucene.search.Sort;
|
import org.apache.lucene.search.Sort;
|
||||||
|
@ -62,20 +62,20 @@ public class TestNumericTerms64 extends LuceneTestCase {
|
||||||
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
.setMaxBufferedDocs(TestUtil.nextInt(random(), 100, 1000))
|
||||||
.setMergePolicy(newLogMergePolicy()));
|
.setMergePolicy(newLogMergePolicy()));
|
||||||
|
|
||||||
final FieldType storedLong = new FieldType(LegacyLongField.TYPE_NOT_STORED);
|
final LegacyFieldType storedLong = new LegacyFieldType(LegacyLongField.TYPE_NOT_STORED);
|
||||||
storedLong.setStored(true);
|
storedLong.setStored(true);
|
||||||
storedLong.freeze();
|
storedLong.freeze();
|
||||||
|
|
||||||
final FieldType storedLong8 = new FieldType(storedLong);
|
final LegacyFieldType storedLong8 = new LegacyFieldType(storedLong);
|
||||||
storedLong8.setNumericPrecisionStep(8);
|
storedLong8.setNumericPrecisionStep(8);
|
||||||
|
|
||||||
final FieldType storedLong4 = new FieldType(storedLong);
|
final LegacyFieldType storedLong4 = new LegacyFieldType(storedLong);
|
||||||
storedLong4.setNumericPrecisionStep(4);
|
storedLong4.setNumericPrecisionStep(4);
|
||||||
|
|
||||||
final FieldType storedLong6 = new FieldType(storedLong);
|
final LegacyFieldType storedLong6 = new LegacyFieldType(storedLong);
|
||||||
storedLong6.setNumericPrecisionStep(6);
|
storedLong6.setNumericPrecisionStep(6);
|
||||||
|
|
||||||
final FieldType storedLong2 = new FieldType(storedLong);
|
final LegacyFieldType storedLong2 = new LegacyFieldType(storedLong);
|
||||||
storedLong2.setNumericPrecisionStep(2);
|
storedLong2.setNumericPrecisionStep(2);
|
||||||
|
|
||||||
LegacyLongField
|
LegacyLongField
|
||||||
|
|
|
@ -28,10 +28,7 @@ import java.util.Set;
|
||||||
import org.apache.lucene.document.Document;
|
import org.apache.lucene.document.Document;
|
||||||
import org.apache.lucene.document.Field.Store;
|
import org.apache.lucene.document.Field.Store;
|
||||||
import org.apache.lucene.document.Field;
|
import org.apache.lucene.document.Field;
|
||||||
import org.apache.lucene.document.FieldType;
|
|
||||||
import org.apache.lucene.document.IntPoint;
|
import org.apache.lucene.document.IntPoint;
|
||||||
import org.apache.lucene.document.LegacyIntField;
|
|
||||||
import org.apache.lucene.document.LegacyLongField;
|
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
import org.apache.lucene.document.NumericDocValuesField;
|
||||||
import org.apache.lucene.document.StoredField;
|
import org.apache.lucene.document.StoredField;
|
||||||
import org.apache.lucene.document.StringField;
|
import org.apache.lucene.document.StringField;
|
||||||
|
@ -43,9 +40,12 @@ import org.apache.lucene.index.IndexWriter;
|
||||||
import org.apache.lucene.index.LeafReader;
|
import org.apache.lucene.index.LeafReader;
|
||||||
import org.apache.lucene.index.LeafReaderContext;
|
import org.apache.lucene.index.LeafReaderContext;
|
||||||
import org.apache.lucene.index.SortedSetDocValues;
|
import org.apache.lucene.index.SortedSetDocValues;
|
||||||
|
import org.apache.lucene.legacy.LegacyFieldType;
|
||||||
|
import org.apache.lucene.legacy.LegacyIntField;
|
||||||
|
import org.apache.lucene.legacy.LegacyLongField;
|
||||||
|
import org.apache.lucene.legacy.LegacyNumericUtils;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
import org.apache.lucene.util.LegacyNumericUtils;
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
import org.apache.solr.index.SlowCompositeReaderWrapper;
|
||||||
|
@ -224,7 +224,7 @@ public class TestUninvertingReader extends LuceneTestCase {
|
||||||
final Directory dir = newDirectory();
|
final Directory dir = newDirectory();
|
||||||
final IndexWriter iw = new IndexWriter(dir, newIndexWriterConfig(null));
|
final IndexWriter iw = new IndexWriter(dir, newIndexWriterConfig(null));
|
||||||
|
|
||||||
final FieldType NO_TRIE_TYPE = new FieldType(LegacyIntField.TYPE_NOT_STORED);
|
final LegacyFieldType NO_TRIE_TYPE = new LegacyFieldType(LegacyIntField.TYPE_NOT_STORED);
|
||||||
NO_TRIE_TYPE.setNumericPrecisionStep(Integer.MAX_VALUE);
|
NO_TRIE_TYPE.setNumericPrecisionStep(Integer.MAX_VALUE);
|
||||||
|
|
||||||
final Map<String,Type> UNINVERT_MAP = new LinkedHashMap<String,Type>();
|
final Map<String,Type> UNINVERT_MAP = new LinkedHashMap<String,Type>();
|
||||||
|
|
Loading…
Reference in New Issue