LUCENE-2781: drop deprecations from trunk

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1040463 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Robert Muir 2010-11-30 11:22:39 +00:00
parent 14305d9e3c
commit a58c26978f
271 changed files with 1533 additions and 110075 deletions

View File

@ -1,38 +0,0 @@
package org.apache.lucene.benchmark.byTask.feeds;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.benchmark.byTask.utils.Config;
/**
* A {@link DocMaker} which reads the English Wikipedia dump. Uses
* {@link EnwikiContentSource} as its content source, regardless if a different
* content source was defined in the configuration.
* @deprecated Please use {@link DocMaker} instead, with content.source=EnwikiContentSource
*/
@Deprecated
public class EnwikiDocMaker extends DocMaker {
@Override
public void setConfig(Config config) {
super.setConfig(config);
// Override whatever content source was set in the config
source = new EnwikiContentSource();
source.setConfig(config);
System.out.println("NOTE: EnwikiDocMaker is deprecated; please use DocMaker instead (which is the default if you don't specify doc.maker) with content.source=EnwikiContentSource");
}
}

View File

@ -1,50 +0,0 @@
package org.apache.lucene.benchmark.byTask.feeds;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.benchmark.byTask.utils.Config;
/**
* A DocMaker reading one line at a time as a Document from a single file. This
* saves IO cost (over DirContentSource) of recursing through a directory and
* opening a new file for every document. It also re-uses its Document and Field
* instance to improve indexing speed.<br>
* The expected format of each line is (arguments are separated by &lt;TAB&gt;):
* <i>title, date, body</i>. If a line is read in a different format, a
* {@link RuntimeException} will be thrown. In general, you should use this doc
* maker with files that were created with
* {@link org.apache.lucene.benchmark.byTask.tasks.WriteLineDocTask}.<br>
* <br>
* Config properties:
* <ul>
* <li>doc.random.id.limit=N (default -1) -- create random docid in the range
* 0..N; this is useful with UpdateDoc to test updating random documents; if
* this is unspecified or -1, then docid is sequentially assigned
* </ul>
* @deprecated Please use {@link DocMaker} instead, with content.source=LineDocSource
*/
@Deprecated
public class LineDocMaker extends DocMaker {
@Override
public void setConfig(Config config) {
super.setConfig(config);
source = new LineDocSource();
source.setConfig(config);
System.out.println("NOTE: LineDocMaker is deprecated; please use DocMaker instead (which is the default if you don't specify doc.maker) with content.source=LineDocSource");
}
}

View File

@ -21,12 +21,7 @@ import java.io.ByteArrayInputStream;
import java.io.DataInputStream; import java.io.DataInputStream;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.*;
import java.util.Collections;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Set;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.store.IndexInput; import org.apache.lucene.store.IndexInput;
@ -195,6 +190,10 @@ public class JEDirectory extends Directory {
return new JEIndexInput(this, name); return new JEIndexInput(this, name);
} }
@Override
public void sync(Collection<String> names) throws IOException {
}
@Override @Override
public Lock makeLock(String name) { public Lock makeLock(String name) {
return new JELock(); return new JELock();

View File

@ -21,12 +21,7 @@ import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.io.DataInputStream; import java.io.DataInputStream;
import java.util.Set; import java.util.*;
import java.util.HashSet;
import java.util.List;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Collections;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.store.Lock; import org.apache.lucene.store.Lock;
@ -211,6 +206,10 @@ public class DbDirectory extends Directory {
} }
@Override @Override
public void sync(Collection<String> names) throws IOException {
}
@Override
public IndexInput openInput(String name) public IndexInput openInput(String name)
throws IOException throws IOException
{ {

View File

@ -204,7 +204,7 @@ public class SimpleCharStream
} }
/** /**
* @deprecated * @deprecated (gen)
* @see #getEndColumn * @see #getEndColumn
*/ */
@ -213,7 +213,7 @@ public class SimpleCharStream
} }
/** /**
* @deprecated * @deprecated (gen)
* @see #getEndLine * @see #getEndLine
*/ */

View File

@ -37,17 +37,7 @@ public class TextFragment
this.textStartPos = textStartPos; this.textStartPos = textStartPos;
this.fragNum = fragNum; this.fragNum = fragNum;
} }
/**
* @deprecated Use {@link #TextFragment(CharSequence, int, int)} instead.
* This constructor will be removed in Lucene 4.0
*/
@Deprecated
public TextFragment(StringBuffer markedUpText,int textStartPos, int fragNum)
{
this.markedUpText=markedUpText;
this.textStartPos = textStartPos;
this.fragNum = fragNum;
}
void setScore(float score) void setScore(float score)
{ {
this.score=score; this.score=score;

View File

@ -107,25 +107,12 @@ public abstract class BaseFragmentsBuilder implements FragmentsBuilder {
return fragments.toArray( new String[fragments.size()] ); return fragments.toArray( new String[fragments.size()] );
} }
@Deprecated
protected String[] getFieldValues( IndexReader reader, int docId, String fieldName) throws IOException {
Document doc = reader.document( docId, new MapFieldSelector( new String[]{ fieldName } ) );
return doc.getValues( fieldName ); // according to Document class javadoc, this never returns null
}
protected Field[] getFields( IndexReader reader, int docId, String fieldName) throws IOException { protected Field[] getFields( IndexReader reader, int docId, String fieldName) throws IOException {
// according to javadoc, doc.getFields(fieldName) cannot be used with lazy loaded field??? // according to javadoc, doc.getFields(fieldName) cannot be used with lazy loaded field???
Document doc = reader.document( docId, new MapFieldSelector( new String[]{ fieldName } ) ); Document doc = reader.document( docId, new MapFieldSelector(fieldName) );
return doc.getFields( fieldName ); // according to Document class javadoc, this never returns null return doc.getFields( fieldName ); // according to Document class javadoc, this never returns null
} }
@Deprecated
protected String makeFragment( StringBuilder buffer, int[] index, String[] values, WeightedFragInfo fragInfo ){
final int s = fragInfo.startOffset;
return makeFragment( fragInfo, getFragmentSource( buffer, index, values, s, fragInfo.endOffset ), s,
preTags, postTags, NULL_ENCODER );
}
protected String makeFragment( StringBuilder buffer, int[] index, Field[] values, WeightedFragInfo fragInfo, protected String makeFragment( StringBuilder buffer, int[] index, Field[] values, WeightedFragInfo fragInfo,
String[] preTags, String[] postTags, Encoder encoder ){ String[] preTags, String[] postTags, Encoder encoder ){
final int s = fragInfo.startOffset; final int s = fragInfo.startOffset;
@ -151,18 +138,6 @@ public abstract class BaseFragmentsBuilder implements FragmentsBuilder {
return fragment.toString(); return fragment.toString();
} }
@Deprecated
protected String getFragmentSource( StringBuilder buffer, int[] index, String[] values,
int startOffset, int endOffset ){
while( buffer.length() < endOffset && index[0] < values.length ){
buffer.append( values[index[0]] );
buffer.append( multiValuedSeparator );
index[0]++;
}
int eo = buffer.length() < endOffset ? buffer.length() : endOffset;
return buffer.substring( startOffset, eo );
}
protected String getFragmentSource( StringBuilder buffer, int[] index, Field[] values, protected String getFragmentSource( StringBuilder buffer, int[] index, Field[] values,
int startOffset, int endOffset ){ int startOffset, int endOffset ){
while( buffer.length() < endOffset && index[0] < values.length ){ while( buffer.length() < endOffset && index[0] < values.length ){

View File

@ -70,12 +70,7 @@ import org.apache.lucene.search.WildcardQuery;
import org.apache.lucene.search.BooleanClause.Occur; import org.apache.lucene.search.BooleanClause.Occur;
import org.apache.lucene.search.highlight.SynonymTokenizer.TestHighlightRunner; import org.apache.lucene.search.highlight.SynonymTokenizer.TestHighlightRunner;
import org.apache.lucene.search.regex.RegexQuery; import org.apache.lucene.search.regex.RegexQuery;
import org.apache.lucene.search.regex.SpanRegexQuery; import org.apache.lucene.search.spans.*;
import org.apache.lucene.search.spans.SpanNearQuery;
import org.apache.lucene.search.spans.SpanNotQuery;
import org.apache.lucene.search.spans.SpanOrQuery;
import org.apache.lucene.search.spans.SpanQuery;
import org.apache.lucene.search.spans.SpanTermQuery;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.util.automaton.BasicAutomata; import org.apache.lucene.util.automaton.BasicAutomata;
import org.apache.lucene.util.automaton.CharacterRunAutomaton; import org.apache.lucene.util.automaton.CharacterRunAutomaton;
@ -300,8 +295,7 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
} }
public void testSpanRegexQuery() throws Exception { public void testSpanRegexQuery() throws Exception {
query = new SpanOrQuery(new SpanQuery [] { query = new SpanOrQuery(new SpanMultiTermQueryWrapper<RegexQuery>(new RegexQuery(new Term(FIELD_NAME, "ken.*"))));
new SpanRegexQuery(new Term(FIELD_NAME, "ken.*")) });
searcher = new IndexSearcher(ramDir, true); searcher = new IndexSearcher(ramDir, true);
hits = searcher.search(query, 100); hits = searcher.search(query, 100);
int maxNumFragmentsRequired = 2; int maxNumFragmentsRequired = 2;
@ -698,8 +692,8 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
String text = searcher.doc(hits.scoreDocs[i].doc).get(HighlighterTest.FIELD_NAME); String text = searcher.doc(hits.scoreDocs[i].doc).get(HighlighterTest.FIELD_NAME);
int maxNumFragmentsRequired = 2; int maxNumFragmentsRequired = 2;
String fragmentSeparator = "..."; String fragmentSeparator = "...";
QueryScorer scorer = null; QueryScorer scorer;
TokenStream tokenStream = null; TokenStream tokenStream;
tokenStream = analyzer.tokenStream(HighlighterTest.FIELD_NAME, new StringReader(text)); tokenStream = analyzer.tokenStream(HighlighterTest.FIELD_NAME, new StringReader(text));
@ -726,8 +720,8 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
String text = searcher.doc(hits.scoreDocs[i].doc).get(HighlighterTest.FIELD_NAME); String text = searcher.doc(hits.scoreDocs[i].doc).get(HighlighterTest.FIELD_NAME);
int maxNumFragmentsRequired = 2; int maxNumFragmentsRequired = 2;
String fragmentSeparator = "..."; String fragmentSeparator = "...";
QueryScorer scorer = null; QueryScorer scorer;
TokenStream tokenStream = null; TokenStream tokenStream;
tokenStream = analyzer.tokenStream(HighlighterTest.FIELD_NAME, new StringReader(text)); tokenStream = analyzer.tokenStream(HighlighterTest.FIELD_NAME, new StringReader(text));
@ -754,8 +748,8 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
String text = searcher.doc(hits.scoreDocs[i].doc).get(HighlighterTest.FIELD_NAME); String text = searcher.doc(hits.scoreDocs[i].doc).get(HighlighterTest.FIELD_NAME);
int maxNumFragmentsRequired = 2; int maxNumFragmentsRequired = 2;
String fragmentSeparator = "..."; String fragmentSeparator = "...";
QueryScorer scorer = null; QueryScorer scorer;
TokenStream tokenStream = null; TokenStream tokenStream;
tokenStream = analyzer.tokenStream(HighlighterTest.FIELD_NAME, new StringReader(text)); tokenStream = analyzer.tokenStream(HighlighterTest.FIELD_NAME, new StringReader(text));
@ -820,8 +814,7 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
Highlighter hg = new Highlighter(new SimpleHTMLFormatter(), new QueryTermScorer(query)); Highlighter hg = new Highlighter(new SimpleHTMLFormatter(), new QueryTermScorer(query));
hg.setTextFragmenter(new NullFragmenter()); hg.setTextFragmenter(new NullFragmenter());
String match = null; String match = hg.getBestFragment(analyzer, "data", "help me [54-65]");
match = hg.getBestFragment(analyzer, "data", "help me [54-65]");
assertEquals("<B>help</B> me [54-65]", match); assertEquals("<B>help</B> me [54-65]", match);
} }
@ -1133,7 +1126,7 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
TermQuery query = new TermQuery(new Term("data", goodWord)); TermQuery query = new TermQuery(new Term("data", goodWord));
String match = null; String match;
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
sb.append(goodWord); sb.append(goodWord);
for (int i = 0; i < 10000; i++) { for (int i = 0; i < 10000; i++) {
@ -1246,8 +1239,7 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
public void run() throws Exception { public void run() throws Exception {
doSearching("AnInvalidQueryWhichShouldYieldNoResults"); doSearching("AnInvalidQueryWhichShouldYieldNoResults");
for (int i = 0; i < texts.length; i++) { for (String text : texts) {
String text = texts[i];
TokenStream tokenStream = analyzer.tokenStream(FIELD_NAME, new StringReader(text)); TokenStream tokenStream = analyzer.tokenStream(FIELD_NAME, new StringReader(text));
Highlighter highlighter = getHighlighter(query, FIELD_NAME, tokenStream, Highlighter highlighter = getHighlighter(query, FIELD_NAME, tokenStream,
HighlighterTest.this); HighlighterTest.this);
@ -1716,8 +1708,8 @@ public class HighlighterTest extends BaseTokenStreamTestCase implements Formatte
ramDir = newDirectory(); ramDir = newDirectory();
IndexWriter writer = new IndexWriter(ramDir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(ramDir, newIndexWriterConfig(
TEST_VERSION_CURRENT, new MockAnalyzer(MockTokenizer.SIMPLE, true, MockTokenFilter.ENGLISH_STOPSET, true))); TEST_VERSION_CURRENT, new MockAnalyzer(MockTokenizer.SIMPLE, true, MockTokenFilter.ENGLISH_STOPSET, true)));
for (int i = 0; i < texts.length; i++) { for (String text : texts) {
addDoc(writer, texts[i]); addDoc(writer, text);
} }
Document doc = new Document(); Document doc = new Document();
NumericField nfield = new NumericField(NUMERIC_FIELD_NAME, Store.YES, true); NumericField nfield = new NumericField(NUMERIC_FIELD_NAME, Store.YES, true);
@ -1881,7 +1873,7 @@ final class SynonymTokenizer extends TokenStream {
} }
public Highlighter getHighlighter(Query query, String fieldName, TokenStream stream, Formatter formatter, boolean expanMultiTerm) { public Highlighter getHighlighter(Query query, String fieldName, TokenStream stream, Formatter formatter, boolean expanMultiTerm) {
Scorer scorer = null; Scorer scorer;
if (mode == QUERY) { if (mode == QUERY) {
scorer = new QueryScorer(query, fieldName); scorer = new QueryScorer(query, fieldName);
if(!expanMultiTerm) { if(!expanMultiTerm) {

View File

@ -64,8 +64,6 @@ public class InstantiatedIndexWriter implements Closeable {
private PrintStream infoStream = null; private PrintStream infoStream = null;
private int maxFieldLength = IndexWriter.DEFAULT_MAX_FIELD_LENGTH;
private final InstantiatedIndex index; private final InstantiatedIndex index;
private final Analyzer analyzer; private final Analyzer analyzer;
@ -431,9 +429,7 @@ public class InstantiatedIndexWriter implements Closeable {
}; };
/** /**
* Adds a document to this index. If the document contains more than * Adds a document to this index.
* {@link #setMaxFieldLength(int)} terms for a given field, the remainder are
* discarded.
*/ */
public void addDocument(Document doc) throws IOException { public void addDocument(Document doc) throws IOException {
addDocument(doc, getAnalyzer()); addDocument(doc, getAnalyzer());
@ -441,9 +437,7 @@ public class InstantiatedIndexWriter implements Closeable {
/** /**
* Adds a document to this index, using the provided analyzer instead of the * Adds a document to this index, using the provided analyzer instead of the
* value of {@link #getAnalyzer()}. If the document contains more than * value of {@link #getAnalyzer()}.
* {@link #setMaxFieldLength(int)} terms for a given field, the remainder are
* discarded.
* *
* @param doc * @param doc
* @param analyzer * @param analyzer
@ -555,9 +549,6 @@ public class InstantiatedIndexWriter implements Closeable {
} }
tokens.add(token); // the vector will be built on commit. tokens.add(token); // the vector will be built on commit.
fieldSetting.fieldLength++; fieldSetting.fieldLength++;
if (fieldSetting.fieldLength > maxFieldLength) {
break;
}
} }
tokenStream.end(); tokenStream.end();
tokenStream.close(); tokenStream.close();
@ -666,14 +657,6 @@ public class InstantiatedIndexWriter implements Closeable {
addDocument(doc, analyzer); addDocument(doc, analyzer);
} }
public int getMaxFieldLength() {
return maxFieldLength;
}
public void setMaxFieldLength(int maxFieldLength) {
this.maxFieldLength = maxFieldLength;
}
public Similarity getSimilarity() { public Similarity getSimilarity() {
return similarity; return similarity;
} }

View File

@ -22,6 +22,7 @@ import java.util.Date;
import java.util.List; import java.util.List;
import java.util.ArrayList; import java.util.ArrayList;
import org.apache.lucene.search.DefaultSimilarity;
import org.apache.lucene.search.Similarity; import org.apache.lucene.search.Similarity;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory; import org.apache.lucene.store.FSDirectory;
@ -52,19 +53,21 @@ public class FieldNormModifier {
*/ */
public static void main(String[] args) throws IOException { public static void main(String[] args) throws IOException {
if (args.length < 3) { if (args.length < 3) {
System.err.println("Usage: FieldNormModifier <index> <package.SimilarityClassName | -n> <field1> [field2] ..."); System.err.println("Usage: FieldNormModifier <index> <package.SimilarityClassName | -d> <field1> [field2] ...");
System.exit(1); System.exit(1);
} }
Similarity s = null; Similarity s = null;
if (!args[1].equals("-n")) {
try { if (args[1].equals("-d"))
s = Class.forName(args[1]).asSubclass(Similarity.class).newInstance(); args[1] = DefaultSimilarity.class.getName();
} catch (Exception e) {
System.err.println("Couldn't instantiate similarity with empty constructor: " + args[1]); try {
e.printStackTrace(System.err); s = Class.forName(args[1]).asSubclass(Similarity.class).newInstance();
System.exit(1); } catch (Exception e) {
} System.err.println("Couldn't instantiate similarity with empty constructor: " + args[1]);
e.printStackTrace(System.err);
System.exit(1);
} }
Directory d = FSDirectory.open(new File(args[0])); Directory d = FSDirectory.open(new File(args[0]));
@ -142,11 +145,7 @@ public class FieldNormModifier {
for (int d = 0; d < termCounts.length; d++) { for (int d = 0; d < termCounts.length; d++) {
if (delDocs == null || !delDocs.get(d)) { if (delDocs == null || !delDocs.get(d)) {
if (sim == null) { subReader.setNorm(d, fieldName, sim.encodeNormValue(sim.lengthNorm(fieldName, termCounts[d])));
subReader.setNorm(d, fieldName, Similarity.encodeNorm(1.0f));
} else {
subReader.setNorm(d, fieldName, sim.encodeNormValue(sim.lengthNorm(fieldName, termCounts[d])));
}
} }
} }
} }

View File

@ -96,7 +96,7 @@ public class MultiPassIndexSplitter {
new WhitespaceAnalyzer(Version.LUCENE_CURRENT)) new WhitespaceAnalyzer(Version.LUCENE_CURRENT))
.setOpenMode(OpenMode.CREATE)); .setOpenMode(OpenMode.CREATE));
System.err.println("Writing part " + (i + 1) + " ..."); System.err.println("Writing part " + (i + 1) + " ...");
w.addIndexes(new IndexReader[]{input}); w.addIndexes(input);
w.close(); w.close();
} }
System.err.println("Done."); System.err.println("Done.");

View File

@ -1,144 +0,0 @@
package org.apache.lucene.misc;
/**
* Copyright 2006 The Apache Software Foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.MultiFields;
import org.apache.lucene.index.Terms;
import org.apache.lucene.index.TermsEnum;
import org.apache.lucene.index.DocsEnum;
import org.apache.lucene.search.Similarity;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory;
import org.apache.lucene.util.StringHelper;
import org.apache.lucene.util.Bits;
import java.io.File;
import java.io.IOException;
import java.util.Date;
/**
* Given a directory, a Similarity, and a list of fields, updates the
* fieldNorms in place for every document using the Similarity.lengthNorm.
*
* <p>
* NOTE: This only works if you do <b>not</b> use field/document boosts in your
* index.
* </p>
*
* @version $Id$
* @deprecated Use {@link org.apache.lucene.index.FieldNormModifier}
*/
@Deprecated
public class LengthNormModifier {
/**
* Command Line Execution method.
*
* <pre>
* Usage: LengthNormModifier /path/index package.SimilarityClassName field1 field2 ...
* </pre>
*/
public static void main(String[] args) throws IOException {
if (args.length < 3) {
System.err.println("Usage: LengthNormModifier <index> <package.SimilarityClassName> <field1> [field2] ...");
System.exit(1);
}
Similarity s = null;
try {
s = Class.forName(args[1]).asSubclass(Similarity.class).newInstance();
} catch (Exception e) {
System.err.println("Couldn't instantiate similarity with empty constructor: " + args[1]);
e.printStackTrace(System.err);
}
File index = new File(args[0]);
Directory d = FSDirectory.open(index);
LengthNormModifier lnm = new LengthNormModifier(d, s);
for (int i = 2; i < args.length; i++) {
System.out.print("Updating field: " + args[i] + " " + (new Date()).toString() + " ... ");
lnm.reSetNorms(args[i]);
System.out.println(new Date().toString());
}
d.close();
}
private Directory dir;
private Similarity sim;
/**
* Constructor for code that wishes to use this class progaomatically.
*
* @param d The Directory to modify
* @param s The Similarity to use in <code>reSetNorms</code>
*/
public LengthNormModifier(Directory d, Similarity s) {
dir = d;
sim = s;
}
/**
* Resets the norms for the specified field.
*
* <p>
* Opens a new IndexReader on the Directory given to this instance,
* modifies the norms using the Similarity given to this instance,
* and closes the IndexReader.
* </p>
*
* @param field the field whose norms should be reset
*/
public void reSetNorms(String field) throws IOException {
String fieldName = StringHelper.intern(field);
int[] termCounts = new int[0];
IndexReader reader = IndexReader.open(dir, false);
try {
termCounts = new int[reader.maxDoc()];
Bits delDocs = MultiFields.getDeletedDocs(reader);
DocsEnum docs = null;
Terms terms = MultiFields.getTerms(reader, field);
if (terms != null) {
TermsEnum termsEnum = terms.iterator();
while(termsEnum.next() != null) {
docs = termsEnum.docs(delDocs, docs);
int doc;
while ((doc = docs.nextDoc()) != DocsEnum.NO_MORE_DOCS) {
termCounts[doc] += docs.freq();
}
}
}
for (int d = 0; d < termCounts.length; d++) {
if (!delDocs.get(d)) {
byte norm = Similarity.encodeNorm(sim.lengthNorm(fieldName, termCounts[d]));
reader.setNorm(d, fieldName, norm);
}
}
} finally {
reader.close();
}
}
}

View File

@ -106,27 +106,15 @@ public class BooleanFilter extends Filter
} }
if (res !=null) if (res !=null)
return finalResult(res, reader.maxDoc()); return res;
return DocIdSet.EMPTY_DOCIDSET; return DocIdSet.EMPTY_DOCIDSET;
} }
/** Provide a SortedVIntList when it is definitely smaller
* than an OpenBitSet.
* @deprecated Either use CachingWrapperFilter, or
* switch to a different DocIdSet implementation yourself.
* This method will be removed in Lucene 4.0
*/
@Deprecated
protected final DocIdSet finalResult(OpenBitSetDISI result, int maxDocs) {
return result;
}
/** /**
* Adds a new FilterClause to the Boolean Filter container * Adds a new FilterClause to the Boolean Filter container
* @param filterClause A FilterClause object containing a Filter and an Occur parameter * @param filterClause A FilterClause object containing a Filter and an Occur parameter
*/ */
public void add(FilterClause filterClause) public void add(FilterClause filterClause)
{ {
if (filterClause.getOccur().equals(Occur.MUST)) { if (filterClause.getOccur().equals(Occur.MUST)) {

View File

@ -149,18 +149,6 @@ public class ChainedFilter extends Filter
return result; return result;
} }
/** Provide a SortedVIntList when it is definitely
* smaller than an OpenBitSet
* @deprecated Either use CachingWrapperFilter, or
* switch to a different DocIdSet implementation yourself.
* This method will be removed in Lucene 4.0
**/
@Deprecated
protected final DocIdSet finalResult(OpenBitSetDISI result, int maxDocs) {
return result;
}
/** /**
* Delegates to each filter in the chain. * Delegates to each filter in the chain.
* @param reader IndexReader * @param reader IndexReader
@ -175,7 +163,7 @@ public class ChainedFilter extends Filter
{ {
doChain(result, logic, chain[index[0]].getDocIdSet(reader)); doChain(result, logic, chain[index[0]].getDocIdSet(reader));
} }
return finalResult(result, reader.maxDoc()); return result;
} }
/** /**
@ -195,7 +183,7 @@ public class ChainedFilter extends Filter
{ {
doChain(result, logic[index[0]], chain[index[0]].getDocIdSet(reader)); doChain(result, logic[index[0]], chain[index[0]].getDocIdSet(reader));
} }
return finalResult(result, reader.maxDoc()); return result;
} }
@Override @Override

View File

@ -1,46 +0,0 @@
package org.apache.lucene.search.regex;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.index.Term;
import org.apache.lucene.search.spans.SpanMultiTermQueryWrapper;
/**
* A SpanQuery version of {@link RegexQuery} allowing regular expression
* queries to be nested within other SpanQuery subclasses.
* @deprecated Use <code>new SpanMultiTermQueryWrapper&lt;RegexQuery&gt;(new RegexQuery())</code> instead.
* This query will be removed in Lucene 4.0
*/
@Deprecated
public class SpanRegexQuery extends SpanMultiTermQueryWrapper<RegexQuery> implements RegexQueryCapable {
private final RegexCapabilities regexImpl = new JavaUtilRegexCapabilities();
public SpanRegexQuery(Term term) {
super(new RegexQuery(term));
}
public Term getTerm() { return query.getTerm(); }
public void setRegexImplementation(RegexCapabilities impl) {
query.setRegexImplementation(impl);
}
public RegexCapabilities getRegexImplementation() {
return query.getRegexImplementation();
}
}

View File

@ -17,6 +17,7 @@ package org.apache.lucene.search.regex;
* limitations under the License. * limitations under the License.
*/ */
import org.apache.lucene.search.spans.SpanMultiTermQueryWrapper;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.index.IndexReader; import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.MultiFields; import org.apache.lucene.index.MultiFields;
@ -73,10 +74,10 @@ public class TestRegexQuery extends LuceneTestCase {
} }
private int spanRegexQueryNrHits(String regex1, String regex2, int slop, boolean ordered) throws Exception { private int spanRegexQueryNrHits(String regex1, String regex2, int slop, boolean ordered) throws Exception {
SpanRegexQuery srq1 = new SpanRegexQuery( newTerm(regex1)); SpanQuery srq1 = new SpanMultiTermQueryWrapper<RegexQuery>(new RegexQuery(newTerm(regex1)));
SpanRegexQuery srq2 = new SpanRegexQuery( newTerm(regex2)); SpanQuery srq2 = new SpanMultiTermQueryWrapper<RegexQuery>(new RegexQuery(newTerm(regex2)));
SpanNearQuery query = new SpanNearQuery( new SpanQuery[]{srq1, srq2}, slop, ordered); SpanNearQuery query = new SpanNearQuery( new SpanQuery[]{srq1, srq2}, slop, ordered);
return searcher.search(query, null, 1000).totalHits; return searcher.search(query, null, 1000).totalHits;
} }

View File

@ -112,67 +112,6 @@ public class TestSpanRegexQuery extends LuceneTestCase {
indexStoreB.close(); indexStoreB.close();
} }
/** remove in lucene 4.0 */
@Deprecated
public void testSpanRegexOld() throws Exception {
Directory directory = newDirectory();
IndexWriter writer = new IndexWriter(directory, newIndexWriterConfig(
TEST_VERSION_CURRENT, new MockAnalyzer()));
Document doc = new Document();
// doc.add(newField("field", "the quick brown fox jumps over the lazy dog",
// Field.Store.NO, Field.Index.ANALYZED));
// writer.addDocument(doc);
// doc = new Document();
doc.add(newField("field", "auto update", Field.Store.NO,
Field.Index.ANALYZED));
writer.addDocument(doc);
doc = new Document();
doc.add(newField("field", "first auto update", Field.Store.NO,
Field.Index.ANALYZED));
writer.addDocument(doc);
writer.optimize();
writer.close();
IndexSearcher searcher = new IndexSearcher(directory, true);
SpanRegexQuery srq = new SpanRegexQuery(new Term("field", "aut.*"));
SpanFirstQuery sfq = new SpanFirstQuery(srq, 1);
// SpanNearQuery query = new SpanNearQuery(new SpanQuery[] {srq, stq}, 6,
// true);
int numHits = searcher.search(sfq, null, 1000).totalHits;
assertEquals(1, numHits);
searcher.close();
directory.close();
}
/** remove in lucene 4.0 */
@Deprecated
public void testSpanRegexBugOld() throws CorruptIndexException, IOException {
createRAMDirectories();
SpanRegexQuery srq = new SpanRegexQuery(new Term("field", "a.*"));
SpanRegexQuery stq = new SpanRegexQuery(new Term("field", "b.*"));
SpanNearQuery query = new SpanNearQuery(new SpanQuery[] { srq, stq }, 6,
true);
// 1. Search the same store which works
IndexSearcher[] arrSearcher = new IndexSearcher[2];
arrSearcher[0] = new IndexSearcher(indexStoreA, true);
arrSearcher[1] = new IndexSearcher(indexStoreB, true);
MultiSearcher searcher = new MultiSearcher(arrSearcher);
int numHits = searcher.search(query, null, 1000).totalHits;
arrSearcher[0].close();
arrSearcher[1].close();
// Will fail here
// We expect 2 but only one matched
// The rewriter function only write it once on the first IndexSearcher
// So it's using term: a1 b1 to search on the second IndexSearcher
// As a result, it won't match the document in the second IndexSearcher
assertEquals(2, numHits);
indexStoreA.close();
indexStoreB.close();
}
private void createRAMDirectories() throws CorruptIndexException, private void createRAMDirectories() throws CorruptIndexException,
LockObtainFailedException, IOException { LockObtainFailedException, IOException {
// creating a document to store // creating a document to store

View File

@ -17,11 +17,7 @@ package org.apache.lucene.queryParser.core.processors;
* limitations under the License. * limitations under the License.
*/ */
import java.util.Collection; import java.util.*;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.ListIterator;
import org.apache.lucene.queryParser.core.QueryNodeException; import org.apache.lucene.queryParser.core.QueryNodeException;
import org.apache.lucene.queryParser.core.config.QueryConfigHandler; import org.apache.lucene.queryParser.core.config.QueryConfigHandler;
@ -96,23 +92,6 @@ public class QueryNodeProcessorPipeline implements QueryNodeProcessor,
} }
/**
* Adds a processor to the pipeline, it's always added to the end of the
* pipeline.
*
* @deprecated this class now conforms to {@link List} interface, so use
* {@link #add(QueryNodeProcessor)} instead
*
* @param processor the processor to be added
*/
@Deprecated
public void addProcessor(QueryNodeProcessor processor) {
this.processors.add(processor);
processor.setQueryConfigHandler(this.queryConfig);
}
/** /**
* For reference about this method check: * For reference about this method check:
* {@link QueryNodeProcessor#setQueryConfigHandler(QueryConfigHandler)}. * {@link QueryNodeProcessor#setQueryConfigHandler(QueryConfigHandler)}.

View File

@ -1,269 +0,0 @@
package org.apache.lucene.queryParser.standard;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.util.Map;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.queryParser.ParseException;
import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.Query;
/**
* This class behaves as the as the lucene 2.4 MultiFieldQueryParser class, but uses the new
* query parser interface instead of the old one. <br/>
* <br/>
* This class should be used when the new query parser features are needed and
* also keep at the same time the old query parser interface. <br/>
*
* @deprecated this class will be removed soon, it's a temporary class to be
* used along the transition from the old query parser to the new
* one
*/
@Deprecated
public class MultiFieldQueryParserWrapper extends QueryParserWrapper {
/**
* Creates a MultiFieldQueryParser. Allows passing of a map with term to
* Boost, and the boost to apply to each term.
*
* <p>
* It will, when parse(String query) is called, construct a query like this
* (assuming the query consists of two terms and you specify the two fields
* <code>title</code> and <code>body</code>):
* </p>
*
* <code>
* (title:term1 body:term1) (title:term2 body:term2)
* </code>
*
* <p>
* When setDefaultOperator(AND_OPERATOR) is set, the result will be:
* </p>
*
* <code>
* +(title:term1 body:term1) +(title:term2 body:term2)
* </code>
*
* <p>
* When you pass a boost (title=>5 body=>10) you can get
* </p>
*
* <code>
* +(title:term1^5.0 body:term1^10.0) +(title:term2^5.0 body:term2^10.0)
* </code>
*
* <p>
* In other words, all the query's terms must appear, but it doesn't matter in
* what fields they appear.
* </p>
*/
public MultiFieldQueryParserWrapper(String[] fields, Analyzer analyzer, Map<String, Float> boosts) {
this(fields, analyzer);
StandardQueryParser qpHelper = getQueryParserHelper();
qpHelper.setMultiFields(fields);
qpHelper.setFieldsBoost(boosts);
}
/**
* Creates a MultiFieldQueryParser.
*
* <p>
* It will, when parse(String query) is called, construct a query like this
* (assuming the query consists of two terms and you specify the two fields
* <code>title</code> and <code>body</code>):
* </p>
*
* <code>
* (title:term1 body:term1) (title:term2 body:term2)
* </code>
*
* <p>
* When setDefaultOperator(AND_OPERATOR) is set, the result will be:
* </p>
*
* <code>
* +(title:term1 body:term1) +(title:term2 body:term2)
* </code>
*
* <p>
* In other words, all the query's terms must appear, but it doesn't matter in
* what fields they appear.
* </p>
*/
public MultiFieldQueryParserWrapper(String[] fields, Analyzer analyzer) {
super(null, analyzer);
StandardQueryParser qpHelper = getQueryParserHelper();
qpHelper.setAnalyzer(analyzer);
qpHelper.setMultiFields(fields);
}
/**
* Parses a query which searches on the fields specified.
* <p>
* If x fields are specified, this effectively constructs:
*
* <pre>
* &lt;code&gt;
* (field1:query1) (field2:query2) (field3:query3)...(fieldx:queryx)
* &lt;/code&gt;
* </pre>
*
* @param queries
* Queries strings to parse
* @param fields
* Fields to search on
* @param analyzer
* Analyzer to use
* @throws ParseException
* if query parsing fails
* @throws IllegalArgumentException
* if the length of the queries array differs from the length of the
* fields array
*/
public static Query parse(String[] queries, String[] fields, Analyzer analyzer)
throws ParseException {
if (queries.length != fields.length)
throw new IllegalArgumentException("queries.length != fields.length");
BooleanQuery bQuery = new BooleanQuery();
for (int i = 0; i < fields.length; i++) {
QueryParserWrapper qp = new QueryParserWrapper(fields[i], analyzer);
Query q = qp.parse(queries[i]);
if (q != null && // q never null, just being defensive
(!(q instanceof BooleanQuery) || ((BooleanQuery) q).getClauses().length > 0)) {
bQuery.add(q, BooleanClause.Occur.SHOULD);
}
}
return bQuery;
}
/**
* Parses a query, searching on the fields specified. Use this if you need to
* specify certain fields as required, and others as prohibited.
* <p>
*
* <pre>
* Usage:
* &lt;code&gt;
* String[] fields = {&quot;filename&quot;, &quot;contents&quot;, &quot;description&quot;};
* BooleanClause.Occur[] flags = {BooleanClause.Occur.SHOULD,
* BooleanClause.Occur.MUST,
* BooleanClause.Occur.MUST_NOT};
* MultiFieldQueryParser.parse(&quot;query&quot;, fields, flags, analyzer);
* &lt;/code&gt;
* </pre>
*<p>
* The code above would construct a query:
*
* <pre>
* &lt;code&gt;
* (filename:query) +(contents:query) -(description:query)
* &lt;/code&gt;
* </pre>
*
* @param query
* Query string to parse
* @param fields
* Fields to search on
* @param flags
* Flags describing the fields
* @param analyzer
* Analyzer to use
* @throws ParseException
* if query parsing fails
* @throws IllegalArgumentException
* if the length of the fields array differs from the length of the
* flags array
*/
public static Query parse(String query, String[] fields,
BooleanClause.Occur[] flags, Analyzer analyzer) throws ParseException {
if (fields.length != flags.length)
throw new IllegalArgumentException("fields.length != flags.length");
BooleanQuery bQuery = new BooleanQuery();
for (int i = 0; i < fields.length; i++) {
QueryParserWrapper qp = new QueryParserWrapper(fields[i], analyzer);
Query q = qp.parse(query);
if (q != null && // q never null, just being defensive
(!(q instanceof BooleanQuery) || ((BooleanQuery) q).getClauses().length > 0)) {
bQuery.add(q, flags[i]);
}
}
return bQuery;
}
/**
* Parses a query, searching on the fields specified. Use this if you need to
* specify certain fields as required, and others as prohibited.
* <p>
*
* <pre>
* Usage:
* &lt;code&gt;
* String[] query = {&quot;query1&quot;, &quot;query2&quot;, &quot;query3&quot;};
* String[] fields = {&quot;filename&quot;, &quot;contents&quot;, &quot;description&quot;};
* BooleanClause.Occur[] flags = {BooleanClause.Occur.SHOULD,
* BooleanClause.Occur.MUST,
* BooleanClause.Occur.MUST_NOT};
* MultiFieldQueryParser.parse(query, fields, flags, analyzer);
* &lt;/code&gt;
* </pre>
*<p>
* The code above would construct a query:
*
* <pre>
* &lt;code&gt;
* (filename:query1) +(contents:query2) -(description:query3)
* &lt;/code&gt;
* </pre>
*
* @param queries
* Queries string to parse
* @param fields
* Fields to search on
* @param flags
* Flags describing the fields
* @param analyzer
* Analyzer to use
* @throws ParseException
* if query parsing fails
* @throws IllegalArgumentException
* if the length of the queries, fields, and flags array differ
*/
public static Query parse(String[] queries, String[] fields,
BooleanClause.Occur[] flags, Analyzer analyzer) throws ParseException {
if (!(queries.length == fields.length && queries.length == flags.length))
throw new IllegalArgumentException(
"queries, fields, and flags array have have different length");
BooleanQuery bQuery = new BooleanQuery();
for (int i = 0; i < fields.length; i++) {
QueryParserWrapper qp = new QueryParserWrapper(fields[i], analyzer);
Query q = qp.parse(queries[i]);
if (q != null && // q never null, just being defensive
(!(q instanceof BooleanQuery) || ((BooleanQuery) q).getClauses().length > 0)) {
bQuery.add(q, flags[i]);
}
}
return bQuery;
}
}

View File

@ -1,491 +0,0 @@
package org.apache.lucene.queryParser.standard;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.text.Collator;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.document.DateTools;
import org.apache.lucene.document.DateTools.Resolution;
import org.apache.lucene.queryParser.ParseException;
import org.apache.lucene.queryParser.QueryParser;
import org.apache.lucene.queryParser.core.QueryNodeException;
import org.apache.lucene.queryParser.core.config.FieldConfig;
import org.apache.lucene.queryParser.core.config.QueryConfigHandler;
import org.apache.lucene.queryParser.core.nodes.QueryNode;
import org.apache.lucene.queryParser.core.parser.SyntaxParser;
import org.apache.lucene.queryParser.core.processors.QueryNodeProcessor;
import org.apache.lucene.queryParser.standard.builders.StandardQueryBuilder;
import org.apache.lucene.queryParser.standard.builders.StandardQueryTreeBuilder;
import org.apache.lucene.queryParser.standard.config.AllowLeadingWildcardAttribute;
import org.apache.lucene.queryParser.standard.config.AnalyzerAttribute;
import org.apache.lucene.queryParser.standard.config.DateResolutionAttribute;
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute;
import org.apache.lucene.queryParser.standard.config.DefaultPhraseSlopAttribute;
import org.apache.lucene.queryParser.standard.config.LocaleAttribute;
import org.apache.lucene.queryParser.standard.config.LowercaseExpandedTermsAttribute;
import org.apache.lucene.queryParser.standard.config.MultiTermRewriteMethodAttribute;
import org.apache.lucene.queryParser.standard.config.PositionIncrementsAttribute;
import org.apache.lucene.queryParser.standard.config.RangeCollatorAttribute;
import org.apache.lucene.queryParser.standard.config.StandardQueryConfigHandler;
import org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser;
import org.apache.lucene.queryParser.standard.processors.StandardQueryNodeProcessorPipeline;
import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.FuzzyQuery;
import org.apache.lucene.search.MultiTermQuery;
import org.apache.lucene.search.Query;
/**
* This class performs the query parsing using the new query parser
* implementation, but keeps the old {@link QueryParser} API. <br/>
* <br/>
* This class should be used when the new query parser features are and the old
* {@link QueryParser} API are needed at the same time. <br/>
*
* @deprecated this class will be removed soon, it's a temporary class to be
* used along the transition from the old query parser to the new
* one
*/
@Deprecated
public class QueryParserWrapper {
/**
* The default operator for parsing queries. Use
* {@link QueryParserWrapper#setDefaultOperator} to change it.
*/
static public enum Operator { OR, AND }
// the nested class:
/** Alternative form of QueryParser.Operator.AND */
public static final Operator AND_OPERATOR = Operator.AND;
/** Alternative form of QueryParser.Operator.OR */
public static final Operator OR_OPERATOR = Operator.OR;
/**
* Returns a String where those characters that QueryParser expects to be
* escaped are escaped by a preceding <code>\</code>.
*/
public static String escape(String s) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
// These characters are part of the query syntax and must be escaped
if (c == '\\' || c == '+' || c == '-' || c == '!' || c == '(' || c == ')'
|| c == ':' || c == '^' || c == '[' || c == ']' || c == '\"'
|| c == '{' || c == '}' || c == '~' || c == '*' || c == '?'
|| c == '|' || c == '&') {
sb.append('\\');
}
sb.append(c);
}
return sb.toString();
}
private SyntaxParser syntaxParser = new StandardSyntaxParser();
private StandardQueryConfigHandler config;
private StandardQueryParser qpHelper;
private QueryNodeProcessor processorPipeline;
private StandardQueryBuilder builder = new StandardQueryTreeBuilder();
private String defaultField;
public QueryParserWrapper(String defaultField, Analyzer analyzer) {
this.defaultField = defaultField;
this.qpHelper = new StandardQueryParser();
this.config = (StandardQueryConfigHandler) qpHelper.getQueryConfigHandler();
this.qpHelper.setAnalyzer(analyzer);
this.processorPipeline = new StandardQueryNodeProcessorPipeline(this.config);
}
StandardQueryParser getQueryParserHelper() {
return qpHelper;
}
public String getField() {
return this.defaultField;
}
public Analyzer getAnalyzer() {
if (this.config != null
&& this.config.hasAttribute(AnalyzerAttribute.class)) {
return this.config.getAttribute(AnalyzerAttribute.class).getAnalyzer();
}
return null;
}
/**
* Sets the {@link StandardQueryBuilder} used to generate a {@link Query}
* object from the parsed and processed query node tree.
*
* @param builder the builder
*/
public void setQueryBuilder(StandardQueryBuilder builder) {
this.builder = builder;
}
/**
* Sets the {@link QueryNodeProcessor} used to process the query node tree
* generated by the
* {@link org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser}.
*
* @param processor the processor
*/
public void setQueryProcessor(QueryNodeProcessor processor) {
this.processorPipeline = processor;
this.processorPipeline.setQueryConfigHandler(this.config);
}
/**
* Sets the {@link QueryConfigHandler} used by the {@link QueryNodeProcessor}
* set to this object.
*
* @param queryConfig the query config handler
*/
public void setQueryConfig(StandardQueryConfigHandler queryConfig) {
this.config = queryConfig;
if (this.processorPipeline != null) {
this.processorPipeline.setQueryConfigHandler(this.config);
}
}
/**
* Returns the query config handler used by this query parser
*
* @return the query config handler
*/
public QueryConfigHandler getQueryConfigHandler() {
return this.config;
}
/**
* Returns {@link QueryNodeProcessor} used to process the query node tree
* generated by the
* {@link org.apache.lucene.queryParser.standard.parser.StandardSyntaxParser}.
*
* @return the query processor
*/
public QueryNodeProcessor getQueryProcessor() {
return this.processorPipeline;
}
public ParseException generateParseException() {
return null;
}
public boolean getAllowLeadingWildcard() {
if (this.config != null
&& this.config.hasAttribute(AllowLeadingWildcardAttribute.class)) {
return this.config.getAttribute(AllowLeadingWildcardAttribute.class)
.isAllowLeadingWildcard();
}
return false;
}
public MultiTermQuery.RewriteMethod getMultiTermRewriteMethod() {
if (this.config != null
&& this.config.hasAttribute(MultiTermRewriteMethodAttribute.class)) {
return this.config.getAttribute(MultiTermRewriteMethodAttribute.class)
.getMultiTermRewriteMethod();
}
return MultiTermQuery.CONSTANT_SCORE_AUTO_REWRITE_DEFAULT;
}
public Resolution getDateResolution(String fieldName) {
if (this.config != null) {
FieldConfig fieldConfig = this.config.getFieldConfig(fieldName);
if (fieldConfig != null) {
if (this.config.hasAttribute(DateResolutionAttribute.class)) {
return this.config.getAttribute(DateResolutionAttribute.class)
.getDateResolution();
}
}
}
return null;
}
public boolean getEnablePositionIncrements() {
if (this.config != null
&& this.config.hasAttribute(PositionIncrementsAttribute.class)) {
return this.config.getAttribute(PositionIncrementsAttribute.class)
.isPositionIncrementsEnabled();
}
return false;
}
public float getFuzzyMinSim() {
return FuzzyQuery.defaultMinSimilarity;
}
public int getFuzzyPrefixLength() {
return FuzzyQuery.defaultPrefixLength;
}
public Locale getLocale() {
if (this.config != null && this.config.hasAttribute(LocaleAttribute.class)) {
return this.config.getAttribute(LocaleAttribute.class).getLocale();
}
return Locale.getDefault();
}
public boolean getLowercaseExpandedTerms() {
if (this.config != null
&& this.config.hasAttribute(LowercaseExpandedTermsAttribute.class)) {
return this.config.getAttribute(LowercaseExpandedTermsAttribute.class)
.isLowercaseExpandedTerms();
}
return true;
}
public int getPhraseSlop() {
if (this.config != null
&& this.config.hasAttribute(AllowLeadingWildcardAttribute.class)) {
return this.config.getAttribute(DefaultPhraseSlopAttribute.class)
.getDefaultPhraseSlop();
}
return 0;
}
public Collator getRangeCollator() {
if (this.config != null
&& this.config.hasAttribute(RangeCollatorAttribute.class)) {
return this.config.getAttribute(RangeCollatorAttribute.class)
.getRangeCollator();
}
return null;
}
public boolean getUseOldRangeQuery() {
if (getMultiTermRewriteMethod() == MultiTermQuery.SCORING_BOOLEAN_QUERY_REWRITE) {
return true;
} else {
return false;
}
}
public Query parse(String query) throws ParseException {
try {
QueryNode queryTree = this.syntaxParser.parse(query, getField());
queryTree = this.processorPipeline.process(queryTree);
return this.builder.build(queryTree);
} catch (QueryNodeException e) {
throw new ParseException("parse exception");
}
}
public void setAllowLeadingWildcard(boolean allowLeadingWildcard) {
this.qpHelper.setAllowLeadingWildcard(allowLeadingWildcard);
}
public void setMultiTermRewriteMethod(MultiTermQuery.RewriteMethod method) {
this.qpHelper.setMultiTermRewriteMethod(method);
}
public void setDateResolution(Resolution dateResolution) {
this.qpHelper.setDateResolution(dateResolution);
}
private Map<CharSequence, DateTools.Resolution> dateRes = new HashMap<CharSequence, DateTools.Resolution>();
public void setDateResolution(String fieldName, Resolution dateResolution) {
dateRes.put(fieldName, dateResolution);
this.qpHelper.setDateResolution(dateRes);
}
public void setDefaultOperator(Operator op) {
this.qpHelper
.setDefaultOperator(OR_OPERATOR.equals(op) ? org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute.Operator.OR
: org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute.Operator.AND);
}
public Operator getDefaultOperator() {
if (this.config != null
&& this.config.hasAttribute(DefaultOperatorAttribute.class)) {
return (this.config.getAttribute(DefaultOperatorAttribute.class)
.getOperator() == org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute.Operator.AND) ? AND_OPERATOR
: OR_OPERATOR;
}
return OR_OPERATOR;
}
public void setEnablePositionIncrements(boolean enable) {
this.qpHelper.setEnablePositionIncrements(enable);
}
public void setFuzzyMinSim(float fuzzyMinSim) {
// TODO Auto-generated method stub
}
public void setFuzzyPrefixLength(int fuzzyPrefixLength) {
// TODO Auto-generated method stub
}
public void setLocale(Locale locale) {
this.qpHelper.setLocale(locale);
}
public void setLowercaseExpandedTerms(boolean lowercaseExpandedTerms) {
this.qpHelper.setLowercaseExpandedTerms(lowercaseExpandedTerms);
}
public void setPhraseSlop(int phraseSlop) {
this.qpHelper.setDefaultPhraseSlop(phraseSlop);
}
public void setRangeCollator(Collator rc) {
this.qpHelper.setRangeCollator(rc);
}
public void setUseOldRangeQuery(boolean useOldRangeQuery) {
if (useOldRangeQuery) {
setMultiTermRewriteMethod(MultiTermQuery.SCORING_BOOLEAN_QUERY_REWRITE);
} else {
setMultiTermRewriteMethod(MultiTermQuery.CONSTANT_SCORE_AUTO_REWRITE_DEFAULT);
}
}
protected Query getPrefixQuery(String field, String termStr)
throws ParseException {
throw new UnsupportedOperationException();
}
protected Query getWildcardQuery(String field, String termStr)
throws ParseException {
throw new UnsupportedOperationException();
}
protected Query getFuzzyQuery(String field, String termStr,
float minSimilarity) throws ParseException {
throw new UnsupportedOperationException();
}
/** @deprecated Use {@link #getFieldQuery(String, String, boolean)} instead */
@Deprecated
protected Query getFieldQuery(String field, String queryText) throws ParseException {
return getFieldQuery(field, queryText, true);
}
/**
* @exception ParseException throw in overridden method to disallow
*/
protected Query getFieldQuery(String field, String queryText, boolean quoted)
throws ParseException {
throw new UnsupportedOperationException();
}
protected Query getBooleanQuery(List<BooleanClause> clauses, boolean disableCoord)
throws ParseException {
throw new UnsupportedOperationException();
}
/**
* Base implementation delegates to {@link #getFieldQuery(String,String)}.
* This method may be overridden, for example, to return a SpanNearQuery
* instead of a PhraseQuery.
*
* @exception ParseException throw in overridden method to disallow
*/
protected Query getFieldQuery(String field, String queryText, int slop)
throws ParseException {
throw new UnsupportedOperationException();
}
/**
* @exception ParseException throw in overridden method to disallow
*/
protected Query getRangeQuery(String field, String part1, String part2,
boolean inclusive) throws ParseException {
throw new UnsupportedOperationException();
}
}

View File

@ -39,12 +39,5 @@ are used to reproduce the same behavior as the old query parser.
Check <tt>org.apache.lucene.queryParser.standard.StandardQueryParser</tt> to quick start using the Lucene query parser. Check <tt>org.apache.lucene.queryParser.standard.StandardQueryParser</tt> to quick start using the Lucene query parser.
</p> </p>
<p>
There are 2 wrapper classes that extends QueryParser and MultiFieldQueryParser.
The classes implement internally the new query parser structure. These 2
classes are deprecated and should only be used when there is a need to use the
old query parser interface.
</p>
</body> </body>
</html> </html>

View File

@ -347,7 +347,7 @@ public class JavaCharStream
@Deprecated @Deprecated
/** /**
* @deprecated * @deprecated (gen)
* @see #getEndColumn * @see #getEndColumn
*/ */
public int getColumn() { public int getColumn() {
@ -356,7 +356,7 @@ public class JavaCharStream
@Deprecated @Deprecated
/** /**
* @deprecated * @deprecated (gen)
* @see #getEndLine * @see #getEndLine
*/ */
public int getLine() { public int getLine() {

View File

@ -24,7 +24,6 @@ import java.util.Date;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
import org.apache.lucene.document.DateField;
import org.apache.lucene.document.DateTools; import org.apache.lucene.document.DateTools;
import org.apache.lucene.document.DateTools.Resolution; import org.apache.lucene.document.DateTools.Resolution;
import org.apache.lucene.queryParser.core.QueryNodeException; import org.apache.lucene.queryParser.core.QueryNodeException;
@ -140,17 +139,8 @@ public class ParametricRangeQueryNodeProcessor extends QueryNodeProcessorImpl {
d2 = cal.getTime(); d2 = cal.getTime();
} }
if (dateRes == null) { part1 = DateTools.dateToString(d1, dateRes);
// no default or field specific date resolution has been set, part2 = DateTools.dateToString(d2, dateRes);
// use deprecated DateField to maintain compatibilty with
// pre-1.9 Lucene versions.
part1 = DateField.dateToString(d1);
part2 = DateField.dateToString(d2);
} else {
part1 = DateTools.dateToString(d1, dateRes);
part2 = DateTools.dateToString(d2, dateRes);
}
} catch (Exception e) { } catch (Exception e) {
// do nothing // do nothing
} }

View File

@ -28,14 +28,14 @@ public interface CharStream {
/** /**
* Returns the column position of the character last read. * Returns the column position of the character last read.
* @deprecated * @deprecated (gen)
* @see #getEndColumn * @see #getEndColumn
*/ */
int getColumn(); int getColumn();
/** /**
* Returns the line number of the character last read. * Returns the line number of the character last read.
* @deprecated * @deprecated (gen)
* @see #getEndLine * @see #getEndLine
*/ */
int getLine(); int getLine();

View File

@ -25,11 +25,11 @@ public class TestQueryNode extends LuceneTestCase {
/* LUCENE-2227 bug in QueryNodeImpl.add() */ /* LUCENE-2227 bug in QueryNodeImpl.add() */
public void testAddChildren() throws Exception { public void testAddChildren() throws Exception {
FieldQueryNode nodeA = new FieldQueryNode("foo", "A", 0, 1); QueryNode nodeA = new FieldQueryNode("foo", "A", 0, 1);
FieldQueryNode nodeB = new FieldQueryNode("foo", "B", 1, 2); QueryNode nodeB = new FieldQueryNode("foo", "B", 1, 2);
BooleanQueryNode bq = new BooleanQueryNode( BooleanQueryNode bq = new BooleanQueryNode(
Arrays.asList(new QueryNode[] { nodeA })); Arrays.asList(nodeA));
bq.add(Arrays.asList(new QueryNode[] { nodeB })); bq.add(Arrays.asList(nodeB));
assertEquals(2, bq.getChildren().size()); assertEquals(2, bq.getChildren().size());
} }
} }

View File

@ -34,7 +34,6 @@ import org.apache.lucene.analysis.TokenFilter;
import org.apache.lucene.analysis.TokenStream; import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.analysis.tokenattributes.OffsetAttribute; import org.apache.lucene.analysis.tokenattributes.OffsetAttribute;
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute; import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
import org.apache.lucene.document.DateField;
import org.apache.lucene.document.DateTools; import org.apache.lucene.document.DateTools;
import org.apache.lucene.queryParser.TestQueryParser; import org.apache.lucene.queryParser.TestQueryParser;
import org.apache.lucene.queryParser.core.QueryNodeException; import org.apache.lucene.queryParser.core.QueryNodeException;
@ -405,19 +404,11 @@ public class TestPrecedenceQueryParser extends LuceneTestCase {
final String hourField = "hour"; final String hourField = "hour";
PrecedenceQueryParser qp = new PrecedenceQueryParser(new MockAnalyzer()); PrecedenceQueryParser qp = new PrecedenceQueryParser(new MockAnalyzer());
// Don't set any date resolution and verify if DateField is used
assertDateRangeQueryEquals(qp, defaultField, startDate, endDate,
endDateExpected.getTime(), null);
Map<CharSequence, DateTools.Resolution> fieldMap = new HashMap<CharSequence,DateTools.Resolution>(); Map<CharSequence, DateTools.Resolution> fieldMap = new HashMap<CharSequence,DateTools.Resolution>();
// set a field specific date resolution // set a field specific date resolution
fieldMap.put(monthField, DateTools.Resolution.MONTH); fieldMap.put(monthField, DateTools.Resolution.MONTH);
qp.setDateResolution(fieldMap); qp.setDateResolution(fieldMap);
// DateField should still be used for defaultField
assertDateRangeQueryEquals(qp, defaultField, startDate, endDate,
endDateExpected.getTime(), null);
// set default date resolution to MILLISECOND // set default date resolution to MILLISECOND
qp.setDateResolution(DateTools.Resolution.MILLISECOND); qp.setDateResolution(DateTools.Resolution.MILLISECOND);
@ -439,20 +430,14 @@ public class TestPrecedenceQueryParser extends LuceneTestCase {
} }
/** for testing DateTools support */ /** for testing DateTools support */
private String getDate(String s, DateTools.Resolution resolution) private String getDate(String s, DateTools.Resolution resolution) throws Exception {
throws Exception {
DateFormat df = DateFormat.getDateInstance(DateFormat.SHORT); DateFormat df = DateFormat.getDateInstance(DateFormat.SHORT);
return getDate(df.parse(s), resolution); return getDate(df.parse(s), resolution);
} }
/** for testing DateTools support */ /** for testing DateTools support */
private String getDate(Date d, DateTools.Resolution resolution) private String getDate(Date d, DateTools.Resolution resolution) throws Exception {
throws Exception { return DateTools.dateToString(d, resolution);
if (resolution == null) {
return DateField.dateToString(d);
} else {
return DateTools.dateToString(d, resolution);
}
} }
public void assertQueryEquals(PrecedenceQueryParser qp, String field, String query, public void assertQueryEquals(PrecedenceQueryParser qp, String field, String query,

View File

@ -1,245 +0,0 @@
package org.apache.lucene.queryParser.standard;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.io.Reader;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.MockTokenizer;
import org.apache.lucene.analysis.TokenFilter;
import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
import org.apache.lucene.analysis.tokenattributes.OffsetAttribute;
import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute;
import org.apache.lucene.analysis.tokenattributes.TypeAttribute;
import org.apache.lucene.queryParser.ParseException;
import org.apache.lucene.util.LuceneTestCase;
/**
* This test case is a copy of the core Lucene query parser test, it was adapted
* to use new QueryParserWrapper instead of the old query parser.
*
* Test QueryParser's ability to deal with Analyzers that return more than one
* token per position or that return tokens with a position increment &gt; 1.
*
*/
public class TestMultiAnalyzerWrapper extends LuceneTestCase {
private static int multiToken = 0;
public void testMultiAnalyzer() throws ParseException {
QueryParserWrapper qp = new QueryParserWrapper("", new MultiAnalyzer());
// trivial, no multiple tokens:
assertEquals("foo", qp.parse("foo").toString());
assertEquals("foo", qp.parse("\"foo\"").toString());
assertEquals("foo foobar", qp.parse("foo foobar").toString());
assertEquals("\"foo foobar\"", qp.parse("\"foo foobar\"").toString());
assertEquals("\"foo foobar blah\"", qp.parse("\"foo foobar blah\"")
.toString());
// two tokens at the same position:
assertEquals("(multi multi2) foo", qp.parse("multi foo").toString());
assertEquals("foo (multi multi2)", qp.parse("foo multi").toString());
assertEquals("(multi multi2) (multi multi2)", qp.parse("multi multi")
.toString());
assertEquals("+(foo (multi multi2)) +(bar (multi multi2))", qp.parse(
"+(foo multi) +(bar multi)").toString());
assertEquals("+(foo (multi multi2)) field:\"bar (multi multi2)\"", qp
.parse("+(foo multi) field:\"bar multi\"").toString());
// phrases:
assertEquals("\"(multi multi2) foo\"", qp.parse("\"multi foo\"").toString());
assertEquals("\"foo (multi multi2)\"", qp.parse("\"foo multi\"").toString());
assertEquals("\"foo (multi multi2) foobar (multi multi2)\"", qp.parse(
"\"foo multi foobar multi\"").toString());
// fields:
assertEquals("(field:multi field:multi2) field:foo", qp.parse(
"field:multi field:foo").toString());
assertEquals("field:\"(multi multi2) foo\"", qp
.parse("field:\"multi foo\"").toString());
// three tokens at one position:
assertEquals("triplemulti multi3 multi2", qp.parse("triplemulti")
.toString());
assertEquals("foo (triplemulti multi3 multi2) foobar", qp.parse(
"foo triplemulti foobar").toString());
// phrase with non-default slop:
assertEquals("\"(multi multi2) foo\"~10", qp.parse("\"multi foo\"~10")
.toString());
// phrase with non-default boost:
assertEquals("\"(multi multi2) foo\"^2.0", qp.parse("\"multi foo\"^2")
.toString());
// phrase after changing default slop
qp.setPhraseSlop(99);
assertEquals("\"(multi multi2) foo\"~99 bar", qp.parse("\"multi foo\" bar")
.toString());
assertEquals("\"(multi multi2) foo\"~99 \"foo bar\"~2", qp.parse(
"\"multi foo\" \"foo bar\"~2").toString());
qp.setPhraseSlop(0);
// non-default operator:
qp.setDefaultOperator(QueryParserWrapper.AND_OPERATOR);
assertEquals("+(multi multi2) +foo", qp.parse("multi foo").toString());
}
// public void testMultiAnalyzerWithSubclassOfQueryParser() throws
// ParseException {
// this test doesn't make sense when using the new QueryParser API
// DumbQueryParser qp = new DumbQueryParser("", new MultiAnalyzer());
// qp.setPhraseSlop(99); // modified default slop
//
// // direct call to (super's) getFieldQuery to demonstrate differnce
// // between phrase and multiphrase with modified default slop
// assertEquals("\"foo bar\"~99",
// qp.getSuperFieldQuery("","foo bar").toString());
// assertEquals("\"(multi multi2) bar\"~99",
// qp.getSuperFieldQuery("","multi bar").toString());
//
//
// // ask sublcass to parse phrase with modified default slop
// assertEquals("\"(multi multi2) foo\"~99 bar",
// qp.parse("\"multi foo\" bar").toString());
//
// }
public void testPosIncrementAnalyzer() throws ParseException {
QueryParserWrapper qp = new QueryParserWrapper("",
new PosIncrementAnalyzer());
assertEquals("quick brown", qp.parse("the quick brown").toString());
assertEquals("\"quick brown\"", qp.parse("\"the quick brown\"").toString());
assertEquals("quick brown fox", qp.parse("the quick brown fox").toString());
assertEquals("\"quick brown fox\"", qp.parse("\"the quick brown fox\"")
.toString());
}
/**
* Expands "multi" to "multi" and "multi2", both at the same position, and
* expands "triplemulti" to "triplemulti", "multi3", and "multi2".
*/
private class MultiAnalyzer extends Analyzer {
public MultiAnalyzer() {
}
@Override
public TokenStream tokenStream(String fieldName, Reader reader) {
TokenStream result = new MockTokenizer(reader, MockTokenizer.WHITESPACE, true);
result = new TestFilter(result);
return result;
}
}
private final class TestFilter extends TokenFilter {
private String prevType;
private int prevStartOffset;
private int prevEndOffset;
private final CharTermAttribute termAtt = addAttribute(CharTermAttribute.class);
private final PositionIncrementAttribute posIncrAtt = addAttribute(PositionIncrementAttribute.class);
private final OffsetAttribute offsetAtt = addAttribute(OffsetAttribute.class);
private final TypeAttribute typeAtt = addAttribute(TypeAttribute.class);
public TestFilter(TokenStream in) {
super(in);
}
@Override
public final boolean incrementToken() throws java.io.IOException {
if (multiToken > 0) {
termAtt.setEmpty().append("multi" + (multiToken + 1));
offsetAtt.setOffset(prevStartOffset, prevEndOffset);
typeAtt.setType(prevType);
posIncrAtt.setPositionIncrement(0);
multiToken--;
return true;
} else {
boolean next = input.incrementToken();
if (next == false) {
return false;
}
prevType = typeAtt.type();
prevStartOffset = offsetAtt.startOffset();
prevEndOffset = offsetAtt.endOffset();
String text = termAtt.toString();
if (text.equals("triplemulti")) {
multiToken = 2;
return true;
} else if (text.equals("multi")) {
multiToken = 1;
return true;
} else {
return true;
}
}
}
}
/**
* Analyzes "the quick brown" as: quick(incr=2) brown(incr=1). Does not work
* correctly for input other than "the quick brown ...".
*/
private class PosIncrementAnalyzer extends Analyzer {
public PosIncrementAnalyzer() {
}
@Override
public TokenStream tokenStream(String fieldName, Reader reader) {
TokenStream result = new MockTokenizer(reader, MockTokenizer.WHITESPACE, true);
result = new TestPosIncrementFilter(result);
return result;
}
}
private class TestPosIncrementFilter extends TokenFilter {
private final CharTermAttribute termAtt = addAttribute(CharTermAttribute.class);
private final PositionIncrementAttribute posIncrAtt = addAttribute(PositionIncrementAttribute.class);
public TestPosIncrementFilter(TokenStream in) {
super(in);
}
@Override
public final boolean incrementToken() throws java.io.IOException {
while (input.incrementToken()) {
if (termAtt.toString().equals("the")) {
// stopword, do nothing
} else if (termAtt.toString().equals("quick")) {
posIncrAtt.setPositionIncrement(2);
return true;
} else {
posIncrAtt.setPositionIncrement(1);
return true;
}
}
return false;
}
}
}

View File

@ -1,370 +0,0 @@
package org.apache.lucene.queryParser.standard;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.io.Reader;
import java.util.HashMap;
import java.util.Map;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.analysis.MockAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.queryParser.ParseException;
import org.apache.lucene.queryParser.standard.MultiFieldQueryParserWrapper;
import org.apache.lucene.queryParser.standard.QueryParserWrapper;
import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.BooleanClause.Occur;
import org.apache.lucene.store.Directory;
import org.apache.lucene.util.LuceneTestCase;
/**
* Tests multi field query parsing using the
* {@link MultiFieldQueryParserWrapper}.
*
* @deprecated this tests test the deprecated MultiFieldQueryParserWrapper, so
* when the latter is gone, so should this test.
*/
@Deprecated
public class TestMultiFieldQueryParserWrapper extends LuceneTestCase {
/**
* test stop words parsing for both the non static form, and for the
* corresponding static form (qtxt, fields[]).
*/
public void testStopwordsParsing() throws Exception {
assertStopQueryEquals("one", "b:one t:one");
assertStopQueryEquals("one stop", "b:one t:one");
assertStopQueryEquals("one (stop)", "b:one t:one");
assertStopQueryEquals("one ((stop))", "b:one t:one");
assertStopQueryEquals("stop", "");
assertStopQueryEquals("(stop)", "");
assertStopQueryEquals("((stop))", "");
}
// verify parsing of query using a stopping analyzer
private void assertStopQueryEquals(String qtxt, String expectedRes)
throws Exception {
String[] fields = { "b", "t" };
Occur occur[] = { Occur.SHOULD, Occur.SHOULD };
TestQueryParserWrapper.QPTestAnalyzer a = new TestQueryParserWrapper.QPTestAnalyzer();
MultiFieldQueryParserWrapper mfqp = new MultiFieldQueryParserWrapper(
fields, a);
Query q = mfqp.parse(qtxt);
assertEquals(expectedRes, q.toString());
q = MultiFieldQueryParserWrapper.parse(qtxt, fields, occur, a);
assertEquals(expectedRes, q.toString());
}
public void testSimple() throws Exception {
String[] fields = { "b", "t" };
MultiFieldQueryParserWrapper mfqp = new MultiFieldQueryParserWrapper(
fields, new MockAnalyzer());
Query q = mfqp.parse("one");
assertEquals("b:one t:one", q.toString());
q = mfqp.parse("one two");
assertEquals("(b:one t:one) (b:two t:two)", q.toString());
q = mfqp.parse("+one +two");
assertEquals("+(b:one t:one) +(b:two t:two)", q.toString());
q = mfqp.parse("+one -two -three");
assertEquals("+(b:one t:one) -(b:two t:two) -(b:three t:three)", q
.toString());
q = mfqp.parse("one^2 two");
assertEquals("((b:one t:one)^2.0) (b:two t:two)", q.toString());
q = mfqp.parse("one~ two");
assertEquals("(b:one~2.0 t:one~2.0) (b:two t:two)", q.toString());
q = mfqp.parse("one~0.8 two^2");
assertEquals("(b:one~0.8 t:one~0.8) ((b:two t:two)^2.0)", q.toString());
q = mfqp.parse("one* two*");
assertEquals("(b:one* t:one*) (b:two* t:two*)", q.toString());
q = mfqp.parse("[a TO c] two");
assertEquals("(b:[a TO c] t:[a TO c]) (b:two t:two)", q.toString());
q = mfqp.parse("w?ldcard");
assertEquals("b:w?ldcard t:w?ldcard", q.toString());
q = mfqp.parse("\"foo bar\"");
assertEquals("b:\"foo bar\" t:\"foo bar\"", q.toString());
q = mfqp.parse("\"aa bb cc\" \"dd ee\"");
assertEquals("(b:\"aa bb cc\" t:\"aa bb cc\") (b:\"dd ee\" t:\"dd ee\")", q
.toString());
q = mfqp.parse("\"foo bar\"~4");
assertEquals("b:\"foo bar\"~4 t:\"foo bar\"~4", q.toString());
// LUCENE-1213: MultiFieldQueryParserWrapper was ignoring slop when phrase
// had a field.
q = mfqp.parse("b:\"foo bar\"~4");
assertEquals("b:\"foo bar\"~4", q.toString());
// make sure that terms which have a field are not touched:
q = mfqp.parse("one f:two");
assertEquals("(b:one t:one) f:two", q.toString());
// AND mode:
mfqp.setDefaultOperator(QueryParserWrapper.AND_OPERATOR);
q = mfqp.parse("one two");
assertEquals("+(b:one t:one) +(b:two t:two)", q.toString());
q = mfqp.parse("\"aa bb cc\" \"dd ee\"");
assertEquals("+(b:\"aa bb cc\" t:\"aa bb cc\") +(b:\"dd ee\" t:\"dd ee\")",
q.toString());
}
public void testBoostsSimple() throws Exception {
Map<String,Float> boosts = new HashMap<String,Float>();
boosts.put("b", Float.valueOf(5));
boosts.put("t", Float.valueOf(10));
String[] fields = { "b", "t" };
MultiFieldQueryParserWrapper mfqp = new MultiFieldQueryParserWrapper(
fields, new MockAnalyzer(), boosts);
// Check for simple
Query q = mfqp.parse("one");
assertEquals("b:one^5.0 t:one^10.0", q.toString());
// Check for AND
q = mfqp.parse("one AND two");
assertEquals("+(b:one^5.0 t:one^10.0) +(b:two^5.0 t:two^10.0)", q
.toString());
// Check for OR
q = mfqp.parse("one OR two");
assertEquals("(b:one^5.0 t:one^10.0) (b:two^5.0 t:two^10.0)", q.toString());
// Check for AND and a field
q = mfqp.parse("one AND two AND foo:test");
assertEquals("+(b:one^5.0 t:one^10.0) +(b:two^5.0 t:two^10.0) +foo:test", q
.toString());
q = mfqp.parse("one^3 AND two^4");
assertEquals("+((b:one^5.0 t:one^10.0)^3.0) +((b:two^5.0 t:two^10.0)^4.0)",
q.toString());
}
public void testStaticMethod1() throws ParseException {
String[] fields = { "b", "t" };
String[] queries = { "one", "two" };
Query q = MultiFieldQueryParserWrapper.parse(queries, fields,
new MockAnalyzer());
assertEquals("b:one t:two", q.toString());
String[] queries2 = { "+one", "+two" };
q = MultiFieldQueryParserWrapper.parse(queries2, fields,
new MockAnalyzer());
assertEquals("(+b:one) (+t:two)", q.toString());
String[] queries3 = { "one", "+two" };
q = MultiFieldQueryParserWrapper.parse(queries3, fields,
new MockAnalyzer());
assertEquals("b:one (+t:two)", q.toString());
String[] queries4 = { "one +more", "+two" };
q = MultiFieldQueryParserWrapper.parse(queries4, fields,
new MockAnalyzer());
assertEquals("(b:one +b:more) (+t:two)", q.toString());
String[] queries5 = { "blah" };
try {
q = MultiFieldQueryParserWrapper.parse(queries5, fields,
new MockAnalyzer());
fail();
} catch (IllegalArgumentException e) {
// expected exception, array length differs
}
// check also with stop words for this static form (qtxts[], fields[]).
TestQueryParserWrapper.QPTestAnalyzer stopA = new TestQueryParserWrapper.QPTestAnalyzer();
String[] queries6 = { "((+stop))", "+((stop))" };
q = MultiFieldQueryParserWrapper.parse(queries6, fields, stopA);
assertEquals("", q.toString());
String[] queries7 = { "one ((+stop)) +more", "+((stop)) +two" };
q = MultiFieldQueryParserWrapper.parse(queries7, fields, stopA);
assertEquals("(b:one +b:more) (+t:two)", q.toString());
}
public void testStaticMethod2() throws ParseException {
String[] fields = { "b", "t" };
BooleanClause.Occur[] flags = { BooleanClause.Occur.MUST,
BooleanClause.Occur.MUST_NOT };
Query q = MultiFieldQueryParserWrapper.parse("one", fields, flags,
new MockAnalyzer());
assertEquals("+b:one -t:one", q.toString());
q = MultiFieldQueryParserWrapper.parse("one two", fields, flags,
new MockAnalyzer());
assertEquals("+(b:one b:two) -(t:one t:two)", q.toString());
try {
BooleanClause.Occur[] flags2 = { BooleanClause.Occur.MUST };
q = MultiFieldQueryParserWrapper.parse("blah", fields, flags2,
new MockAnalyzer());
fail();
} catch (IllegalArgumentException e) {
// expected exception, array length differs
}
}
public void testStaticMethod2Old() throws ParseException {
String[] fields = { "b", "t" };
// int[] flags = {MultiFieldQueryParserWrapper.REQUIRED_FIELD,
// MultiFieldQueryParserWrapper.PROHIBITED_FIELD};
BooleanClause.Occur[] flags = { BooleanClause.Occur.MUST,
BooleanClause.Occur.MUST_NOT };
Query q = MultiFieldQueryParserWrapper.parse("one", fields, flags,
new MockAnalyzer());// , fields, flags, new MockAnalyzer());
assertEquals("+b:one -t:one", q.toString());
q = MultiFieldQueryParserWrapper.parse("one two", fields, flags,
new MockAnalyzer());
assertEquals("+(b:one b:two) -(t:one t:two)", q.toString());
try {
BooleanClause.Occur[] flags2 = { BooleanClause.Occur.MUST };
q = MultiFieldQueryParserWrapper.parse("blah", fields, flags2,
new MockAnalyzer());
fail();
} catch (IllegalArgumentException e) {
// expected exception, array length differs
}
}
public void testStaticMethod3() throws ParseException {
String[] queries = { "one", "two", "three" };
String[] fields = { "f1", "f2", "f3" };
BooleanClause.Occur[] flags = { BooleanClause.Occur.MUST,
BooleanClause.Occur.MUST_NOT, BooleanClause.Occur.SHOULD };
Query q = MultiFieldQueryParserWrapper.parse(queries, fields, flags,
new MockAnalyzer());
assertEquals("+f1:one -f2:two f3:three", q.toString());
try {
BooleanClause.Occur[] flags2 = { BooleanClause.Occur.MUST };
q = MultiFieldQueryParserWrapper.parse(queries, fields, flags2,
new MockAnalyzer());
fail();
} catch (IllegalArgumentException e) {
// expected exception, array length differs
}
}
public void testStaticMethod3Old() throws ParseException {
String[] queries = { "one", "two" };
String[] fields = { "b", "t" };
BooleanClause.Occur[] flags = { BooleanClause.Occur.MUST,
BooleanClause.Occur.MUST_NOT };
Query q = MultiFieldQueryParserWrapper.parse(queries, fields, flags,
new MockAnalyzer());
assertEquals("+b:one -t:two", q.toString());
try {
BooleanClause.Occur[] flags2 = { BooleanClause.Occur.MUST };
q = MultiFieldQueryParserWrapper.parse(queries, fields, flags2,
new MockAnalyzer());
fail();
} catch (IllegalArgumentException e) {
// expected exception, array length differs
}
}
public void testAnalyzerReturningNull() throws ParseException {
String[] fields = new String[] { "f1", "f2", "f3" };
MultiFieldQueryParserWrapper parser = new MultiFieldQueryParserWrapper(
fields, new AnalyzerReturningNull());
Query q = parser.parse("bla AND blo");
assertEquals("+(f2:bla f3:bla) +(f2:blo f3:blo)", q.toString());
// the following queries are not affected as their terms are not analyzed
// anyway:
q = parser.parse("bla*");
assertEquals("f1:bla* f2:bla* f3:bla*", q.toString());
q = parser.parse("bla~");
assertEquals("f1:bla~2.0 f2:bla~2.0 f3:bla~2.0", q.toString());
q = parser.parse("[a TO c]");
assertEquals("f1:[a TO c] f2:[a TO c] f3:[a TO c]", q.toString());
}
public void testStopWordSearching() throws Exception {
Analyzer analyzer = new MockAnalyzer();
Directory ramDir = newDirectory();
IndexWriter iw = new IndexWriter(ramDir, analyzer, true,
IndexWriter.MaxFieldLength.LIMITED);
Document doc = new Document();
doc.add(newField("body", "blah the footest blah", Field.Store.NO,
Field.Index.ANALYZED));
iw.addDocument(doc);
iw.close();
MultiFieldQueryParserWrapper mfqp = new MultiFieldQueryParserWrapper(
new String[] { "body" }, analyzer);
mfqp.setDefaultOperator(QueryParserWrapper.Operator.AND);
Query q = mfqp.parse("the footest");
IndexSearcher is = new IndexSearcher(ramDir, true);
ScoreDoc[] hits = is.search(q, null, 1000).scoreDocs;
assertEquals(1, hits.length);
is.close();
ramDir.close();
}
/**
* Return empty tokens for field "f1".
*/
private static class AnalyzerReturningNull extends Analyzer {
MockAnalyzer stdAnalyzer = new MockAnalyzer();
public AnalyzerReturningNull() {
}
@Override
public TokenStream tokenStream(String fieldName, Reader reader) {
if ("f1".equals(fieldName)) {
return new EmptyTokenStream();
} else {
return stdAnalyzer.tokenStream(fieldName, reader);
}
}
private static class EmptyTokenStream extends TokenStream {
@Override
public boolean incrementToken() {
return false;
}
}
}
}

View File

@ -39,7 +39,6 @@ import org.apache.lucene.analysis.Tokenizer;
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute; import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
import org.apache.lucene.analysis.tokenattributes.OffsetAttribute; import org.apache.lucene.analysis.tokenattributes.OffsetAttribute;
import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute; import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute;
import org.apache.lucene.document.DateField;
import org.apache.lucene.document.DateTools; import org.apache.lucene.document.DateTools;
import org.apache.lucene.document.Document; import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field; import org.apache.lucene.document.Field;
@ -692,12 +691,6 @@ public class TestQPHelper extends LuceneTestCase {
ramDir.close(); ramDir.close();
} }
/** for testing legacy DateField support */
private String getLegacyDate(String s) throws Exception {
DateFormat df = DateFormat.getDateInstance(DateFormat.SHORT);
return DateField.dateToString(df.parse(s));
}
/** for testing DateTools support */ /** for testing DateTools support */
private String getDate(String s, DateTools.Resolution resolution) private String getDate(String s, DateTools.Resolution resolution)
throws Exception { throws Exception {
@ -708,11 +701,7 @@ public class TestQPHelper extends LuceneTestCase {
/** for testing DateTools support */ /** for testing DateTools support */
private String getDate(Date d, DateTools.Resolution resolution) private String getDate(Date d, DateTools.Resolution resolution)
throws Exception { throws Exception {
if (resolution == null) { return DateTools.dateToString(d, resolution);
return DateField.dateToString(d);
} else {
return DateTools.dateToString(d, resolution);
}
} }
private String escapeDateString(String s) { private String escapeDateString(String s) {
@ -735,21 +724,6 @@ public class TestQPHelper extends LuceneTestCase {
return df.format(calendar.getTime()); return df.format(calendar.getTime());
} }
/** for testing legacy DateField support */
public void testLegacyDateRange() throws Exception {
String startDate = getLocalizedDate(2002, 1, 1);
String endDate = getLocalizedDate(2002, 1, 4);
Calendar endDateExpected = new GregorianCalendar();
endDateExpected.clear();
endDateExpected.set(2002, 1, 4, 23, 59, 59);
endDateExpected.set(Calendar.MILLISECOND, 999);
assertQueryEquals("[ " + escapeDateString(startDate) + " TO " + escapeDateString(endDate) + "]", null, "["
+ getLegacyDate(startDate) + " TO "
+ DateField.dateToString(endDateExpected.getTime()) + "]");
assertQueryEquals("{ " + escapeDateString(startDate) + " " + escapeDateString(endDate) + " }", null, "{"
+ getLegacyDate(startDate) + " TO " + getLegacyDate(endDate) + "}");
}
public void testDateRange() throws Exception { public void testDateRange() throws Exception {
String startDate = getLocalizedDate(2002, 1, 1); String startDate = getLocalizedDate(2002, 1, 1);
String endDate = getLocalizedDate(2002, 1, 4); String endDate = getLocalizedDate(2002, 1, 4);
@ -762,20 +736,12 @@ public class TestQPHelper extends LuceneTestCase {
final String hourField = "hour"; final String hourField = "hour";
StandardQueryParser qp = new StandardQueryParser(); StandardQueryParser qp = new StandardQueryParser();
// Don't set any date resolution and verify if DateField is used
assertDateRangeQueryEquals(qp, defaultField, startDate, endDate,
endDateExpected.getTime(), null);
Map<CharSequence, DateTools.Resolution> dateRes = new HashMap<CharSequence, DateTools.Resolution>(); Map<CharSequence, DateTools.Resolution> dateRes = new HashMap<CharSequence, DateTools.Resolution>();
// set a field specific date resolution // set a field specific date resolution
dateRes.put(monthField, DateTools.Resolution.MONTH); dateRes.put(monthField, DateTools.Resolution.MONTH);
qp.setDateResolution(dateRes); qp.setDateResolution(dateRes);
// DateField should still be used for defaultField
assertDateRangeQueryEquals(qp, defaultField, startDate, endDate,
endDateExpected.getTime(), null);
// set default date resolution to MILLISECOND // set default date resolution to MILLISECOND
qp.setDateResolution(DateTools.Resolution.MILLISECOND); qp.setDateResolution(DateTools.Resolution.MILLISECOND);
@ -1075,22 +1041,35 @@ public class TestQPHelper extends LuceneTestCase {
assertEquals(query1, query2); assertEquals(query1, query2);
} }
public void testLocalDateFormat() throws IOException, QueryNodeException { // Todo (nocommit): Convert from DateField to DateUtil
Directory ramDir = newDirectory(); // public void testLocalDateFormat() throws IOException, QueryNodeException {
IndexWriter iw = new IndexWriter(ramDir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer(MockTokenizer.WHITESPACE, false))); // Directory ramDir = newDirectory();
addDateDoc("a", 2005, 12, 2, 10, 15, 33, iw); // IndexWriter iw = new IndexWriter(ramDir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer(MockTokenizer.WHITESPACE, false)));
addDateDoc("b", 2005, 12, 4, 22, 15, 00, iw); // addDateDoc("a", 2005, 12, 2, 10, 15, 33, iw);
iw.close(); // addDateDoc("b", 2005, 12, 4, 22, 15, 00, iw);
IndexSearcher is = new IndexSearcher(ramDir, true); // iw.close();
assertHits(1, "[12/1/2005 TO 12/3/2005]", is); // IndexSearcher is = new IndexSearcher(ramDir, true);
assertHits(2, "[12/1/2005 TO 12/4/2005]", is); // assertHits(1, "[12/1/2005 TO 12/3/2005]", is);
assertHits(1, "[12/3/2005 TO 12/4/2005]", is); // assertHits(2, "[12/1/2005 TO 12/4/2005]", is);
assertHits(1, "{12/1/2005 TO 12/3/2005}", is); // assertHits(1, "[12/3/2005 TO 12/4/2005]", is);
assertHits(1, "{12/1/2005 TO 12/4/2005}", is); // assertHits(1, "{12/1/2005 TO 12/3/2005}", is);
assertHits(0, "{12/3/2005 TO 12/4/2005}", is); // assertHits(1, "{12/1/2005 TO 12/4/2005}", is);
is.close(); // assertHits(0, "{12/3/2005 TO 12/4/2005}", is);
ramDir.close(); // is.close();
} // ramDir.close();
// }
//
// private void addDateDoc(String content, int year, int month, int day,
// int hour, int minute, int second, IndexWriter iw) throws IOException {
// Document d = new Document();
// d.add(newField("f", content, Field.Store.YES, Field.Index.ANALYZED));
// Calendar cal = Calendar.getInstance(Locale.ENGLISH);
// cal.set(year, month - 1, day, hour, minute, second);
// d.add(newField("date", DateField.dateToString(cal.getTime()),
// Field.Store.YES, Field.Index.NOT_ANALYZED));
// iw.addDocument(d);
// }
public void testStarParsing() throws Exception { public void testStarParsing() throws Exception {
// final int[] type = new int[1]; // final int[] type = new int[1];
@ -1251,17 +1230,6 @@ public class TestQPHelper extends LuceneTestCase {
assertEquals(expected, hits.length); assertEquals(expected, hits.length);
} }
private void addDateDoc(String content, int year, int month, int day,
int hour, int minute, int second, IndexWriter iw) throws IOException {
Document d = new Document();
d.add(newField("f", content, Field.Store.YES, Field.Index.ANALYZED));
Calendar cal = Calendar.getInstance(Locale.ENGLISH);
cal.set(year, month - 1, day, hour, minute, second);
d.add(newField("date", DateField.dateToString(cal.getTime()),
Field.Store.YES, Field.Index.NOT_ANALYZED));
iw.addDocument(d);
}
@Override @Override
public void tearDown() throws Exception { public void tearDown() throws Exception {
BooleanQuery.setMaxClauseCount(originalMaxClauses); BooleanQuery.setMaxClauseCount(originalMaxClauses);

View File

@ -76,7 +76,7 @@ public class TestRemoteSearchable extends RemoteTestCase {
document = searcher.doc(0, fs); document = searcher.doc(0, fs);
assertTrue("document is null and it shouldn't be", document != null); assertTrue("document is null and it shouldn't be", document != null);
assertTrue("document.getFields() Size: " + document.getFields().size() + " is not: " + 1, document.getFields().size() == 1); assertTrue("document.getFields() Size: " + document.getFields().size() + " is not: " + 1, document.getFields().size() == 1);
fs = new MapFieldSelector(new String[]{"other"}); fs = new MapFieldSelector("other");
document = searcher.doc(0, fs); document = searcher.doc(0, fs);
assertTrue("document is null and it shouldn't be", document != null); assertTrue("document is null and it shouldn't be", document != null);
assertTrue("document.getFields() Size: " + document.getFields().size() + " is not: " + 1, document.getFields().size() == 1); assertTrue("document.getFields() Size: " + document.getFields().size() + " is not: " + 1, document.getFields().size() == 1);

View File

@ -84,10 +84,12 @@ public class TestRemoteSort extends RemoteTestCase {
@BeforeClass @BeforeClass
public static void beforeClass() throws Exception { public static void beforeClass() throws Exception {
indexStore = newDirectory(); indexStore = newDirectory();
IndexWriter writer = new IndexWriter(indexStore, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) indexStore,
.setMaxBufferedDocs(2)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(1000); setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(1000))
);
for (int i=0; i<data.length; ++i) { for (int i=0; i<data.length; ++i) {
Document doc = new Document(); Document doc = new Document();
doc.add (new Field ("tracer", data[i][0], Field.Store.YES, Field.Index.NO)); doc.add (new Field ("tracer", data[i][0], Field.Store.YES, Field.Index.NO));
@ -217,7 +219,7 @@ public class TestRemoteSort extends RemoteTestCase {
@Test @Test
public void testRemoteSort() throws Exception { public void testRemoteSort() throws Exception {
Searchable searcher = lookupRemote(); Searchable searcher = lookupRemote();
MultiSearcher multi = new MultiSearcher (new Searchable[] { searcher }); MultiSearcher multi = new MultiSearcher (searcher);
runMultiSorts(multi, true); // this runs on the full index runMultiSorts(multi, true); // this runs on the full index
} }
@ -255,7 +257,7 @@ public class TestRemoteSort extends RemoteTestCase {
HashMap<String,Float> scoresA = getScores (full.search (queryA, null, 1000).scoreDocs, full); HashMap<String,Float> scoresA = getScores (full.search (queryA, null, 1000).scoreDocs, full);
// we'll test searching locally, remote and multi // we'll test searching locally, remote and multi
MultiSearcher remote = new MultiSearcher (new Searchable[] { lookupRemote() }); MultiSearcher remote = new MultiSearcher (lookupRemote());
// change sorting and make sure relevancy stays the same // change sorting and make sure relevancy stays the same

View File

@ -1,126 +0,0 @@
/**
* 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.spatial.geometry.shape;
/**
* Imported from mq java client. No changes made.
*
* <p><font color="red"><b>NOTE:</b> This API is still in
* flux and might change in incompatible ways in the next
* release.</font>
*
* @deprecated This has been replaced with more accurate
* math in {@link LLRect}. This class will be removed in a future release.
*/
@Deprecated
public class DistanceApproximation
{
private double m_testLat;
private double m_testLng;
private double m_mpd;
private static final double m_milesPerLngDeg[]={
69.170976f, 69.160441f, 69.128838f, 69.076177f, 69.002475f,
68.907753f, 68.792041f, 68.655373f, 68.497792f, 68.319345f,
68.120088f, 67.900079f, 67.659387f, 67.398085f, 67.116253f,
66.813976f, 66.491346f, 66.148462f, 65.785428f, 65.402355f,
64.999359f, 64.576564f, 64.134098f, 63.672096f, 63.190698f,
62.690052f, 62.170310f, 61.631630f, 61.074176f, 60.498118f,
59.903632f, 59.290899f, 58.660106f, 58.011443f, 57.345111f,
56.661310f, 55.960250f, 55.242144f, 54.507211f, 53.755675f,
52.987764f, 52.203713f, 51.403761f, 50.588151f, 49.757131f,
48.910956f, 48.049882f, 47.174172f, 46.284093f, 45.379915f,
44.461915f, 43.530372f, 42.585570f, 41.627796f, 40.657342f,
39.674504f, 38.679582f, 37.672877f, 36.654698f, 35.625354f,
34.585159f, 33.534429f, 32.473485f, 31.402650f, 30.322249f,
29.232613f, 28.134073f, 27.026963f, 25.911621f, 24.788387f,
23.657602f, 22.519612f, 21.374762f, 20.223401f, 19.065881f,
17.902554f, 16.733774f, 15.559897f, 14.381280f, 13.198283f,
12.011266f, 10.820591f, 9.626619f, 8.429716f, 7.230245f,
6.028572f, 4.825062f, 3.620083f, 2.414002f, 1.207185f,
1.000000f};
public static final double MILES_PER_LATITUDE = 69.170976f;
public static final double KILOMETERS_PER_MILE = 1.609347f;
public DistanceApproximation()
{
}
public void setTestPoint(double lat, double lng)
{
m_testLat = lat;
m_testLng = lng;
m_mpd = m_milesPerLngDeg[(int)(Math.abs(lat) + 0.5f)];
}
// Approximate arc distance between 2 lat,lng positions using miles per
// latitude and longitude degree
public double getDistanceSq(double lat, double lng)
{
double latMiles = (lat - m_testLat) * MILES_PER_LATITUDE;
// Approximate longitude miles using the miles per degree assuming the
// middle latitude/longitude. This is less accurate at high (near
// polar) latitudes but no road network is present at the poles!
// If we ever have any roads crossing the international date we will
// have to worry about that case.
double lngMiles = (lng - m_testLng) * m_mpd;
// Find the squared distance by the Pythagorean theorem (without sqrt)
return (latMiles * latMiles + lngMiles * lngMiles);
}
// Approximate arc distance between a segment (with lat,lng endpoints) and
// the test position
public double getDistanceSq(double lat1, double lng1, double lat2, double lng2)
{
// Check if lat1,lng1 is closest point. Construct a vector from point1
// to point2 (v1) and another from point 1 to the test point (v2).
// If dot product is negative then point 1 is the closest point
double v1y = lat2 - lat1;
double v1x = lng2 - lng1;
double v2y = m_testLat - lat1;
double v2x = m_testLng - lng1;
double dot = v1x * v2x + v1y * v2y;
if (dot <= 0.0f)
return getDistanceSq(lat1, lng1);
// Get the component of vector v2 along v1. If component is greater
// than 1 then the endpoint is the closest point.
double c = dot / (v1x * v1x + v1y * v1y);
if (c >= 1.0f)
return getDistanceSq(lat2, lng2);
// Since we are working io lat,lng space we need to find the point
// along p1->p2 such that q->pt is perpendicular to p1->p2. We
// then find the distance squared between Q and pt.
return getDistanceSq((lat1 + v1y * c), (lng1 + v1x * c));
}
// Return the number of miles per degree of longitude
public static double getMilesPerLngDeg(double lat)
{
return (Math.abs(lat) <= 90.0) ? m_milesPerLngDeg[(int)(Math.abs(lat) + 0.5f)] : 69.170976f;
}
public static double getMilesPerLatDeg() {
return MILES_PER_LATITUDE;
}
}

View File

@ -28,7 +28,7 @@ package org.apache.lucene.spatial.tier.projections;
* flux and might change in incompatible ways in the next * flux and might change in incompatible ways in the next
* release.</font> * release.</font>
* *
* @deprecated Until we can put in place proper tests and a proper fix. * @deprecated (3.1) Until we can put in place proper tests and a proper fix.
*/ */
@Deprecated @Deprecated
public class SinusoidalProjector implements IProjector { public class SinusoidalProjector implements IProjector {

View File

@ -58,7 +58,7 @@ public class TestParser extends LuceneTestCase {
BufferedReader d = new BufferedReader(new InputStreamReader(TestParser.class.getResourceAsStream("reuters21578.txt"))); BufferedReader d = new BufferedReader(new InputStreamReader(TestParser.class.getResourceAsStream("reuters21578.txt")));
dir=newDirectory(); dir=newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig(Version.LUCENE_24, analyzer)); IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig(Version.LUCENE_40, analyzer));
String line = d.readLine(); String line = d.readLine();
while(line!=null) while(line!=null)
{ {

View File

@ -29,7 +29,6 @@ import org.apache.lucene.util.LuceneTestCase;
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.index.IndexWriter.MaxFieldLength;
import org.apache.lucene.search.Filter; import org.apache.lucene.search.Filter;
import org.apache.lucene.search.NumericRangeFilter; import org.apache.lucene.search.NumericRangeFilter;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;

View File

@ -25,7 +25,6 @@ import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
import org.apache.lucene.util.AttributeSource; import org.apache.lucene.util.AttributeSource;
import org.apache.lucene.util.CharacterUtils; import org.apache.lucene.util.CharacterUtils;
import org.apache.lucene.util.Version; import org.apache.lucene.util.Version;
import org.apache.lucene.util.VirtualMethod;
import org.apache.lucene.util.CharacterUtils.CharacterBuffer; import org.apache.lucene.util.CharacterUtils.CharacterBuffer;
/** /**
@ -78,8 +77,6 @@ public abstract class CharTokenizer extends Tokenizer {
public CharTokenizer(Version matchVersion, Reader input) { public CharTokenizer(Version matchVersion, Reader input) {
super(input); super(input);
charUtils = CharacterUtils.getInstance(matchVersion); charUtils = CharacterUtils.getInstance(matchVersion);
useOldAPI = useOldAPI(matchVersion);
} }
/** /**
@ -96,7 +93,6 @@ public abstract class CharTokenizer extends Tokenizer {
Reader input) { Reader input) {
super(source, input); super(source, input);
charUtils = CharacterUtils.getInstance(matchVersion); charUtils = CharacterUtils.getInstance(matchVersion);
useOldAPI = useOldAPI(matchVersion);
} }
/** /**
@ -113,147 +109,30 @@ public abstract class CharTokenizer extends Tokenizer {
Reader input) { Reader input) {
super(factory, input); super(factory, input);
charUtils = CharacterUtils.getInstance(matchVersion); charUtils = CharacterUtils.getInstance(matchVersion);
useOldAPI = useOldAPI(matchVersion);
}
/**
* Creates a new {@link CharTokenizer} instance
* @param input the input to split up into tokens
* @deprecated use {@link #CharTokenizer(Version, Reader)} instead. This will be
* removed in Lucene 4.0.
*/
@Deprecated
public CharTokenizer(Reader input) {
this(Version.LUCENE_30, input);
}
/**
* Creates a new {@link CharTokenizer} instance
* @param input the input to split up into tokens
* @param source the attribute source to use for this {@link Tokenizer}
* @deprecated use {@link #CharTokenizer(Version, AttributeSource, Reader)} instead. This will be
* removed in Lucene 4.0.
*/
@Deprecated
public CharTokenizer(AttributeSource source, Reader input) {
this(Version.LUCENE_30, source, input);
}
/**
* Creates a new {@link CharTokenizer} instance
* @param input the input to split up into tokens
* @param factory the attribute factory to use for this {@link Tokenizer}
* @deprecated use {@link #CharTokenizer(Version, AttributeSource.AttributeFactory, Reader)} instead. This will be
* removed in Lucene 4.0.
*/
@Deprecated
public CharTokenizer(AttributeFactory factory, Reader input) {
this(Version.LUCENE_30, factory, input);
} }
private int offset = 0, bufferIndex = 0, dataLen = 0, finalOffset = 0; private int offset = 0, bufferIndex = 0, dataLen = 0, finalOffset = 0;
private static final int MAX_WORD_LEN = 255; private static final int MAX_WORD_LEN = 255;
private static final int IO_BUFFER_SIZE = 4096; private static final int IO_BUFFER_SIZE = 4096;
private final CharTermAttribute termAtt = addAttribute(CharTermAttribute.class);; private final CharTermAttribute termAtt = addAttribute(CharTermAttribute.class);
private final OffsetAttribute offsetAtt = addAttribute(OffsetAttribute.class); private final OffsetAttribute offsetAtt = addAttribute(OffsetAttribute.class);
private final CharacterUtils charUtils; private final CharacterUtils charUtils;
private final CharacterBuffer ioBuffer = CharacterUtils.newCharacterBuffer(IO_BUFFER_SIZE); private final CharacterBuffer ioBuffer = CharacterUtils.newCharacterBuffer(IO_BUFFER_SIZE);
/**
* @deprecated this will be removed in lucene 4.0
*/
@Deprecated
private final boolean useOldAPI;
/**
* @deprecated this will be removed in lucene 4.0
*/
@Deprecated
private static final VirtualMethod<CharTokenizer> isTokenCharMethod =
new VirtualMethod<CharTokenizer>(CharTokenizer.class, "isTokenChar", char.class);
/**
* @deprecated this will be removed in lucene 4.0
*/
@Deprecated
private static final VirtualMethod<CharTokenizer> normalizeMethod =
new VirtualMethod<CharTokenizer>(CharTokenizer.class, "normalize", char.class);
/**
* Returns true iff a UTF-16 code unit should be included in a token. This
* tokenizer generates as tokens adjacent sequences of characters which
* satisfy this predicate. Characters for which this is <code>false</code> are
* used to define token boundaries and are not included in tokens.
* <p>
* Note: This method cannot handle <a href=
* "http://java.sun.com/j2se/1.5.0/docs/api/java/lang/Character.html#supplementary"
* >supplementary characters</a>. To support all Unicode characters, including
* supplementary characters, use the {@link #isTokenChar(int)} method.
* </p>
*
* @deprecated use {@link #isTokenChar(int)} instead. This method will be
* removed in Lucene 4.0.
*/
@Deprecated
protected boolean isTokenChar(char c) {
return isTokenChar((int)c);
}
/**
* Called on each token UTF-16 code unit to normalize it before it is added to the
* token. The default implementation does nothing. Subclasses may use this to,
* e.g., lowercase tokens.
* <p>
* Note: This method cannot handle <a href=
* "http://java.sun.com/j2se/1.5.0/docs/api/java/lang/Character.html#supplementary"
* >supplementary characters</a>. To support all Unicode characters, including
* supplementary characters, use the {@link #normalize(int)} method.
* </p>
*
* @deprecated use {@link #normalize(int)} instead. This method will be
* removed in Lucene 4.0.
*/
@Deprecated
protected char normalize(char c) {
return (char) normalize((int) c);
}
/** /**
* Returns true iff a codepoint should be included in a token. This tokenizer * Returns true iff a codepoint should be included in a token. This tokenizer
* generates as tokens adjacent sequences of codepoints which satisfy this * generates as tokens adjacent sequences of codepoints which satisfy this
* predicate. Codepoints for which this is false are used to define token * predicate. Codepoints for which this is false are used to define token
* boundaries and are not included in tokens. * boundaries and are not included in tokens.
* <p>
* As of Lucene 3.1 the char based API ({@link #isTokenChar(char)} and
* {@link #normalize(char)}) has been depreciated in favor of a Unicode 4.0
* compatible int based API to support codepoints instead of UTF-16 code
* units. Subclasses of {@link CharTokenizer} must not override the char based
* methods if a {@link Version} >= 3.1 is passed to the constructor.
* <p>
* <p>
* NOTE: This method will be marked <i>abstract</i> in Lucene 4.0.
* </p>
*/ */
protected boolean isTokenChar(int c) { protected abstract boolean isTokenChar(int c);
throw new UnsupportedOperationException("since LUCENE_31 subclasses of CharTokenizer must implement isTokenChar(int)");
}
/** /**
* Called on each token character to normalize it before it is added to the * Called on each token character to normalize it before it is added to the
* token. The default implementation does nothing. Subclasses may use this to, * token. The default implementation does nothing. Subclasses may use this to,
* e.g., lowercase tokens. * e.g., lowercase tokens.
* <p>
* As of Lucene 3.1 the char based API ({@link #isTokenChar(char)} and
* {@link #normalize(char)}) has been depreciated in favor of a Unicode 4.0
* compatible int based API to support codepoints instead of UTF-16 code
* units. Subclasses of {@link CharTokenizer} must not override the char based
* methods if a {@link Version} >= 3.1 is passed to the constructor.
* <p>
* <p>
* NOTE: This method will be marked <i>abstract</i> in Lucene 4.0.
* </p>
*/ */
protected int normalize(int c) { protected int normalize(int c) {
return c; return c;
@ -262,8 +141,6 @@ public abstract class CharTokenizer extends Tokenizer {
@Override @Override
public final boolean incrementToken() throws IOException { public final boolean incrementToken() throws IOException {
clearAttributes(); clearAttributes();
if(useOldAPI) // TODO remove this in LUCENE 4.0
return incrementTokenOld();
int length = 0; int length = 0;
int start = -1; // this variable is always initialized int start = -1; // this variable is always initialized
char[] buffer = termAtt.buffer(); char[] buffer = termAtt.buffer();
@ -307,62 +184,6 @@ public abstract class CharTokenizer extends Tokenizer {
} }
/**
* The <= 3.0 version of incrementToken. This is a backwards compat implementation used
* if a version <= 3.0 is provided to the ctor.
* @deprecated remove in 4.0
*/
@Deprecated
private boolean incrementTokenOld() throws IOException {
int length = 0;
int start = -1; // this variable is always initialized
char[] buffer = termAtt.buffer();
final char[] oldIoBuffer = ioBuffer.getBuffer();
while (true) {
if (bufferIndex >= dataLen) {
offset += dataLen;
dataLen = input.read(oldIoBuffer);
if (dataLen == -1) {
dataLen = 0; // so next offset += dataLen won't decrement offset
if (length > 0) {
break;
} else {
finalOffset = correctOffset(offset);
return false;
}
}
bufferIndex = 0;
}
final char c = oldIoBuffer[bufferIndex++];
if (isTokenChar(c)) { // if it's a token char
if (length == 0) { // start of token
assert start == -1;
start = offset + bufferIndex - 1;
} else if (length == buffer.length) {
buffer = termAtt.resizeBuffer(1+length);
}
buffer[length++] = normalize(c); // buffer it, normalized
if (length == MAX_WORD_LEN) // buffer overflow!
break;
} else if (length > 0) // at non-Letter w/ chars
break; // return 'em
}
termAtt.setLength(length);
assert start != -1;
offsetAtt.setOffset(correctOffset(start), correctOffset(start+length));
return true;
}
@Override @Override
public final void end() { public final void end() {
// set final offset // set final offset
@ -378,17 +199,4 @@ public abstract class CharTokenizer extends Tokenizer {
finalOffset = 0; finalOffset = 0;
ioBuffer.reset(); // make sure to reset the IO buffer!! ioBuffer.reset(); // make sure to reset the IO buffer!!
} }
/**
* @deprecated this will be removed in lucene 4.0
*/
@Deprecated
private boolean useOldAPI(Version matchVersion) {
final Class<? extends CharTokenizer> clazz = this.getClass();
if (matchVersion.onOrAfter(Version.LUCENE_31)
&& (isTokenCharMethod.isOverriddenAsOf(clazz) || normalizeMethod
.isOverriddenAsOf(clazz))) throw new IllegalArgumentException(
"For matchVersion >= LUCENE_31, CharTokenizer subclasses must not override isTokenChar(char) or normalize(char).");
return !matchVersion.onOrAfter(Version.LUCENE_31);
}
} }

View File

@ -1,123 +0,0 @@
package org.apache.lucene.document;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.search.PrefixQuery;
import org.apache.lucene.search.TermRangeQuery;
import org.apache.lucene.search.NumericRangeQuery; // for javadocs
import org.apache.lucene.util.NumericUtils; // for javadocs
import java.util.Date; // for javadoc
import java.util.Calendar; // for javadoc
// do not remove in 3.0, needed for reading old indexes!
/**
* Provides support for converting dates to strings and vice-versa.
* The strings are structured so that lexicographic sorting orders by date,
* which makes them suitable for use as field values and search terms.
*
* <P>Note that this class saves dates with millisecond granularity,
* which is bad for {@link TermRangeQuery} and {@link PrefixQuery}, as those
* queries are expanded to a BooleanQuery with a potentially large number
* of terms when searching. Thus you might want to use
* {@link DateTools} instead.
*
* <P>
* Note: dates before 1970 cannot be used, and therefore cannot be
* indexed when using this class. See {@link DateTools} for an
* alternative without such a limitation.
*
* <P>
* Another approach is {@link NumericUtils}, which provides
* a sortable binary representation (prefix encoded) of numeric values, which
* date/time are.
* For indexing a {@link Date} or {@link Calendar}, just get the unix timestamp as
* <code>long</code> using {@link Date#getTime} or {@link Calendar#getTimeInMillis} and
* index this as a numeric value with {@link NumericField}
* and use {@link NumericRangeQuery} to query it.
*
* @deprecated If you build a new index, use {@link DateTools} or
* {@link NumericField} instead.
* This class is included for use with existing
* indices and will be removed in a future release (possibly Lucene 4.0).
*/
@Deprecated
public class DateField {
private DateField() {}
// make date strings long enough to last a millenium
private static int DATE_LEN = Long.toString(1000L*365*24*60*60*1000,
Character.MAX_RADIX).length();
public static String MIN_DATE_STRING() {
return timeToString(0);
}
public static String MAX_DATE_STRING() {
char[] buffer = new char[DATE_LEN];
char c = Character.forDigit(Character.MAX_RADIX-1, Character.MAX_RADIX);
for (int i = 0 ; i < DATE_LEN; i++)
buffer[i] = c;
return new String(buffer);
}
/**
* Converts a Date to a string suitable for indexing.
* @throws RuntimeException if the date specified in the
* method argument is before 1970
*/
public static String dateToString(Date date) {
return timeToString(date.getTime());
}
/**
* Converts a millisecond time to a string suitable for indexing.
* @throws RuntimeException if the time specified in the
* method argument is negative, that is, before 1970
*/
public static String timeToString(long time) {
if (time < 0)
throw new RuntimeException("time '" + time + "' is too early, must be >= 0");
String s = Long.toString(time, Character.MAX_RADIX);
if (s.length() > DATE_LEN)
throw new RuntimeException("time '" + time + "' is too late, length of string " +
"representation must be <= " + DATE_LEN);
// Pad with leading zeros
if (s.length() < DATE_LEN) {
StringBuilder sb = new StringBuilder(s);
while (sb.length() < DATE_LEN)
sb.insert(0, 0);
s = sb.toString();
}
return s;
}
/** Converts a string-encoded date into a millisecond time. */
public static long stringToTime(String s) {
return Long.parseLong(s, Character.MAX_RADIX);
}
/** Converts a string-encoded date into a Date object. */
public static Date stringToDate(String s) {
return new Date(stringToTime(s));
}
}

View File

@ -36,10 +36,6 @@ import org.apache.lucene.util.NumericUtils; // for javadocs
* save dates with a finer resolution than you really need, as then * save dates with a finer resolution than you really need, as then
* RangeQuery and PrefixQuery will require more memory and become slower. * RangeQuery and PrefixQuery will require more memory and become slower.
* *
* <P>Compared to {@link DateField} the strings generated by the methods
* in this class take slightly more space, unless your selected resolution
* is set to <code>Resolution.DAY</code> or lower.
*
* <P> * <P>
* Another approach is {@link NumericUtils}, which provides * Another approach is {@link NumericUtils}, which provides
* a sortable binary representation (prefix encoded) of numeric values, which * a sortable binary representation (prefix encoded) of numeric values, which

View File

@ -17,13 +17,13 @@ package org.apache.lucene.document;
* limitations under the License. * limitations under the License.
*/ */
import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.index.IndexWriter; // for javadoc
import org.apache.lucene.util.StringHelper;
import java.io.Reader; import java.io.Reader;
import java.io.Serializable; import java.io.Serializable;
import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.util.StringHelper;
/** /**
A field is a section of a Document. Each field has two parts, a name and a A field is a section of a Document. Each field has two parts, a name and a
value. Values may be free text, provided as a String or as a Reader, or they value. Values may be free text, provided as a String or as a Reader, or they
@ -516,24 +516,6 @@ public final class Field extends AbstractField implements Fieldable, Serializabl
} }
/**
* Create a stored field with binary value. Optionally the value may be compressed.
*
* @param name The name of the field
* @param value The binary value
* @param store Must be Store.YES
* @throws IllegalArgumentException if store is <code>Store.NO</code>
* @deprecated Use {@link #Field(String, byte[]) instead}
*/
@Deprecated
public Field(String name, byte[] value, Store store) {
this(name, value, 0, value.length);
if (store == Store.NO) {
throw new IllegalArgumentException("binary values can't be unstored");
}
}
/** /**
* Create a stored field with binary value. Optionally the value may be compressed. * Create a stored field with binary value. Optionally the value may be compressed.
* *
@ -544,26 +526,6 @@ public final class Field extends AbstractField implements Fieldable, Serializabl
this(name, value, 0, value.length); this(name, value, 0, value.length);
} }
/**
* Create a stored field with binary value. Optionally the value may be compressed.
*
* @param name The name of the field
* @param value The binary value
* @param offset Starting offset in value where this Field's bytes are
* @param length Number of bytes to use for this Field, starting at offset
* @param store How <code>value</code> should be stored (compressed or not)
* @throws IllegalArgumentException if store is <code>Store.NO</code>
* @deprecated Use {@link #Field(String, byte[], int, int) instead}
*/
@Deprecated
public Field(String name, byte[] value, int offset, int length, Store store) {
this(name, value, offset, length);
if (store == Store.NO) {
throw new IllegalArgumentException("binary values can't be unstored");
}
}
/** /**
* Create a stored field with binary value. Optionally the value may be compressed. * Create a stored field with binary value. Optionally the value may be compressed.
* *

View File

@ -1,140 +0,0 @@
package org.apache.lucene.document;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.document.NumericField; // for javadocs
import org.apache.lucene.search.NumericRangeQuery; // for javadocs
import org.apache.lucene.util.NumericUtils; // for javadocs
// do not remove this class in 3.0, it may be needed to decode old indexes!
/**
* Provides support for converting longs to Strings, and back again. The strings
* are structured so that lexicographic sorting order is preserved.
*
* <p>
* That is, if l1 is less than l2 for any two longs l1 and l2, then
* NumberTools.longToString(l1) is lexicographically less than
* NumberTools.longToString(l2). (Similarly for "greater than" and "equals".)
*
* <p>
* This class handles <b>all</b> long values (unlike
* {@link org.apache.lucene.document.DateField}).
*
* @deprecated For new indexes use {@link NumericUtils} instead, which
* provides a sortable binary representation (prefix encoded) of numeric
* values.
* To index and efficiently query numeric values use {@link NumericField}
* and {@link NumericRangeQuery}.
* This class is included for use with existing
* indices and will be removed in a future release (possibly Lucene 4.0).
*/
@Deprecated
public class NumberTools {
private static final int RADIX = 36;
private static final char NEGATIVE_PREFIX = '-';
// NB: NEGATIVE_PREFIX must be < POSITIVE_PREFIX
private static final char POSITIVE_PREFIX = '0';
//NB: this must be less than
/**
* Equivalent to longToString(Long.MIN_VALUE)
*/
public static final String MIN_STRING_VALUE = NEGATIVE_PREFIX
+ "0000000000000";
/**
* Equivalent to longToString(Long.MAX_VALUE)
*/
public static final String MAX_STRING_VALUE = POSITIVE_PREFIX
+ "1y2p0ij32e8e7";
/**
* The length of (all) strings returned by {@link #longToString}
*/
public static final int STR_SIZE = MIN_STRING_VALUE.length();
/**
* Converts a long to a String suitable for indexing.
*/
public static String longToString(long l) {
if (l == Long.MIN_VALUE) {
// special case, because long is not symmetric around zero
return MIN_STRING_VALUE;
}
StringBuilder buf = new StringBuilder(STR_SIZE);
if (l < 0) {
buf.append(NEGATIVE_PREFIX);
l = Long.MAX_VALUE + l + 1;
} else {
buf.append(POSITIVE_PREFIX);
}
String num = Long.toString(l, RADIX);
int padLen = STR_SIZE - num.length() - buf.length();
while (padLen-- > 0) {
buf.append('0');
}
buf.append(num);
return buf.toString();
}
/**
* Converts a String that was returned by {@link #longToString} back to a
* long.
*
* @throws IllegalArgumentException
* if the input is null
* @throws NumberFormatException
* if the input does not parse (it was not a String returned by
* longToString()).
*/
public static long stringToLong(String str) {
if (str == null) {
throw new NullPointerException("string cannot be null");
}
if (str.length() != STR_SIZE) {
throw new NumberFormatException("string is the wrong size");
}
if (str.equals(MIN_STRING_VALUE)) {
return Long.MIN_VALUE;
}
char prefix = str.charAt(0);
long l = Long.parseLong(str.substring(1), RADIX);
if (prefix == POSITIVE_PREFIX) {
// nop
} else if (prefix == NEGATIVE_PREFIX) {
l = l - Long.MAX_VALUE - 1;
} else {
throw new NumberFormatException(
"string does not begin with the correct prefix");
}
return l;
}
}

View File

@ -23,6 +23,7 @@ import org.apache.lucene.store.BufferedIndexInput;
import org.apache.lucene.store.IndexOutput; import org.apache.lucene.store.IndexOutput;
import org.apache.lucene.store.Lock; import org.apache.lucene.store.Lock;
import java.util.Collection;
import java.util.HashMap; import java.util.HashMap;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
@ -227,6 +228,10 @@ public class CompoundFileReader extends Directory {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
} }
@Override
public void sync(Collection<String> names) throws IOException {
}
/** Not implemented /** Not implemented
* @throws UnsupportedOperationException */ * @throws UnsupportedOperationException */
@Override @Override

View File

@ -180,68 +180,11 @@ import java.util.Date;
* keeps track of the last non commit checkpoint. * keeps track of the last non commit checkpoint.
*/ */
public class IndexWriter implements Closeable { public class IndexWriter implements Closeable {
/**
* Default value for the write lock timeout (1,000).
* @see #setDefaultWriteLockTimeout
* @deprecated use {@link IndexWriterConfig#WRITE_LOCK_TIMEOUT} instead
*/
@Deprecated
public static long WRITE_LOCK_TIMEOUT = IndexWriterConfig.WRITE_LOCK_TIMEOUT;
private long writeLockTimeout;
/** /**
* Name of the write lock in the index. * Name of the write lock in the index.
*/ */
public static final String WRITE_LOCK_NAME = "write.lock"; public static final String WRITE_LOCK_NAME = "write.lock";
/**
* Value to denote a flush trigger is disabled
* @deprecated use {@link IndexWriterConfig#DISABLE_AUTO_FLUSH} instead
*/
@Deprecated
public final static int DISABLE_AUTO_FLUSH = IndexWriterConfig.DISABLE_AUTO_FLUSH;
/**
* Disabled by default (because IndexWriter flushes by RAM usage
* by default). Change using {@link #setMaxBufferedDocs(int)}.
* @deprecated use {@link IndexWriterConfig#DEFAULT_MAX_BUFFERED_DOCS} instead.
*/
@Deprecated
public final static int DEFAULT_MAX_BUFFERED_DOCS = IndexWriterConfig.DEFAULT_MAX_BUFFERED_DOCS;
/**
* Default value is 16 MB (which means flush when buffered
* docs consume 16 MB RAM). Change using {@link #setRAMBufferSizeMB}.
* @deprecated use {@link IndexWriterConfig#DEFAULT_RAM_BUFFER_SIZE_MB} instead.
*/
@Deprecated
public final static double DEFAULT_RAM_BUFFER_SIZE_MB = IndexWriterConfig.DEFAULT_RAM_BUFFER_SIZE_MB;
/**
* Disabled by default (because IndexWriter flushes by RAM usage
* by default). Change using {@link #setMaxBufferedDeleteTerms(int)}.
* @deprecated use {@link IndexWriterConfig#DEFAULT_MAX_BUFFERED_DELETE_TERMS} instead
*/
@Deprecated
public final static int DEFAULT_MAX_BUFFERED_DELETE_TERMS = IndexWriterConfig.DEFAULT_MAX_BUFFERED_DELETE_TERMS;
/**
* Default value is 10,000. Change using {@link #setMaxFieldLength(int)}.
*
* @deprecated see {@link IndexWriterConfig}
*/
@Deprecated
public final static int DEFAULT_MAX_FIELD_LENGTH = 10000;
/**
* Default value is 128. Change using {@link #setTermIndexInterval(int)}.
* @deprecated use {@link IndexWriterConfig#DEFAULT_TERM_INDEX_INTERVAL} instead.
*/
@Deprecated
public final static int DEFAULT_TERM_INDEX_INTERVAL = IndexWriterConfig.DEFAULT_TERM_INDEX_INTERVAL;
/** /**
* Absolute hard maximum length for a term, in bytes once * Absolute hard maximum length for a term, in bytes once
* encoded as UTF8. If a term arrives from the analyzer * encoded as UTF8. If a term arrives from the analyzer
@ -268,9 +211,6 @@ public class IndexWriter implements Closeable {
private final Directory directory; // where this index resides private final Directory directory; // where this index resides
private final Analyzer analyzer; // how to analyze text private final Analyzer analyzer; // how to analyze text
// TODO 4.0: this should be made final once the setter is out
private /*final*/Similarity similarity = Similarity.getDefault(); // how to normalize
private volatile long changeCount; // increments every time a change is completed private volatile long changeCount; // increments every time a change is completed
private long lastCommitChangeCount; // last changeCount that was committed private long lastCommitChangeCount; // last changeCount that was committed
@ -290,8 +230,7 @@ public class IndexWriter implements Closeable {
private Lock writeLock; private Lock writeLock;
// TODO 4.0: this should be made final once the setter is out private final int termIndexInterval;
private /*final*/int termIndexInterval;
private boolean closed; private boolean closed;
private boolean closing; private boolean closing;
@ -301,8 +240,7 @@ public class IndexWriter implements Closeable {
private HashSet<SegmentInfo> mergingSegments = new HashSet<SegmentInfo>(); private HashSet<SegmentInfo> mergingSegments = new HashSet<SegmentInfo>();
private MergePolicy mergePolicy; private MergePolicy mergePolicy;
// TODO 4.0: this should be made final once the setter is removed private final MergeScheduler mergeScheduler;
private /*final*/MergeScheduler mergeScheduler;
private LinkedList<MergePolicy.OneMerge> pendingMerges = new LinkedList<MergePolicy.OneMerge>(); private LinkedList<MergePolicy.OneMerge> pendingMerges = new LinkedList<MergePolicy.OneMerge>();
private Set<MergePolicy.OneMerge> runningMerges = new HashSet<MergePolicy.OneMerge>(); private Set<MergePolicy.OneMerge> runningMerges = new HashSet<MergePolicy.OneMerge>();
private List<MergePolicy.OneMerge> mergeExceptions = new ArrayList<MergePolicy.OneMerge>(); private List<MergePolicy.OneMerge> mergeExceptions = new ArrayList<MergePolicy.OneMerge>();
@ -730,276 +668,6 @@ public class IndexWriter implements Closeable {
throw new IllegalArgumentException("this method can only be called when the merge policy is the default LogMergePolicy"); throw new IllegalArgumentException("this method can only be called when the merge policy is the default LogMergePolicy");
} }
/** <p>Get the current setting of whether newly flushed
* segments will use the compound file format. Note that
* this just returns the value previously set with
* setUseCompoundFile(boolean), or the default value
* (true). You cannot use this to query the status of
* previously flushed segments.</p>
*
* <p>Note that this method is a convenience method: it
* just calls mergePolicy.getUseCompoundFile as long as
* mergePolicy is an instance of {@link LogMergePolicy}.
* Otherwise an IllegalArgumentException is thrown.</p>
*
* @see #setUseCompoundFile(boolean)
* @deprecated use {@link LogMergePolicy#getUseCompoundDocStore()} and
* {@link LogMergePolicy#getUseCompoundFile()} directly.
*/
@Deprecated
public boolean getUseCompoundFile() {
return getLogMergePolicy().getUseCompoundFile();
}
/**
* <p>
* Setting to turn on usage of a compound file. When on, multiple files for
* each segment are merged into a single file when a new segment is flushed.
* </p>
*
* <p>
* Note that this method is a convenience method: it just calls
* mergePolicy.setUseCompoundFile as long as mergePolicy is an instance of
* {@link LogMergePolicy}. Otherwise an IllegalArgumentException is thrown.
* </p>
*
* @deprecated use {@link LogMergePolicy#setUseCompoundDocStore(boolean)} and
* {@link LogMergePolicy#setUseCompoundFile(boolean)} directly.
* Note that this method set the given value on both, therefore
* you should consider doing the same.
*/
@Deprecated
public void setUseCompoundFile(boolean value) {
getLogMergePolicy().setUseCompoundFile(value);
getLogMergePolicy().setUseCompoundDocStore(value);
}
/** Expert: Set the Similarity implementation used by this IndexWriter.
*
* @see Similarity#setDefault(Similarity)
* @deprecated use {@link IndexWriterConfig#setSimilarity(Similarity)} instead
*/
@Deprecated
public void setSimilarity(Similarity similarity) {
ensureOpen();
this.similarity = similarity;
docWriter.setSimilarity(similarity);
// Required so config.getSimilarity returns the right value. But this will
// go away together with the method in 4.0.
config.setSimilarity(similarity);
}
/** Expert: Return the Similarity implementation used by this IndexWriter.
*
* <p>This defaults to the current value of {@link Similarity#getDefault()}.
* @deprecated use {@link IndexWriterConfig#getSimilarity()} instead
*/
@Deprecated
public Similarity getSimilarity() {
ensureOpen();
return similarity;
}
/** Expert: Set the interval between indexed terms. Large values cause less
* memory to be used by IndexReader, but slow random-access to terms. Small
* values cause more memory to be used by an IndexReader, and speed
* random-access to terms.
*
* This parameter determines the amount of computation required per query
* term, regardless of the number of documents that contain that term. In
* particular, it is the maximum number of other terms that must be
* scanned before a term is located and its frequency and position information
* may be processed. In a large index with user-entered query terms, query
* processing time is likely to be dominated not by term lookup but rather
* by the processing of frequency and positional data. In a small index
* or when many uncommon query terms are generated (e.g., by wildcard
* queries) term lookup may become a dominant cost.
*
* In particular, <code>numUniqueTerms/interval</code> terms are read into
* memory by an IndexReader, and, on average, <code>interval/2</code> terms
* must be scanned for each random term access.
*
* @see #DEFAULT_TERM_INDEX_INTERVAL
* @deprecated use {@link IndexWriterConfig#setTermIndexInterval(int)}
*/
@Deprecated
public void setTermIndexInterval(int interval) {
ensureOpen();
this.termIndexInterval = interval;
// Required so config.getTermIndexInterval returns the right value. But this
// will go away together with the method in 4.0.
config.setTermIndexInterval(interval);
}
/** Expert: Return the interval between indexed terms.
*
* @see #setTermIndexInterval(int)
* @deprecated use {@link IndexWriterConfig#getTermIndexInterval()}
*/
@Deprecated
public int getTermIndexInterval() {
// We pass false because this method is called by SegmentMerger while we are in the process of closing
ensureOpen(false);
return termIndexInterval;
}
/**
* Constructs an IndexWriter for the index in <code>d</code>.
* Text will be analyzed with <code>a</code>. If <code>create</code>
* is true, then a new, empty index will be created in
* <code>d</code>, replacing the index already there, if any.
*
* @param d the index directory
* @param a the analyzer to use
* @param create <code>true</code> to create the index or overwrite
* the existing one; <code>false</code> to append to the existing
* index
* @param mfl Maximum field length in number of terms/tokens: LIMITED, UNLIMITED, or user-specified
* via the MaxFieldLength constructor.
* @throws CorruptIndexException if the index is corrupt
* @throws LockObtainFailedException if another writer
* has this index open (<code>write.lock</code> could not
* be obtained)
* @throws IOException if the directory cannot be read/written to, or
* if it does not exist and <code>create</code> is
* <code>false</code> or if there is any other low-level
* IO error
* @deprecated use {@link #IndexWriter(Directory, IndexWriterConfig)} instead
*/
@Deprecated
public IndexWriter(Directory d, Analyzer a, boolean create, MaxFieldLength mfl)
throws CorruptIndexException, LockObtainFailedException, IOException {
this(d, new IndexWriterConfig(Version.LUCENE_31, a).setOpenMode(
create ? OpenMode.CREATE : OpenMode.APPEND).setMaxFieldLength(
mfl.getLimit()));
}
/**
* Constructs an IndexWriter for the index in
* <code>d</code>, first creating it if it does not
* already exist. Text will be analyzed with
* <code>a</code>.
*
* @param d the index directory
* @param a the analyzer to use
* @param mfl Maximum field length in number of terms/tokens: LIMITED, UNLIMITED, or user-specified
* via the MaxFieldLength constructor.
* @throws CorruptIndexException if the index is corrupt
* @throws LockObtainFailedException if another writer
* has this index open (<code>write.lock</code> could not
* be obtained)
* @throws IOException if the directory cannot be
* read/written to or if there is any other low-level
* IO error
* @deprecated use {@link #IndexWriter(Directory, IndexWriterConfig)} instead
*/
@Deprecated
public IndexWriter(Directory d, Analyzer a, MaxFieldLength mfl)
throws CorruptIndexException, LockObtainFailedException, IOException {
this(d, new IndexWriterConfig(Version.LUCENE_31, a)
.setMaxFieldLength(mfl.getLimit()));
}
/**
* Expert: constructs an IndexWriter with a custom {@link
* IndexDeletionPolicy}, for the index in <code>d</code>,
* first creating it if it does not already exist. Text
* will be analyzed with <code>a</code>.
*
* @param d the index directory
* @param a the analyzer to use
* @param deletionPolicy see <a href="#deletionPolicy">above</a>
* @param mfl whether or not to limit field lengths
* @throws CorruptIndexException if the index is corrupt
* @throws LockObtainFailedException if another writer
* has this index open (<code>write.lock</code> could not
* be obtained)
* @throws IOException if the directory cannot be
* read/written to or if there is any other low-level
* IO error
* @deprecated use {@link #IndexWriter(Directory, IndexWriterConfig)} instead
*/
@Deprecated
public IndexWriter(Directory d, Analyzer a, IndexDeletionPolicy deletionPolicy, MaxFieldLength mfl)
throws CorruptIndexException, LockObtainFailedException, IOException {
this(d, new IndexWriterConfig(Version.LUCENE_31, a).setMaxFieldLength(
mfl.getLimit()).setIndexDeletionPolicy(deletionPolicy));
}
/**
* Expert: constructs an IndexWriter with a custom {@link
* IndexDeletionPolicy}, for the index in <code>d</code>.
* Text will be analyzed with <code>a</code>. If
* <code>create</code> is true, then a new, empty index
* will be created in <code>d</code>, replacing the index
* already there, if any.
*
* @param d the index directory
* @param a the analyzer to use
* @param create <code>true</code> to create the index or overwrite
* the existing one; <code>false</code> to append to the existing
* index
* @param deletionPolicy see <a href="#deletionPolicy">above</a>
* @param mfl {@link org.apache.lucene.index.IndexWriter.MaxFieldLength}, whether or not to limit field lengths. Value is in number of terms/tokens
* @throws CorruptIndexException if the index is corrupt
* @throws LockObtainFailedException if another writer
* has this index open (<code>write.lock</code> could not
* be obtained)
* @throws IOException if the directory cannot be read/written to, or
* if it does not exist and <code>create</code> is
* <code>false</code> or if there is any other low-level
* IO error
* @deprecated use {@link #IndexWriter(Directory, IndexWriterConfig)} instead
*/
@Deprecated
public IndexWriter(Directory d, Analyzer a, boolean create, IndexDeletionPolicy deletionPolicy, MaxFieldLength mfl)
throws CorruptIndexException, LockObtainFailedException, IOException {
this(d, new IndexWriterConfig(Version.LUCENE_31, a).setOpenMode(
create ? OpenMode.CREATE : OpenMode.APPEND).setMaxFieldLength(
mfl.getLimit()).setIndexDeletionPolicy(deletionPolicy));
}
/**
* Expert: constructs an IndexWriter on specific commit
* point, with a custom {@link IndexDeletionPolicy}, for
* the index in <code>d</code>. Text will be analyzed
* with <code>a</code>.
*
* <p> This is only meaningful if you've used a {@link
* IndexDeletionPolicy} in that past that keeps more than
* just the last commit.
*
* <p>This operation is similar to {@link #rollback()},
* except that method can only rollback what's been done
* with the current instance of IndexWriter since its last
* commit, whereas this method can rollback to an
* arbitrary commit point from the past, assuming the
* {@link IndexDeletionPolicy} has preserved past
* commits.
*
* @param d the index directory
* @param a the analyzer to use
* @param deletionPolicy see <a href="#deletionPolicy">above</a>
* @param mfl whether or not to limit field lengths, value is in number of terms/tokens. See {@link org.apache.lucene.index.IndexWriter.MaxFieldLength}.
* @param commit which commit to open
* @throws CorruptIndexException if the index is corrupt
* @throws LockObtainFailedException if another writer
* has this index open (<code>write.lock</code> could not
* be obtained)
* @throws IOException if the directory cannot be read/written to, or
* if it does not exist and <code>create</code> is
* <code>false</code> or if there is any other low-level
* IO error
* @deprecated use {@link #IndexWriter(Directory, IndexWriterConfig)} instead
*/
@Deprecated
public IndexWriter(Directory d, Analyzer a, IndexDeletionPolicy deletionPolicy, MaxFieldLength mfl, IndexCommit commit)
throws CorruptIndexException, LockObtainFailedException, IOException {
this(d, new IndexWriterConfig(Version.LUCENE_31, a)
.setOpenMode(OpenMode.APPEND).setMaxFieldLength(mfl.getLimit())
.setIndexDeletionPolicy(deletionPolicy).setIndexCommit(commit));
}
CodecProvider codecs; CodecProvider codecs;
/** /**
@ -1038,8 +706,6 @@ public class IndexWriter implements Closeable {
setMessageID(defaultInfoStream); setMessageID(defaultInfoStream);
maxFieldLength = conf.getMaxFieldLength(); maxFieldLength = conf.getMaxFieldLength();
termIndexInterval = conf.getTermIndexInterval(); termIndexInterval = conf.getTermIndexInterval();
writeLockTimeout = conf.getWriteLockTimeout();
similarity = conf.getSimilarity();
mergePolicy = conf.getMergePolicy(); mergePolicy = conf.getMergePolicy();
mergePolicy.setIndexWriter(this); mergePolicy.setIndexWriter(this);
mergeScheduler = conf.getMergeScheduler(); mergeScheduler = conf.getMergeScheduler();
@ -1061,7 +727,7 @@ public class IndexWriter implements Closeable {
writeLock = directory.makeLock(WRITE_LOCK_NAME); writeLock = directory.makeLock(WRITE_LOCK_NAME);
if (!writeLock.obtain(writeLockTimeout)) // obtain write lock if (!writeLock.obtain(conf.getWriteLockTimeout())) // obtain write lock
throw new LockObtainFailedException("Index locked for write: " + writeLock); throw new LockObtainFailedException("Index locked for write: " + writeLock);
boolean success = false; boolean success = false;
@ -1176,203 +842,13 @@ public class IndexWriter implements Closeable {
return config; return config;
} }
/**
* Expert: set the merge policy used by this writer.
*
* @deprecated use {@link IndexWriterConfig#setMergePolicy(MergePolicy)} instead.
*/
@Deprecated
public void setMergePolicy(MergePolicy mp) {
ensureOpen();
if (mp == null)
throw new NullPointerException("MergePolicy must be non-null");
if (mergePolicy != mp)
mergePolicy.close();
mergePolicy = mp;
mergePolicy.setIndexWriter(this);
pushMaxBufferedDocs();
if (infoStream != null)
message("setMergePolicy " + mp);
// Required so config.getMergePolicy returns the right value. But this will
// go away together with the method in 4.0.
config.setMergePolicy(mp);
}
/**
* Expert: returns the current MergePolicy in use by this writer.
* @see #setMergePolicy
*
* @deprecated use {@link IndexWriterConfig#getMergePolicy()} instead
*/
@Deprecated
public MergePolicy getMergePolicy() {
ensureOpen();
return mergePolicy;
}
/**
* Expert: set the merge scheduler used by this writer.
* @deprecated use {@link IndexWriterConfig#setMergeScheduler(MergeScheduler)} instead
*/
@Deprecated
synchronized public void setMergeScheduler(MergeScheduler mergeScheduler) throws CorruptIndexException, IOException {
ensureOpen();
if (mergeScheduler == null)
throw new NullPointerException("MergeScheduler must be non-null");
if (this.mergeScheduler != mergeScheduler) {
finishMerges(true);
this.mergeScheduler.close();
}
this.mergeScheduler = mergeScheduler;
if (infoStream != null)
message("setMergeScheduler " + mergeScheduler);
// Required so config.getMergeScheduler returns the right value. But this will
// go away together with the method in 4.0.
config.setMergeScheduler(mergeScheduler);
}
/**
* Expert: returns the current MergeScheduler in use by this
* writer.
* @see #setMergeScheduler(MergeScheduler)
* @deprecated use {@link IndexWriterConfig#getMergeScheduler()} instead
*/
@Deprecated
public MergeScheduler getMergeScheduler() {
ensureOpen();
return mergeScheduler;
}
/** <p>Determines the largest segment (measured by
* document count) that may be merged with other segments.
* Small values (e.g., less than 10,000) are best for
* interactive indexing, as this limits the length of
* pauses while indexing to a few seconds. Larger values
* are best for batched indexing and speedier
* searches.</p>
*
* <p>The default value is {@link Integer#MAX_VALUE}.</p>
*
* <p>Note that this method is a convenience method: it
* just calls mergePolicy.setMaxMergeDocs as long as
* mergePolicy is an instance of {@link LogMergePolicy}.
* Otherwise an IllegalArgumentException is thrown.</p>
*
* <p>The default merge policy ({@link
* LogByteSizeMergePolicy}) also allows you to set this
* limit by net size (in MB) of the segment, using {@link
* LogByteSizeMergePolicy#setMaxMergeMB}.</p>
* @deprecated use {@link LogMergePolicy#setMaxMergeDocs(int)} directly.
*/
@Deprecated
public void setMaxMergeDocs(int maxMergeDocs) {
getLogMergePolicy().setMaxMergeDocs(maxMergeDocs);
}
/**
* <p>Returns the largest segment (measured by document
* count) that may be merged with other segments.</p>
*
* <p>Note that this method is a convenience method: it
* just calls mergePolicy.getMaxMergeDocs as long as
* mergePolicy is an instance of {@link LogMergePolicy}.
* Otherwise an IllegalArgumentException is thrown.</p>
*
* @see #setMaxMergeDocs
* @deprecated use {@link LogMergePolicy#getMaxMergeDocs()} directly.
*/
@Deprecated
public int getMaxMergeDocs() {
return getLogMergePolicy().getMaxMergeDocs();
}
/**
* The maximum number of terms that will be indexed for a single field in a
* document. This limits the amount of memory required for indexing, so that
* collections with very large files will not crash the indexing process by
* running out of memory. This setting refers to the number of running terms,
* not to the number of different terms.<p/>
* <strong>Note:</strong> this silently truncates large documents, excluding from the
* index all terms that occur further in the document. If you know your source
* documents are large, be sure to set this value high enough to accomodate
* the expected size. If you set it to Integer.MAX_VALUE, then the only limit
* is your memory, but you should anticipate an OutOfMemoryError.<p/>
* By default, no more than {@link #DEFAULT_MAX_FIELD_LENGTH} terms
* will be indexed for a field.
* @deprecated use {@link IndexWriterConfig#setMaxFieldLength(int)} instead
*/
@Deprecated
public void setMaxFieldLength(int maxFieldLength) {
ensureOpen();
this.maxFieldLength = maxFieldLength;
docWriter.setMaxFieldLength(maxFieldLength);
if (infoStream != null)
message("setMaxFieldLength " + maxFieldLength);
// Required so config.getMaxFieldLength returns the right value. But this
// will go away together with the method in 4.0.
config.setMaxFieldLength(maxFieldLength);
}
/**
* Returns the maximum number of terms that will be
* indexed for a single field in a document.
* @see #setMaxFieldLength
* @deprecated use {@link IndexWriterConfig#getMaxFieldLength()} instead
*/
@Deprecated
public int getMaxFieldLength() {
ensureOpen();
return maxFieldLength;
}
/** Determines the minimal number of documents required
* before the buffered in-memory documents are flushed as
* a new Segment. Large values generally gives faster
* indexing.
*
* <p>When this is set, the writer will flush every
* maxBufferedDocs added documents. Pass in {@link
* #DISABLE_AUTO_FLUSH} to prevent triggering a flush due
* to number of buffered documents. Note that if flushing
* by RAM usage is also enabled, then the flush will be
* triggered by whichever comes first.</p>
*
* <p>Disabled by default (writer flushes by RAM usage).</p>
*
* @throws IllegalArgumentException if maxBufferedDocs is
* enabled but smaller than 2, or it disables maxBufferedDocs
* when ramBufferSize is already disabled
* @see #setRAMBufferSizeMB
* @deprecated use {@link IndexWriterConfig#setMaxBufferedDocs(int)} instead.
*/
@Deprecated
public void setMaxBufferedDocs(int maxBufferedDocs) {
ensureOpen();
if (maxBufferedDocs != DISABLE_AUTO_FLUSH && maxBufferedDocs < 2)
throw new IllegalArgumentException(
"maxBufferedDocs must at least be 2 when enabled");
if (maxBufferedDocs == DISABLE_AUTO_FLUSH
&& getRAMBufferSizeMB() == DISABLE_AUTO_FLUSH)
throw new IllegalArgumentException(
"at least one of ramBufferSize and maxBufferedDocs must be enabled");
docWriter.setMaxBufferedDocs(maxBufferedDocs);
pushMaxBufferedDocs();
if (infoStream != null)
message("setMaxBufferedDocs " + maxBufferedDocs);
// Required so config.getMaxBufferedDocs returns the right value. But this
// will go away together with the method in 4.0.
config.setMaxBufferedDocs(maxBufferedDocs);
}
/** /**
* If we are flushing by doc count (not by RAM usage), and * If we are flushing by doc count (not by RAM usage), and
* using LogDocMergePolicy then push maxBufferedDocs down * using LogDocMergePolicy then push maxBufferedDocs down
* as its minMergeDocs, to keep backwards compatibility. * as its minMergeDocs, to keep backwards compatibility.
*/ */
private void pushMaxBufferedDocs() { private void pushMaxBufferedDocs() {
if (docWriter.getMaxBufferedDocs() != DISABLE_AUTO_FLUSH) { if (docWriter.getMaxBufferedDocs() != IndexWriterConfig.DISABLE_AUTO_FLUSH) {
final MergePolicy mp = mergePolicy; final MergePolicy mp = mergePolicy;
if (mp instanceof LogDocMergePolicy) { if (mp instanceof LogDocMergePolicy) {
LogDocMergePolicy lmp = (LogDocMergePolicy) mp; LogDocMergePolicy lmp = (LogDocMergePolicy) mp;
@ -1386,164 +862,6 @@ public class IndexWriter implements Closeable {
} }
} }
/**
* Returns the number of buffered added documents that will
* trigger a flush if enabled.
* @see #setMaxBufferedDocs
* @deprecated use {@link IndexWriterConfig#getMaxBufferedDocs()} instead.
*/
@Deprecated
public int getMaxBufferedDocs() {
ensureOpen();
return docWriter.getMaxBufferedDocs();
}
/** Determines the amount of RAM that may be used for
* buffering added documents and deletions before they are
* flushed to the Directory. Generally for faster
* indexing performance it's best to flush by RAM usage
* instead of document count and use as large a RAM buffer
* as you can.
*
* <p>When this is set, the writer will flush whenever
* buffered documents and deletions use this much RAM.
* Pass in {@link #DISABLE_AUTO_FLUSH} to prevent
* triggering a flush due to RAM usage. Note that if
* flushing by document count is also enabled, then the
* flush will be triggered by whichever comes first.</p>
*
* <p> <b>NOTE</b>: the account of RAM usage for pending
* deletions is only approximate. Specifically, if you
* delete by Query, Lucene currently has no way to measure
* the RAM usage if individual Queries so the accounting
* will under-estimate and you should compensate by either
* calling commit() periodically yourself, or by using
* {@link #setMaxBufferedDeleteTerms} to flush by count
* instead of RAM usage (each buffered delete Query counts
* as one).
*
* <p> <b>NOTE</b>: because IndexWriter uses
* <code>int</code>s when managing its internal storage,
* the absolute maximum value for this setting is somewhat
* less than 2048 MB. The precise limit depends on
* various factors, such as how large your documents are,
* how many fields have norms, etc., so it's best to set
* this value comfortably under 2048.</p>
*
* <p> The default value is {@link #DEFAULT_RAM_BUFFER_SIZE_MB}.</p>
*
* @throws IllegalArgumentException if ramBufferSize is
* enabled but non-positive, or it disables ramBufferSize
* when maxBufferedDocs is already disabled
* @deprecated use {@link IndexWriterConfig#setRAMBufferSizeMB(double)} instead.
*/
@Deprecated
public void setRAMBufferSizeMB(double mb) {
if (mb > 2048.0) {
throw new IllegalArgumentException("ramBufferSize " + mb + " is too large; should be comfortably less than 2048");
}
if (mb != DISABLE_AUTO_FLUSH && mb <= 0.0)
throw new IllegalArgumentException(
"ramBufferSize should be > 0.0 MB when enabled");
if (mb == DISABLE_AUTO_FLUSH && getMaxBufferedDocs() == DISABLE_AUTO_FLUSH)
throw new IllegalArgumentException(
"at least one of ramBufferSize and maxBufferedDocs must be enabled");
docWriter.setRAMBufferSizeMB(mb);
if (infoStream != null)
message("setRAMBufferSizeMB " + mb);
// Required so config.getRAMBufferSizeMB returns the right value. But this
// will go away together with the method in 4.0.
config.setRAMBufferSizeMB(mb);
}
/**
* Returns the value set by {@link #setRAMBufferSizeMB} if enabled.
* @deprecated use {@link IndexWriterConfig#getRAMBufferSizeMB()} instead.
*/
@Deprecated
public double getRAMBufferSizeMB() {
return docWriter.getRAMBufferSizeMB();
}
/**
* <p>Determines the minimal number of delete terms required before the buffered
* in-memory delete terms are applied and flushed. If there are documents
* buffered in memory at the time, they are merged and a new segment is
* created.</p>
* <p>Disabled by default (writer flushes by RAM usage).</p>
*
* @throws IllegalArgumentException if maxBufferedDeleteTerms
* is enabled but smaller than 1
* @see #setRAMBufferSizeMB
* @deprecated use {@link IndexWriterConfig#setMaxBufferedDeleteTerms(int)} instead.
*/
@Deprecated
public void setMaxBufferedDeleteTerms(int maxBufferedDeleteTerms) {
ensureOpen();
if (maxBufferedDeleteTerms != DISABLE_AUTO_FLUSH
&& maxBufferedDeleteTerms < 1)
throw new IllegalArgumentException(
"maxBufferedDeleteTerms must at least be 1 when enabled");
docWriter.setMaxBufferedDeleteTerms(maxBufferedDeleteTerms);
if (infoStream != null)
message("setMaxBufferedDeleteTerms " + maxBufferedDeleteTerms);
// Required so config.getMaxBufferedDeleteTerms returns the right value. But
// this will go away together with the method in 4.0.
config.setMaxBufferedDeleteTerms(maxBufferedDeleteTerms);
}
/**
* Returns the number of buffered deleted terms that will
* trigger a flush if enabled.
* @see #setMaxBufferedDeleteTerms
* @deprecated use {@link IndexWriterConfig#getMaxBufferedDeleteTerms()} instead
*/
@Deprecated
public int getMaxBufferedDeleteTerms() {
ensureOpen();
return docWriter.getMaxBufferedDeleteTerms();
}
/** Determines how often segment indices are merged by addDocument(). With
* smaller values, less RAM is used while indexing, and searches on
* unoptimized indices are faster, but indexing speed is slower. With larger
* values, more RAM is used during indexing, and while searches on unoptimized
* indices are slower, indexing is faster. Thus larger values (> 10) are best
* for batch index creation, and smaller values (< 10) for indices that are
* interactively maintained.
*
* <p>Note that this method is a convenience method: it
* just calls mergePolicy.setMergeFactor as long as
* mergePolicy is an instance of {@link LogMergePolicy}.
* Otherwise an IllegalArgumentException is thrown.</p>
*
* <p>This must never be less than 2. The default value is 10.
* @deprecated use {@link LogMergePolicy#setMergeFactor(int)} directly.
*/
@Deprecated
public void setMergeFactor(int mergeFactor) {
getLogMergePolicy().setMergeFactor(mergeFactor);
}
/**
* <p>Returns the number of segments that are merged at
* once and also controls the total number of segments
* allowed to accumulate in the index.</p>
*
* <p>Note that this method is a convenience method: it
* just calls mergePolicy.getMergeFactor as long as
* mergePolicy is an instance of {@link LogMergePolicy}.
* Otherwise an IllegalArgumentException is thrown.</p>
*
* @see #setMergeFactor
* @deprecated use {@link LogMergePolicy#getMergeFactor()} directly.
*/
@Deprecated
public int getMergeFactor() {
return getLogMergePolicy().getMergeFactor();
}
/** If non-null, this will be the default infoStream used /** If non-null, this will be the default infoStream used
* by a newly instantiated IndexWriter. * by a newly instantiated IndexWriter.
* @see #setInfoStream * @see #setInfoStream
@ -1595,52 +913,6 @@ public class IndexWriter implements Closeable {
return infoStream != null; return infoStream != null;
} }
/**
* Sets the maximum time to wait for a write lock (in milliseconds) for this instance of IndexWriter. @see
* @see #setDefaultWriteLockTimeout to change the default value for all instances of IndexWriter.
* @deprecated use {@link IndexWriterConfig#setWriteLockTimeout(long)} instead
*/
@Deprecated
public void setWriteLockTimeout(long writeLockTimeout) {
ensureOpen();
this.writeLockTimeout = writeLockTimeout;
// Required so config.getWriteLockTimeout returns the right value. But this
// will go away together with the method in 4.0.
config.setWriteLockTimeout(writeLockTimeout);
}
/**
* Returns allowed timeout when acquiring the write lock.
* @see #setWriteLockTimeout
* @deprecated use {@link IndexWriterConfig#getWriteLockTimeout()}
*/
@Deprecated
public long getWriteLockTimeout() {
ensureOpen();
return writeLockTimeout;
}
/**
* Sets the default (for any instance of IndexWriter) maximum time to wait for a write lock (in
* milliseconds).
* @deprecated use {@link IndexWriterConfig#setDefaultWriteLockTimeout(long)} instead
*/
@Deprecated
public static void setDefaultWriteLockTimeout(long writeLockTimeout) {
IndexWriterConfig.setDefaultWriteLockTimeout(writeLockTimeout);
}
/**
* Returns default write lock timeout for newly
* instantiated IndexWriters.
* @see #setDefaultWriteLockTimeout
* @deprecated use {@link IndexWriterConfig#getDefaultWriteLockTimeout()} instead
*/
@Deprecated
public static long getDefaultWriteLockTimeout() {
return IndexWriterConfig.getDefaultWriteLockTimeout();
}
/** /**
* Commits all changes to an index and closes all * Commits all changes to an index and closes all
* associated files. Note that this may be a costly * associated files. Note that this may be a costly
@ -3030,7 +2302,7 @@ public class IndexWriter implements Closeable {
} }
// Now create the compound file if needed // Now create the compound file if needed
if (mergePolicy instanceof LogMergePolicy && getUseCompoundFile()) { if (mergePolicy instanceof LogMergePolicy && ((LogMergePolicy) mergePolicy).getUseCompoundFile()) {
List<String> files = null; List<String> files = null;
@ -3998,7 +3270,7 @@ public class IndexWriter implements Closeable {
} }
} }
private final synchronized void closeMergeReaders(MergePolicy.OneMerge merge, boolean suppressExceptions) throws IOException { private synchronized void closeMergeReaders(MergePolicy.OneMerge merge, boolean suppressExceptions) throws IOException {
final int numSegments = merge.segments.size(); final int numSegments = merge.segments.size();
if (suppressExceptions) { if (suppressExceptions) {
// Suppress any new exceptions so we throw the // Suppress any new exceptions so we throw the
@ -4043,7 +3315,7 @@ public class IndexWriter implements Closeable {
/** Does the actual (time-consuming) work of the merge, /** Does the actual (time-consuming) work of the merge,
* but without holding synchronized lock on IndexWriter * but without holding synchronized lock on IndexWriter
* instance */ * instance */
final private int mergeMiddle(MergePolicy.OneMerge merge) private int mergeMiddle(MergePolicy.OneMerge merge)
throws CorruptIndexException, IOException { throws CorruptIndexException, IOException {
merge.checkAborted(directory); merge.checkAborted(directory);
@ -4507,63 +3779,6 @@ public class IndexWriter implements Closeable {
directory.makeLock(IndexWriter.WRITE_LOCK_NAME).release(); directory.makeLock(IndexWriter.WRITE_LOCK_NAME).release();
} }
/**
* Specifies maximum field length (in number of tokens/terms) in
* {@link IndexWriter} constructors. {@link #setMaxFieldLength(int)} overrides
* the value set by the constructor.
*
* @deprecated use {@link IndexWriterConfig} and pass
* {@link IndexWriterConfig#UNLIMITED_FIELD_LENGTH} or your own
* value.
*/
@Deprecated
public static final class MaxFieldLength {
private int limit;
private String name;
/**
* Private type-safe-enum-pattern constructor.
*
* @param name instance name
* @param limit maximum field length
*/
private MaxFieldLength(String name, int limit) {
this.name = name;
this.limit = limit;
}
/**
* Public constructor to allow users to specify the maximum field size limit.
*
* @param limit The maximum field length
*/
public MaxFieldLength(int limit) {
this("User-specified", limit);
}
public int getLimit() {
return limit;
}
@Override
public String toString()
{
return name + ":" + limit;
}
/** Sets the maximum field length to {@link Integer#MAX_VALUE}. */
public static final MaxFieldLength UNLIMITED
= new MaxFieldLength("UNLIMITED", Integer.MAX_VALUE);
/**
* Sets the maximum field length to
* {@link #DEFAULT_MAX_FIELD_LENGTH}
* */
public static final MaxFieldLength LIMITED
= new MaxFieldLength("LIMITED", DEFAULT_MAX_FIELD_LENGTH);
}
/** If {@link #getReader} has been called (ie, this writer /** If {@link #getReader} has been called (ie, this writer
* is in near real-time mode), then after a merge * is in near real-time mode), then after a merge
* completes, this class can be invoked to warm the * completes, this class can be invoked to warm the
@ -4582,31 +3797,6 @@ public class IndexWriter implements Closeable {
private IndexReaderWarmer mergedSegmentWarmer; private IndexReaderWarmer mergedSegmentWarmer;
/**
* Set the merged segment warmer. See {@link IndexReaderWarmer}.
*
* @deprecated use
* {@link IndexWriterConfig#setMergedSegmentWarmer}
* instead.
*/
@Deprecated
public void setMergedSegmentWarmer(IndexReaderWarmer warmer) {
mergedSegmentWarmer = warmer;
// Required so config.getMergedSegmentWarmer returns the right value. But
// this will go away together with the method in 4.0.
config.setMergedSegmentWarmer(mergedSegmentWarmer);
}
/**
* Returns the current merged segment warmer. See {@link IndexReaderWarmer}.
*
* @deprecated use {@link IndexWriterConfig#getMergedSegmentWarmer()} instead.
*/
@Deprecated
public IndexReaderWarmer getMergedSegmentWarmer() {
return mergedSegmentWarmer;
}
private void handleOOM(OutOfMemoryError oom, String location) { private void handleOOM(OutOfMemoryError oom, String location) {
if (infoStream != null) { if (infoStream != null) {
message("hit OutOfMemoryError inside " + location); message("hit OutOfMemoryError inside " + location);

View File

@ -1240,33 +1240,6 @@ public class SegmentReader extends IndexReader implements Cloneable {
public final Object getCoreCacheKey() { public final Object getCoreCacheKey() {
return core; return core;
} }
/**
* Lotsa tests did hacks like:<br/>
* SegmentReader reader = (SegmentReader) IndexReader.open(dir);<br/>
* They broke. This method serves as a hack to keep hacks working
* We do it with R/W access for the tests (BW compatibility)
* @deprecated Remove this when tests are fixed!
*/
@Deprecated
static SegmentReader getOnlySegmentReader(Directory dir) throws IOException {
return getOnlySegmentReader(IndexReader.open(dir, false));
}
static SegmentReader getOnlySegmentReader(IndexReader reader) {
if (reader instanceof SegmentReader)
return (SegmentReader) reader;
if (reader instanceof DirectoryReader) {
IndexReader[] subReaders = reader.getSequentialSubReaders();
if (subReaders.length != 1)
throw new IllegalArgumentException(reader + " has " + subReaders.length + " segments instead of exactly one");
return (SegmentReader) subReaders[0];
}
throw new IllegalArgumentException(reader + " is not a SegmentReader or a single-segment DirectoryReader");
}
@Override @Override
public int getTermInfosIndexDivisor() { public int getTermInfosIndexDivisor() {

View File

@ -168,7 +168,7 @@ public final class Term implements Comparable<Term>, java.io.Serializable {
BytesRef.getUTF8SortedAsUTF16Comparator(); BytesRef.getUTF8SortedAsUTF16Comparator();
/** /**
* @deprecated For internal backwards compatibility use only * @deprecated (4.0) For internal backwards compatibility use only
* @lucene.internal * @lucene.internal
*/ */
@Deprecated @Deprecated

View File

@ -32,7 +32,7 @@ import org.apache.lucene.index.codecs.FieldsProducer;
* format. It does not provide a writer because newly * format. It does not provide a writer because newly
* written segments should use StandardCodec. * written segments should use StandardCodec.
* *
* @deprecated This is only used to read indexes created * @deprecated (4.0) This is only used to read indexes created
* before 4.0. * before 4.0.
* @lucene.experimental * @lucene.experimental
*/ */

View File

@ -44,7 +44,10 @@ import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.UnicodeUtil; import org.apache.lucene.util.UnicodeUtil;
/** Exposes flex API on a pre-flex index, as a codec. /** Exposes flex API on a pre-flex index, as a codec.
* @lucene.experimental */ * @lucene.experimental
* @deprecated (4.0)
*/
@Deprecated
public class PreFlexFields extends FieldsProducer { public class PreFlexFields extends FieldsProducer {
private static final boolean DEBUG_SURROGATES = false; private static final boolean DEBUG_SURROGATES = false;

View File

@ -26,7 +26,7 @@ import org.apache.lucene.index.codecs.standard.DefaultSkipListReader;
import org.apache.lucene.store.IndexInput; import org.apache.lucene.store.IndexInput;
import org.apache.lucene.util.Bits; import org.apache.lucene.util.Bits;
/** @deprecated /** @deprecated (4.0)
* @lucene.experimental */ * @lucene.experimental */
@Deprecated @Deprecated
public class SegmentTermDocs { public class SegmentTermDocs {

View File

@ -26,7 +26,7 @@ import org.apache.lucene.index.IndexFormatTooOldException;
import org.apache.lucene.index.IndexFormatTooNewException; import org.apache.lucene.index.IndexFormatTooNewException;
/** /**
* @deprecated No longer used with flex indexing, except for * @deprecated (4.0) No longer used with flex indexing, except for
* reading old segments * reading old segments
* @lucene.experimental */ * @lucene.experimental */

View File

@ -23,7 +23,11 @@ import org.apache.lucene.index.FieldInfos;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.store.IndexInput; import org.apache.lucene.store.IndexInput;
/** @lucene.experimental */ /**
* @lucene.experimental
* @deprecated (4.0)
*/
@Deprecated
public final class SegmentTermPositions public final class SegmentTermPositions
extends SegmentTermDocs { extends SegmentTermDocs {
private IndexInput proxStream; private IndexInput proxStream;

View File

@ -25,6 +25,11 @@ import org.apache.lucene.util.BytesRef;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.index.FieldInfos; import org.apache.lucene.index.FieldInfos;
/**
* @lucene.experimental
* @deprecated (4.0)
*/
@Deprecated
final class TermBuffer implements Cloneable { final class TermBuffer implements Cloneable {
private String field; private String field;

View File

@ -19,7 +19,7 @@ package org.apache.lucene.index.codecs.preflex;
/** A TermInfo is the record of information stored for a /** A TermInfo is the record of information stored for a
* term * term
* @deprecated This class is no longer used in flexible * @deprecated (4.0) This class is no longer used in flexible
* indexing. */ * indexing. */
@Deprecated @Deprecated

View File

@ -30,7 +30,7 @@ import org.apache.lucene.util.DoubleBarrelLRUCache;
/** This stores a monotonically increasing set of <Term, TermInfo> pairs in a /** This stores a monotonically increasing set of <Term, TermInfo> pairs in a
* Directory. Pairs are accessed either by Term or by ordinal position the * Directory. Pairs are accessed either by Term or by ordinal position the
* set * set
* @deprecated This class has been replaced by * @deprecated (4.0) This class has been replaced by
* FormatPostingsTermsDictReader, except for reading old segments. * FormatPostingsTermsDictReader, except for reading old segments.
* @lucene.experimental * @lucene.experimental
*/ */

View File

@ -28,14 +28,14 @@ public interface CharStream {
/** /**
* Returns the column position of the character last read. * Returns the column position of the character last read.
* @deprecated * @deprecated (gen)
* @see #getEndColumn * @see #getEndColumn
*/ */
int getColumn(); int getColumn();
/** /**
* Returns the line number of the character last read. * Returns the line number of the character last read.
* @deprecated * @deprecated (gen)
* @see #getEndLine * @see #getEndLine
*/ */
int getLine(); int getLine();

View File

@ -18,7 +18,6 @@ import org.apache.lucene.analysis.CachingTokenFilter;
import org.apache.lucene.analysis.TokenStream; import org.apache.lucene.analysis.TokenStream;
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;
import org.apache.lucene.document.DateField;
import org.apache.lucene.document.DateTools; import org.apache.lucene.document.DateTools;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanClause; import org.apache.lucene.search.BooleanClause;
@ -77,10 +76,8 @@ import org.apache.lucene.util.VirtualMethod;
* <tt>date:[6/1/2005 TO 6/4/2005]</tt> produces a range query that searches * <tt>date:[6/1/2005 TO 6/4/2005]</tt> produces a range query that searches
* for "date" fields between 2005-06-01 and 2005-06-04. Note that the format * for "date" fields between 2005-06-01 and 2005-06-04. Note that the format
* of the accepted input depends on {@link #setLocale(Locale) the locale}. * of the accepted input depends on {@link #setLocale(Locale) the locale}.
* By default a date is converted into a search term using the deprecated * A {@link org.apache.lucene.document.DateTools.Resolution} has to be set,
* {@link DateField} for compatibility reasons. * if you want to use {@link DateTools} for date conversion.
* To use the new {@link DateTools} to convert dates, a
* {@link org.apache.lucene.document.DateTools.Resolution} has to be set.
* </p> * </p>
* <p> * <p>
* The date resolution that shall be used for RangeQueries can be set * The date resolution that shall be used for RangeQueries can be set
@ -91,10 +88,9 @@ import org.apache.lucene.util.VirtualMethod;
* resolutions take, if set, precedence over the default date resolution. * resolutions take, if set, precedence over the default date resolution.
* </p> * </p>
* <p> * <p>
* If you use neither {@link DateField} nor {@link DateTools} in your * If you don't use {@link DateTools} in your index, you can create your own
* index, you can create your own
* query parser that inherits QueryParser and overwrites * query parser that inherits QueryParser and overwrites
* {@link #getRangeQuery(String, String, String, boolean)} to * {@link #getRangeQuery(String, String, String, boolean, boolean)} to
* use a different method for date conversion. * use a different method for date conversion.
* </p> * </p>
* *
@ -108,8 +104,6 @@ import org.apache.lucene.util.VirtualMethod;
* <p><b>NOTE</b>: You must specify the required {@link Version} * <p><b>NOTE</b>: You must specify the required {@link Version}
* compatibility when creating QueryParser: * compatibility when creating QueryParser:
* <ul> * <ul>
* <li> As of 2.9, {@link #setEnablePositionIncrements} is true by
* default.
* <li> As of 3.1, {@link #setAutoGeneratePhraseQueries} is false by * <li> As of 3.1, {@link #setAutoGeneratePhraseQueries} is false by
* default. * default.
* </ul> * </ul>

View File

@ -42,7 +42,6 @@ import org.apache.lucene.analysis.CachingTokenFilter;
import org.apache.lucene.analysis.TokenStream; import org.apache.lucene.analysis.TokenStream;
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;
import org.apache.lucene.document.DateField;
import org.apache.lucene.document.DateTools; import org.apache.lucene.document.DateTools;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanClause; import org.apache.lucene.search.BooleanClause;
@ -101,10 +100,8 @@ import org.apache.lucene.util.VirtualMethod;
* <tt>date:[6/1/2005 TO 6/4/2005]</tt> produces a range query that searches * <tt>date:[6/1/2005 TO 6/4/2005]</tt> produces a range query that searches
* for "date" fields between 2005-06-01 and 2005-06-04. Note that the format * for "date" fields between 2005-06-01 and 2005-06-04. Note that the format
* of the accepted input depends on {@link #setLocale(Locale) the locale}. * of the accepted input depends on {@link #setLocale(Locale) the locale}.
* By default a date is converted into a search term using the deprecated * A {@link org.apache.lucene.document.DateTools.Resolution} has to be set,
* {@link DateField} for compatibility reasons. * if you want to use {@link DateTools} for date conversion.
* To use the new {@link DateTools} to convert dates, a
* {@link org.apache.lucene.document.DateTools.Resolution} has to be set.
* </p> * </p>
* <p> * <p>
* The date resolution that shall be used for RangeQueries can be set * The date resolution that shall be used for RangeQueries can be set
@ -115,10 +112,9 @@ import org.apache.lucene.util.VirtualMethod;
* resolutions take, if set, precedence over the default date resolution. * resolutions take, if set, precedence over the default date resolution.
* </p> * </p>
* <p> * <p>
* If you use neither {@link DateField} nor {@link DateTools} in your * If you don't use {@link DateTools} in your index, you can create your own
* index, you can create your own
* query parser that inherits QueryParser and overwrites * query parser that inherits QueryParser and overwrites
* {@link #getRangeQuery(String, String, String, boolean)} to * {@link #getRangeQuery(String, String, String, boolean, boolean)} to
* use a different method for date conversion. * use a different method for date conversion.
* </p> * </p>
* *
@ -132,8 +128,6 @@ import org.apache.lucene.util.VirtualMethod;
* <p><b>NOTE</b>: You must specify the required {@link Version} * <p><b>NOTE</b>: You must specify the required {@link Version}
* compatibility when creating QueryParser: * compatibility when creating QueryParser:
* <ul> * <ul>
* <li> As of 2.9, {@link #setEnablePositionIncrements} is true by
* default.
* <li> As of 3.1, {@link #setAutoGeneratePhraseQueries} is false by * <li> As of 3.1, {@link #setAutoGeneratePhraseQueries} is false by
* default. * default.
* </ul> * </ul>

View File

@ -17,26 +17,24 @@
package org.apache.lucene.queryParser; package org.apache.lucene.queryParser;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.CachingTokenFilter;
import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute;
import org.apache.lucene.analysis.tokenattributes.TermToBytesRefAttribute;
import org.apache.lucene.document.DateField;
import org.apache.lucene.document.DateTools;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.*;
import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.Version;
import org.apache.lucene.util.VirtualMethod;
import org.apache.lucene.queryParser.QueryParser.Operator;
import java.io.IOException; import java.io.IOException;
import java.io.StringReader; import java.io.StringReader;
import java.text.Collator; import java.text.Collator;
import java.text.DateFormat; import java.text.DateFormat;
import java.util.*; import java.util.*;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.CachingTokenFilter;
import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.analysis.tokenattributes.PositionIncrementAttribute;
import org.apache.lucene.analysis.tokenattributes.TermToBytesRefAttribute;
import org.apache.lucene.document.DateTools;
import org.apache.lucene.index.Term;
import org.apache.lucene.queryParser.QueryParser.Operator;
import org.apache.lucene.search.*;
import org.apache.lucene.util.BytesRef;
import org.apache.lucene.util.Version;
/** This class is overridden by QueryParser in QueryParser.jj /** This class is overridden by QueryParser in QueryParser.jj
* and acts to eparate the majority of the Java code from the .jj grammar file. * and acts to eparate the majority of the Java code from the .jj grammar file.
*/ */
@ -84,20 +82,6 @@ public abstract class QueryParserBase {
// for use when constructing RangeQuerys. // for use when constructing RangeQuerys.
Collator rangeCollator = null; Collator rangeCollator = null;
/** @deprecated remove when getFieldQuery is removed */
@Deprecated
static final VirtualMethod<QueryParserBase> getFieldQueryMethod =
new VirtualMethod<QueryParserBase>(QueryParserBase.class, "getFieldQuery", String.class, String.class);
/** @deprecated remove when getFieldQuery is removed */
@Deprecated
static final VirtualMethod<QueryParserBase> getFieldQueryWithQuotedMethod =
new VirtualMethod<QueryParserBase>(QueryParserBase.class, "getFieldQuery", String.class, String.class, boolean.class);
/** @deprecated remove when getFieldQuery is removed */
@Deprecated
final boolean hasNewAPI =
VirtualMethod.compareImplementationDistance(getClass(),
getFieldQueryWithQuotedMethod, getFieldQueryMethod) >= 0; // its ok for both to be overridden
boolean autoGeneratePhraseQueries; boolean autoGeneratePhraseQueries;
// So the generated QueryParser(CharStream) won't error out // So the generated QueryParser(CharStream) won't error out
@ -112,11 +96,6 @@ public abstract class QueryParserBase {
public void init(Version matchVersion, String f, Analyzer a) { public void init(Version matchVersion, String f, Analyzer a) {
analyzer = a; analyzer = a;
field = f; field = f;
if (matchVersion.onOrAfter(Version.LUCENE_29)) {
enablePositionIncrements = true;
} else {
enablePositionIncrements = false;
}
if (matchVersion.onOrAfter(Version.LUCENE_31)) { if (matchVersion.onOrAfter(Version.LUCENE_31)) {
setAutoGeneratePhraseQueries(false); setAutoGeneratePhraseQueries(false);
} else { } else {
@ -190,9 +169,6 @@ public abstract class QueryParserBase {
* surrounded by double quotes. * surrounded by double quotes.
*/ */
public final void setAutoGeneratePhraseQueries(boolean value) { public final void setAutoGeneratePhraseQueries(boolean value) {
if (value == false && !hasNewAPI)
throw new IllegalArgumentException("You must implement the new API: getFieldQuery(String,String,boolean)"
+ " to use setAutoGeneratePhraseQueries(false)");
this.autoGeneratePhraseQueries = value; this.autoGeneratePhraseQueries = value;
} }
@ -272,7 +248,7 @@ public abstract class QueryParserBase {
* Useful when e.g. a StopFilter increases the position increment of * Useful when e.g. a StopFilter increases the position increment of
* the token that follows an omitted token. * the token that follows an omitted token.
* <p> * <p>
* Default: false. * Default: true.
*/ */
public void setEnablePositionIncrements(boolean enable) { public void setEnablePositionIncrements(boolean enable) {
this.enablePositionIncrements = enable; this.enablePositionIncrements = enable;
@ -488,15 +464,6 @@ public abstract class QueryParserBase {
throw new RuntimeException("Clause cannot be both required and prohibited"); throw new RuntimeException("Clause cannot be both required and prohibited");
} }
/**
* @deprecated Use {@link #getFieldQuery(String,String,boolean)} instead.
*/
@Deprecated
protected Query getFieldQuery(String field, String queryText) throws ParseException {
// treat the text as if it was quoted, to drive phrase logic with old versions.
return getFieldQuery(field, queryText, true);
}
/** /**
* @exception org.apache.lucene.queryParser.ParseException throw in overridden method to disallow * @exception org.apache.lucene.queryParser.ParseException throw in overridden method to disallow
*/ */
@ -684,7 +651,7 @@ public abstract class QueryParserBase {
*/ */
protected Query getFieldQuery(String field, String queryText, int slop) protected Query getFieldQuery(String field, String queryText, int slop)
throws ParseException { throws ParseException {
Query query = hasNewAPI ? getFieldQuery(field, queryText, true) : getFieldQuery(field, queryText); Query query = getFieldQuery(field, queryText, true);
if (query instanceof PhraseQuery) { if (query instanceof PhraseQuery) {
((PhraseQuery) query).setSlop(slop); ((PhraseQuery) query).setSlop(slop);
@ -696,11 +663,6 @@ public abstract class QueryParserBase {
return query; return query;
} }
@Deprecated
protected final Query getRangeQuery(String field, String part1, String part2, boolean inclusive) throws MethodRemovedUseAnother {return null;}
/** /**
* *
* @exception org.apache.lucene.queryParser.ParseException * @exception org.apache.lucene.queryParser.ParseException
@ -722,15 +684,7 @@ public abstract class QueryParserBase {
DateTools.Resolution resolution = getDateResolution(field); DateTools.Resolution resolution = getDateResolution(field);
try { try {
Date d1 = df.parse(part1); part1 = DateTools.dateToString(df.parse(part1), resolution);
if (resolution == null) {
// no default or field specific date resolution has been set,
// use deprecated DateField to maintain compatibility with
// pre-1.9 Lucene versions.
part1 = DateField.dateToString(d1);
} else {
part1 = DateTools.dateToString(d1, resolution);
}
} catch (Exception e) { } } catch (Exception e) { }
try { try {
@ -747,14 +701,7 @@ public abstract class QueryParserBase {
cal.set(Calendar.MILLISECOND, 999); cal.set(Calendar.MILLISECOND, 999);
d2 = cal.getTime(); d2 = cal.getTime();
} }
if (resolution == null) { part2 = DateTools.dateToString(d2, resolution);
// no default or field specific date resolution has been set,
// use deprecated DateField to maintain compatibility with
// pre-1.9 Lucene versions.
part2 = DateField.dateToString(d2);
} else {
part2 = DateTools.dateToString(d2, resolution);
}
} catch (Exception e) { } } catch (Exception e) { }
return newRangeQuery(field, part1, part2, startInclusive, endInclusive); return newRangeQuery(field, part1, part2, startInclusive, endInclusive);
@ -838,10 +785,6 @@ public abstract class QueryParserBase {
return new FuzzyQuery(term,minimumSimilarity,prefixLength); return new FuzzyQuery(term,minimumSimilarity,prefixLength);
} }
@Deprecated
protected final Query newRangeQuery(String field, String part1, String part2, boolean inclusive) throws MethodRemovedUseAnother {return null;}
/** /**
* Builds a new TermRangeQuery instance * Builds a new TermRangeQuery instance
* @param field Field * @param field Field
@ -1064,7 +1007,7 @@ public abstract class QueryParserBase {
} }
q = getFuzzyQuery(qfield, termImage, fms); q = getFuzzyQuery(qfield, termImage, fms);
} else { } else {
q = hasNewAPI ? getFieldQuery(qfield, termImage, false) : getFieldQuery(qfield, termImage); q = getFieldQuery(qfield, termImage, false);
} }
return q; return q;
} }

View File

@ -16,7 +16,6 @@ import org.apache.lucene.analysis.CachingTokenFilter;
import org.apache.lucene.analysis.TokenStream; import org.apache.lucene.analysis.TokenStream;
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;
import org.apache.lucene.document.DateField;
import org.apache.lucene.document.DateTools; import org.apache.lucene.document.DateTools;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanClause; import org.apache.lucene.search.BooleanClause;

View File

@ -193,7 +193,7 @@ class BooleanScorer2 extends Scorer {
} }
private Scorer dualConjunctionSumScorer(Scorer req1, Scorer req2) throws IOException { // non counting. private Scorer dualConjunctionSumScorer(Scorer req1, Scorer req2) throws IOException { // non counting.
return new ConjunctionScorer(defaultSimilarity, new Scorer[]{req1, req2}); return new ConjunctionScorer(defaultSimilarity, req1, req2);
// All scorers match, so defaultSimilarity always has 1 as // All scorers match, so defaultSimilarity always has 1 as
// the coordination factor. // the coordination factor.
// Therefore the sum of the scores of two scorers // Therefore the sum of the scores of two scorers

View File

@ -18,15 +18,15 @@ package org.apache.lucene.search;
*/ */
import java.io.IOException;
import java.io.Serializable;
import java.util.Collection;
import org.apache.lucene.index.FieldInvertState; import org.apache.lucene.index.FieldInvertState;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
import org.apache.lucene.search.Explanation.IDFExplanation; import org.apache.lucene.search.Explanation.IDFExplanation;
import org.apache.lucene.util.SmallFloat; import org.apache.lucene.util.SmallFloat;
import java.io.IOException;
import java.io.Serializable;
import java.util.Collection;
/** /**
* Expert: Scoring API. * Expert: Scoring API.
@ -562,16 +562,6 @@ public abstract class Similarity implements Serializable {
NORM_TABLE[i] = SmallFloat.byte315ToFloat((byte)i); NORM_TABLE[i] = SmallFloat.byte315ToFloat((byte)i);
} }
/**
* Decodes a normalization factor stored in an index.
* @see #decodeNormValue(byte)
* @deprecated Use {@link #decodeNormValue} instead.
*/
@Deprecated
public static float decodeNorm(byte b) {
return NORM_TABLE[b & 0xFF]; // & 0xFF maps negative bytes to positive above 127
}
/** Decodes a normalization factor stored in an index. /** Decodes a normalization factor stored in an index.
* @see #encodeNormValue(float) * @see #encodeNormValue(float)
*/ */
@ -579,17 +569,6 @@ public abstract class Similarity implements Serializable {
return NORM_TABLE[b & 0xFF]; // & 0xFF maps negative bytes to positive above 127 return NORM_TABLE[b & 0xFF]; // & 0xFF maps negative bytes to positive above 127
} }
/** Returns a table for decoding normalization bytes.
* @see #encodeNormValue(float)
* @see #decodeNormValue(byte)
*
* @deprecated Use instance methods for encoding/decoding norm values to enable customization.
*/
@Deprecated
public static float[] getNormDecoder() {
return NORM_TABLE;
}
/** /**
* Compute the normalization value for a field, given the accumulated * Compute the normalization value for a field, given the accumulated
* state of term processing for this field (see {@link FieldInvertState}). * state of term processing for this field (see {@link FieldInvertState}).
@ -670,20 +649,6 @@ public abstract class Similarity implements Serializable {
return SmallFloat.floatToByte315(f); return SmallFloat.floatToByte315(f);
} }
/**
* Static accessor kept for backwards compability reason, use encodeNormValue instead.
* @param f norm-value to encode
* @return byte representing the given float
* @deprecated Use {@link #encodeNormValue} instead.
*
* @see #encodeNormValue(float)
*/
@Deprecated
public static byte encodeNorm(float f) {
return SmallFloat.floatToByte315(f);
}
/** Computes a score factor based on a term or phrase's frequency in a /** Computes a score factor based on a term or phrase's frequency in a
* document. This value is multiplied by the {@link #idf(int, int)} * document. This value is multiplied by the {@link #idf(int, int)}
* factor for each term in the query and these products are then summed to * factor for each term in the query and these products are then summed to

View File

@ -21,13 +21,7 @@ import java.io.IOException;
import java.io.Serializable; import java.io.Serializable;
import java.util.Locale; import java.util.Locale;
import org.apache.lucene.search.cache.ByteValuesCreator; import org.apache.lucene.search.cache.*;
import org.apache.lucene.search.cache.CachedArrayCreator;
import org.apache.lucene.search.cache.DoubleValuesCreator;
import org.apache.lucene.search.cache.FloatValuesCreator;
import org.apache.lucene.search.cache.IntValuesCreator;
import org.apache.lucene.search.cache.LongValuesCreator;
import org.apache.lucene.search.cache.ShortValuesCreator;
import org.apache.lucene.util.StringHelper; import org.apache.lucene.util.StringHelper;
/** /**
@ -138,7 +132,7 @@ implements Serializable {
* @throws IllegalArgumentException if the parser fails to * @throws IllegalArgumentException if the parser fails to
* subclass an existing numeric parser, or field is null * subclass an existing numeric parser, or field is null
* *
* @deprecated use EntryCreator version * @deprecated (4.0) use EntryCreator version
*/ */
@Deprecated @Deprecated
public SortField (String field, FieldCache.Parser parser) { public SortField (String field, FieldCache.Parser parser) {
@ -156,7 +150,7 @@ implements Serializable {
* @throws IllegalArgumentException if the parser fails to * @throws IllegalArgumentException if the parser fails to
* subclass an existing numeric parser, or field is null * subclass an existing numeric parser, or field is null
* *
* @deprecated use EntryCreator version * @deprecated (4.0) use EntryCreator version
*/ */
@Deprecated @Deprecated
public SortField (String field, FieldCache.Parser parser, boolean reverse) { public SortField (String field, FieldCache.Parser parser, boolean reverse) {
@ -314,7 +308,7 @@ implements Serializable {
/** Returns the instance of a {@link FieldCache} parser that fits to the given sort type. /** Returns the instance of a {@link FieldCache} parser that fits to the given sort type.
* May return <code>null</code> if no parser was specified. Sorting is using the default parser then. * May return <code>null</code> if no parser was specified. Sorting is using the default parser then.
* @return An instance of a {@link FieldCache} parser, or <code>null</code>. * @return An instance of a {@link FieldCache} parser, or <code>null</code>.
* @deprecated use getEntryCreator() * @deprecated (4.0) use getEntryCreator()
*/ */
@Deprecated @Deprecated
public FieldCache.Parser getParser() { public FieldCache.Parser getParser() {

View File

@ -20,10 +20,10 @@ package org.apache.lucene.search;
import java.io.IOException; import java.io.IOException;
import java.text.Collator; import java.text.Collator;
import org.apache.lucene.index.TermsEnum;
import org.apache.lucene.index.Terms; import org.apache.lucene.index.Terms;
import org.apache.lucene.util.ToStringUtils; import org.apache.lucene.index.TermsEnum;
import org.apache.lucene.util.AttributeSource; import org.apache.lucene.util.AttributeSource;
import org.apache.lucene.util.ToStringUtils;
/** /**
* A Query that matches documents within an range of terms. * A Query that matches documents within an range of terms.
@ -143,12 +143,6 @@ public class TermRangeQuery extends MultiTermQuery {
lowerTerm, upperTerm, includeLower, includeUpper, collator); lowerTerm, upperTerm, includeLower, includeUpper, collator);
} }
/** @deprecated */
@Deprecated
public String field() {
return getField();
}
/** Prints a user-readable version of this query. */ /** Prints a user-readable version of this query. */
@Override @Override
public String toString(String field) { public String toString(String field) {

View File

@ -19,9 +19,9 @@ package org.apache.lucene.search.function;
import java.io.IOException; import java.io.IOException;
import org.apache.lucene.util.ReaderUtil;
import org.apache.lucene.index.IndexReader; import org.apache.lucene.index.IndexReader;
import org.apache.lucene.search.Explanation; import org.apache.lucene.search.Explanation;
import org.apache.lucene.util.ReaderUtil;
/** This class wraps another ValueSource, but protects /** This class wraps another ValueSource, but protects
* against accidental double RAM usage in FieldCache when * against accidental double RAM usage in FieldCache when
@ -31,7 +31,7 @@ import org.apache.lucene.search.Explanation;
* lookup, as it must resolve the incoming document to the * lookup, as it must resolve the incoming document to the
* right sub-reader using a binary search.</p> * right sub-reader using a binary search.</p>
* *
* @deprecated This class is temporary, to ease the * @deprecated (4.0) This class is temporary, to ease the
* migration to segment-based searching. Please change your * migration to segment-based searching. Please change your
* code to not pass composite readers to these APIs. */ * code to not pass composite readers to these APIs. */

View File

@ -105,59 +105,6 @@ public abstract class DataOutput {
writeBytes(utf8Result.bytes, 0, utf8Result.length); writeBytes(utf8Result.bytes, 0, utf8Result.length);
} }
/** Writes a sub sequence of characters from s as the old
* format (modified UTF-8 encoded bytes).
* @param s the source of the characters
* @param start the first character in the sequence
* @param length the number of characters in the sequence
* @deprecated -- please pre-convert to utf8 bytes
* instead or use {@link #writeString}
*/
@Deprecated
public void writeChars(String s, int start, int length)
throws IOException {
final int end = start + length;
for (int i = start; i < end; i++) {
final int code = s.charAt(i);
if (code >= 0x01 && code <= 0x7F)
writeByte((byte)code);
else if (((code >= 0x80) && (code <= 0x7FF)) || code == 0) {
writeByte((byte)(0xC0 | (code >> 6)));
writeByte((byte)(0x80 | (code & 0x3F)));
} else {
writeByte((byte)(0xE0 | (code >>> 12)));
writeByte((byte)(0x80 | ((code >> 6) & 0x3F)));
writeByte((byte)(0x80 | (code & 0x3F)));
}
}
}
/** Writes a sub sequence of characters from char[] as
* the old format (modified UTF-8 encoded bytes).
* @param s the source of the characters
* @param start the first character in the sequence
* @param length the number of characters in the sequence
* @deprecated -- please pre-convert to utf8 bytes instead or use {@link #writeString}
*/
@Deprecated
public void writeChars(char[] s, int start, int length)
throws IOException {
final int end = start + length;
for (int i = start; i < end; i++) {
final int code = s[i];
if (code >= 0x01 && code <= 0x7F)
writeByte((byte)code);
else if (((code >= 0x80) && (code <= 0x7FF)) || code == 0) {
writeByte((byte)(0xC0 | (code >> 6)));
writeByte((byte)(0x80 | (code & 0x3F)));
} else {
writeByte((byte)(0xE0 | (code >>> 12)));
writeByte((byte)(0x80 | ((code >> 6) & 0x3F)));
writeByte((byte)(0x80 | (code & 0x3F)));
}
}
}
private static int COPY_BUFFER_SIZE = 16384; private static int COPY_BUFFER_SIZE = 16384;
private byte[] copyBuffer; private byte[] copyBuffer;

View File

@ -94,19 +94,6 @@ public abstract class Directory implements Closeable {
public abstract IndexOutput createOutput(String name) public abstract IndexOutput createOutput(String name)
throws IOException; throws IOException;
/**
* Ensure that any writes to this file are moved to
* stable storage. Lucene uses this to properly commit
* changes to the index, to prevent a machine/OS crash
* from corrupting the index.
* @deprecated use {@link #sync(Collection)} instead.
* For easy migration you can change your code to call
* sync(Collections.singleton(name))
*/
@Deprecated
public void sync(String name) throws IOException { // TODO 4.0 kill me
}
/** /**
* Ensure that any writes to these files are moved to * Ensure that any writes to these files are moved to
* stable storage. Lucene uses this to properly commit * stable storage. Lucene uses this to properly commit
@ -118,10 +105,7 @@ public abstract class Directory implements Closeable {
* For other impls the operation can be a noop, for various * For other impls the operation can be a noop, for various
* reasons. * reasons.
*/ */
public void sync(Collection<String> names) throws IOException { // TODO 4.0 make me abstract public abstract void sync(Collection<String> names) throws IOException;
for (String name : names)
sync(name);
}
/** Returns a stream reading an existing file. */ /** Returns a stream reading an existing file. */
public abstract IndexInput openInput(String name) public abstract IndexInput openInput(String name)
@ -232,41 +216,6 @@ public abstract class Directory implements Closeable {
} }
} }
/**
* Copy contents of a directory src to a directory dest. If a file in src
* already exists in dest then the one in dest will be blindly overwritten.
* <p>
* <b>NOTE:</b> the source directory cannot change while this method is
* running. Otherwise the results are undefined and you could easily hit a
* FileNotFoundException.
* <p>
* <b>NOTE:</b> this method only copies files that look like index files (ie,
* have extensions matching the known extensions of index files).
*
* @param src source directory
* @param dest destination directory
* @param closeDirSrc if <code>true</code>, call {@link #close()} method on
* source directory
* @deprecated should be replaced with calls to
* {@link #copy(Directory, String, String)} for every file that
* needs copying. You can use the following code:
*
* <pre>
* for (String file : src.listAll()) {
* src.copy(dest, file, file);
* }
* </pre>
*/
@Deprecated
public static void copy(Directory src, Directory dest, boolean closeDirSrc) throws IOException {
for (String file : src.listAll()) {
src.copy(dest, file, file);
}
if (closeDirSrc) {
src.close();
}
}
/** /**
* @throws AlreadyClosedException if this Directory is closed * @throws AlreadyClosedException if this Directory is closed
*/ */

View File

@ -321,12 +321,6 @@ public abstract class FSDirectory extends Directory {
staleFiles.add(io.name); staleFiles.add(io.name);
} }
@Deprecated
@Override
public void sync(String name) throws IOException {
sync(Collections.singleton(name));
}
@Override @Override
public void sync(Collection<String> names) throws IOException { public void sync(Collection<String> names) throws IOException {
ensureOpen(); ensureOpen();
@ -383,12 +377,6 @@ public abstract class FSDirectory extends Directory {
isOpen = false; isOpen = false;
} }
/** @deprecated Use {@link #getDirectory} instead. */
@Deprecated
public File getFile() {
return getDirectory();
}
/** @return the underlying filesystem directory */ /** @return the underlying filesystem directory */
public File getDirectory() { public File getDirectory() {
ensureOpen(); ensureOpen();

View File

@ -135,12 +135,6 @@ public class FileSwitchDirectory extends Directory {
return getDirectory(name).createOutput(name); return getDirectory(name).createOutput(name);
} }
@Deprecated
@Override
public void sync(String name) throws IOException {
sync(Collections.singleton(name));
}
@Override @Override
public void sync(Collection<String> names) throws IOException { public void sync(Collection<String> names) throws IOException {
List<String> primaryNames = new ArrayList<String>(); List<String> primaryNames = new ArrayList<String>();

View File

@ -33,14 +33,7 @@ public class NoLockFactory extends LockFactory {
private static NoLock singletonLock = new NoLock(); private static NoLock singletonLock = new NoLock();
private static NoLockFactory singleton = new NoLockFactory(); private static NoLockFactory singleton = new NoLockFactory();
/** private NoLockFactory() {}
* @deprecated This constructor was not intended to be public and should not be used.
* It will be made private in Lucene 4.0
* @see #getNoLockFactory()
*/
// make private in 4.0!
@Deprecated
public NoLockFactory() {}
public static NoLockFactory getNoLockFactory() { public static NoLockFactory getNoLockFactory() {
return singleton; return singleton;

View File

@ -20,6 +20,7 @@ package org.apache.lucene.store;
import java.io.IOException; import java.io.IOException;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.Serializable; import java.io.Serializable;
import java.util.Collection;
import java.util.Map; import java.util.Map;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicLong;
@ -187,6 +188,9 @@ public class RAMDirectory extends Directory implements Serializable {
return new RAMFile(this); return new RAMFile(this);
} }
public void sync(Collection<String> names) throws IOException {
}
/** Returns a stream reading an existing file. */ /** Returns a stream reading an existing file. */
@Override @Override
public IndexInput openInput(String name) throws IOException { public IndexInput openInput(String name) throws IOException {

View File

@ -37,19 +37,6 @@ import java.nio.ByteBuffer;
* problem, a char is appended, indicating the number of encoded bytes in the * problem, a char is appended, indicating the number of encoded bytes in the
* final content char. * final content char.
* <p/> * <p/>
* Some methods in this class are defined over CharBuffers and ByteBuffers, but
* these are deprecated in favor of methods that operate directly on byte[] and
* char[] arrays. Note that this class calls array() and arrayOffset()
* on the CharBuffers and ByteBuffers it uses, so only wrapped arrays may be
* used. This class interprets the arrayOffset() and limit() values returned
* by its input buffers as beginning and end+1 positions on the wrapped array,
* respectively; similarly, on the output buffer, arrayOffset() is the first
* position written to, and limit() is set to one past the final output array
* position.
* <p/>
* WARNING: This means that the deprecated Buffer-based methods
* only work correctly with buffers that have an offset of 0. For example, they
* will not correctly interpret buffers returned by {@link ByteBuffer#slice}.
* *
* @lucene.experimental * @lucene.experimental
*/ */
@ -71,28 +58,6 @@ public final class IndexableBinaryStringTools {
// Export only static methods // Export only static methods
private IndexableBinaryStringTools() {} private IndexableBinaryStringTools() {}
/**
* Returns the number of chars required to encode the given byte sequence.
*
* @param original The byte sequence to be encoded. Must be backed by an
* array.
* @return The number of chars required to encode the given byte sequence
* @throws IllegalArgumentException If the given ByteBuffer is not backed by
* an array
* @deprecated Use {@link #getEncodedLength(byte[], int, int)} instead. This
* method will be removed in Lucene 4.0
*/
@Deprecated
public static int getEncodedLength(ByteBuffer original)
throws IllegalArgumentException {
if (original.hasArray()) {
return getEncodedLength(original.array(), original.arrayOffset(),
original.limit() - original.arrayOffset());
} else {
throw new IllegalArgumentException("original argument must have a backing array");
}
}
/** /**
* Returns the number of chars required to encode the given bytes. * Returns the number of chars required to encode the given bytes.
* *
@ -107,28 +72,6 @@ public final class IndexableBinaryStringTools {
return (int)((8L * inputLength + 14L) / 15L) + 1; return (int)((8L * inputLength + 14L) / 15L) + 1;
} }
/**
* Returns the number of bytes required to decode the given char sequence.
*
* @param encoded The char sequence to be decoded. Must be backed by an array.
* @return The number of bytes required to decode the given char sequence
* @throws IllegalArgumentException If the given CharBuffer is not backed by
* an array
* @deprecated Use {@link #getDecodedLength(char[], int, int)} instead. This
* method will be removed in Lucene 4.0
*/
@Deprecated
public static int getDecodedLength(CharBuffer encoded)
throws IllegalArgumentException {
if (encoded.hasArray()) {
return getDecodedLength(encoded.array(), encoded.arrayOffset(),
encoded.limit() - encoded.arrayOffset());
} else {
throw new IllegalArgumentException("encoded argument must have a backing array");
}
}
/** /**
* Returns the number of bytes required to decode the given char sequence. * Returns the number of bytes required to decode the given char sequence.
* *
@ -149,36 +92,6 @@ public final class IndexableBinaryStringTools {
} }
} }
/**
* Encodes the input byte sequence into the output char sequence. Before
* calling this method, ensure that the output CharBuffer has sufficient
* capacity by calling {@link #getEncodedLength(java.nio.ByteBuffer)}.
*
* @param input The byte sequence to encode
* @param output Where the char sequence encoding result will go. The limit is
* set to one past the position of the final char.
* @throws IllegalArgumentException If either the input or the output buffer
* is not backed by an array
* @deprecated Use {@link #encode(byte[], int, int, char[], int, int)}
* instead. This method will be removed in Lucene 4.0
*/
@Deprecated
public static void encode(ByteBuffer input, CharBuffer output) {
if (input.hasArray() && output.hasArray()) {
final int inputOffset = input.arrayOffset();
final int inputLength = input.limit() - inputOffset;
final int outputOffset = output.arrayOffset();
final int outputLength = getEncodedLength(input.array(), inputOffset,
inputLength);
output.limit(outputLength + outputOffset);
output.position(0);
encode(input.array(), inputOffset, inputLength, output.array(),
outputOffset, outputLength);
} else {
throw new IllegalArgumentException("Arguments must have backing arrays");
}
}
/** /**
* Encodes the input byte sequence into the output char sequence. Before * Encodes the input byte sequence into the output char sequence. Before
* calling this method, ensure that the output array has sufficient * calling this method, ensure that the output array has sufficient
@ -233,36 +146,6 @@ public final class IndexableBinaryStringTools {
} }
} }
/**
* Decodes the input char sequence into the output byte sequence. Before
* calling this method, ensure that the output ByteBuffer has sufficient
* capacity by calling {@link #getDecodedLength(java.nio.CharBuffer)}.
*
* @param input The char sequence to decode
* @param output Where the byte sequence decoding result will go. The limit is
* set to one past the position of the final char.
* @throws IllegalArgumentException If either the input or the output buffer
* is not backed by an array
* @deprecated Use {@link #decode(char[], int, int, byte[], int, int)}
* instead. This method will be removed in Lucene 4.0
*/
@Deprecated
public static void decode(CharBuffer input, ByteBuffer output) {
if (input.hasArray() && output.hasArray()) {
final int inputOffset = input.arrayOffset();
final int inputLength = input.limit() - inputOffset;
final int outputOffset = output.arrayOffset();
final int outputLength = getDecodedLength(input.array(), inputOffset,
inputLength);
output.limit(outputLength + outputOffset);
output.position(0);
decode(input.array(), inputOffset, inputLength, output.array(),
outputOffset, outputLength);
} else {
throw new IllegalArgumentException("Arguments must have backing arrays");
}
}
/** /**
* Decodes the input char sequence into the output byte sequence. Before * Decodes the input char sequence into the output byte sequence. Before
* calling this method, ensure that the output array has sufficient capacity * calling this method, ensure that the output array has sufficient capacity
@ -330,46 +213,6 @@ public final class IndexableBinaryStringTools {
} }
} }
/**
* Decodes the given char sequence, which must have been encoded by
* {@link #encode(java.nio.ByteBuffer)} or
* {@link #encode(java.nio.ByteBuffer, java.nio.CharBuffer)}.
*
* @param input The char sequence to decode
* @return A byte sequence containing the decoding result. The limit is set to
* one past the position of the final char.
* @throws IllegalArgumentException If the input buffer is not backed by an
* array
* @deprecated Use {@link #decode(char[], int, int, byte[], int, int)}
* instead. This method will be removed in Lucene 4.0
*/
@Deprecated
public static ByteBuffer decode(CharBuffer input) {
byte[] outputArray = new byte[getDecodedLength(input)];
ByteBuffer output = ByteBuffer.wrap(outputArray);
decode(input, output);
return output;
}
/**
* Encodes the input byte sequence.
*
* @param input The byte sequence to encode
* @return A char sequence containing the encoding result. The limit is set to
* one past the position of the final char.
* @throws IllegalArgumentException If the input buffer is not backed by an
* array
* @deprecated Use {@link #encode(byte[], int, int, char[], int, int)}
* instead. This method will be removed in Lucene 4.0
*/
@Deprecated
public static CharBuffer encode(ByteBuffer input) {
char[] outputArray = new char[getEncodedLength(input)];
CharBuffer output = CharBuffer.wrap(outputArray);
encode(input, output);
return output;
}
static class CodingCase { static class CodingCase {
int numBytes, initialShift, middleShift, finalShift, advanceBytes = 2; int numBytes, initialShift, middleShift, finalShift, advanceBytes = 2;
short middleMask, finalMask; short middleMask, finalMask;

View File

@ -17,10 +17,10 @@ package org.apache.lucene.util;
* limitations under the License. * limitations under the License.
*/ */
import org.apache.lucene.analysis.NumericTokenStream; // for javadocs import org.apache.lucene.analysis.NumericTokenStream;
import org.apache.lucene.document.NumericField; // for javadocs import org.apache.lucene.document.NumericField;
import org.apache.lucene.search.NumericRangeFilter;
import org.apache.lucene.search.NumericRangeQuery; // for javadocs import org.apache.lucene.search.NumericRangeQuery; // for javadocs
import org.apache.lucene.search.NumericRangeFilter; // for javadocs
// TODO: Remove the commented out methods before release! // TODO: Remove the commented out methods before release!
@ -130,32 +130,6 @@ public final class NumericUtils {
return hash; return hash;
} }
/*
* Returns prefix coded bits after reducing the precision by <code>shift</code> bits.
* This is method is used by {@link LongRangeBuilder}.
* @param val the numeric value
* @param shift how many bits to strip from the right
* @deprecated This method is no longer needed!
*
@Deprecated
public static String longToPrefixCoded(final long val, final int shift) {
final BytesRef buffer = new BytesRef(BUF_SIZE_LONG);
longToPrefixCoded(val, shift, buffer);
return buffer.utf8ToString();
}*/
/*
* This is a convenience method, that returns prefix coded bits of a long without
* reducing the precision. It can be used to store the full precision value as a
* stored field in index.
* <p>To decode, use {@link #prefixCodedToLong}.
* @deprecated This method is no longer needed!
*
@Deprecated
public static String longToPrefixCoded(final long val) {
return longToPrefixCoded(val, 0);
}*/
/** /**
* 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 NumericTokenStream}. * This is method is used by {@link NumericTokenStream}.
@ -190,46 +164,6 @@ public final class NumericUtils {
return hash; return hash;
} }
/*
* Returns prefix coded bits after reducing the precision by <code>shift</code> bits.
* This is method is used by {@link IntRangeBuilder}.
* @param val the numeric value
* @param shift how many bits to strip from the right
* @deprecated This method is no longer needed!
*
@Deprecated
public static String intToPrefixCoded(final int val, final int shift) {
final BytesRef buffer = new BytesRef(BUF_SIZE_INT);
intToPrefixCoded(val, shift, buffer);
return buffer.utf8ToString();
}*/
/*
* This is a convenience method, that returns prefix coded bits of an int without
* reducing the precision. It can be used to store the full precision value as a
* stored field in index.
* <p>To decode, use {@link #prefixCodedToInt}.
* @deprecated This method is no longer needed!
*
@Deprecated
public static String intToPrefixCoded(final int val) {
return intToPrefixCoded(val, 0);
}*/
/*
* Returns a long from prefixCoded characters.
* Rightmost bits will be zero for lower precision codes.
* This method can be used to decode e.g. a stored field.
* @throws NumberFormatException if the supplied string is
* not correctly prefix encoded.
* @see #longToPrefixCoded(long)
* @deprecated This method is no longer needed!
*
@Deprecated
public static long prefixCodedToLong(final String prefixCoded) {
return prefixCodedToLong(new BytesRef(prefixCoded));
}*/
/** /**
* Returns the shift value from a prefix encoded {@code long}. * Returns the shift value from a prefix encoded {@code long}.
* @throws NumberFormatException if the supplied {@link BytesRef} is * @throws NumberFormatException if the supplied {@link BytesRef} is
@ -278,21 +212,7 @@ public final class NumericUtils {
return (sortableBits << getPrefixCodedLongShift(val)) ^ 0x8000000000000000L; return (sortableBits << getPrefixCodedLongShift(val)) ^ 0x8000000000000000L;
} }
/* /**
* Returns an int from prefixCoded characters.
* Rightmost bits will be zero for lower precision codes.
* This method can be used to decode a term's value.
* @throws NumberFormatException if the supplied string is
* not correctly prefix encoded.
* @see #intToPrefixCoded(int)
* @deprecated This method is no longer needed!
*
@Deprecated
public static int prefixCodedToInt(final String prefixCoded) {
return prefixCodedToInt(new BytesRef(prefixCoded));
}*/
/*
* Returns an int from prefixCoded bytes. * Returns an int from prefixCoded bytes.
* Rightmost bits will be zero for lower precision codes. * Rightmost bits will be zero for lower precision codes.
* This method can be used to decode a term's value. * This method can be used to decode a term's value.
@ -329,16 +249,6 @@ public final class NumericUtils {
return f; return f;
} }
/*
* Convenience method: this just returns:
* longToPrefixCoded(doubleToSortableLong(val))
* @deprecated This method is no longer needed!
*
@Deprecated
public static String doubleToPrefixCoded(double val) {
return longToPrefixCoded(doubleToSortableLong(val));
}*/
/** /**
* Converts a sortable <code>long</code> back to a <code>double</code>. * Converts a sortable <code>long</code> back to a <code>double</code>.
* @see #doubleToSortableLong * @see #doubleToSortableLong
@ -348,16 +258,6 @@ public final class NumericUtils {
return Double.longBitsToDouble(val); return Double.longBitsToDouble(val);
} }
/*
* Convenience method: this just returns:
* sortableLongToDouble(prefixCodedToLong(val))
* @deprecated This method is no longer needed!
*
@Deprecated
public static double prefixCodedToDouble(String val) {
return sortableLongToDouble(prefixCodedToLong(val));
}*/
/** /**
* Converts a <code>float</code> value to a sortable signed <code>int</code>. * Converts a <code>float</code> value to a sortable signed <code>int</code>.
* The value is converted by getting their IEEE 754 floating-point &quot;float format&quot; * The value is converted by getting their IEEE 754 floating-point &quot;float format&quot;
@ -371,16 +271,6 @@ public final class NumericUtils {
return f; return f;
} }
/*
* Convenience method: this just returns:
* intToPrefixCoded(floatToSortableInt(val))
* @deprecated This method is no longer needed!
*
@Deprecated
public static String floatToPrefixCoded(float val) {
return intToPrefixCoded(floatToSortableInt(val));
}*/
/** /**
* Converts a sortable <code>int</code> back to a <code>float</code>. * Converts a sortable <code>int</code> back to a <code>float</code>.
* @see #floatToSortableInt * @see #floatToSortableInt
@ -390,16 +280,6 @@ public final class NumericUtils {
return Float.intBitsToFloat(val); return Float.intBitsToFloat(val);
} }
/*
* Convenience method: this just returns:
* sortableIntToFloat(prefixCodedToInt(val))
* @deprecated This method is no longer needed!
*
@Deprecated
public static float prefixCodedToFloat(String val) {
return sortableIntToFloat(prefixCodedToInt(val));
}*/
/** /**
* Splits a long range recursively. * Splits a long range recursively.
* You may implement a builder that adds clauses to a * You may implement a builder that adds clauses to a

View File

@ -44,7 +44,7 @@ public abstract class StringHelper {
* @param bytes2 The second byte[] to compare * @param bytes2 The second byte[] to compare
* @return The number of common elements. * @return The number of common elements.
*/ */
public static final int bytesDifference(byte[] bytes1, int len1, byte[] bytes2, int len2) { public static int bytesDifference(byte[] bytes1, int len1, byte[] bytes2, int len2) {
int len = len1 < len2 ? len1 : len2; int len = len1 < len2 ? len1 : len2;
for (int i = 0; i < len; i++) for (int i = 0; i < len; i++)
if (bytes1[i] != bytes2[i]) if (bytes1[i] != bytes2[i])
@ -52,29 +52,6 @@ public abstract class StringHelper {
return len; return len;
} }
/**
* Compares two strings, character by character, and returns the
* first position where the two strings differ from one another.
*
* @param s1 The first string to compare
* @param s2 The second string to compare
* @return The first position where the two strings differ.
*
* @deprecated This method cannot handle supplementary characters.
*/
@Deprecated
public static final int stringDifference(String s1, String s2) {
int len1 = s1.length();
int len2 = s2.length();
int len = len1 < len2 ? len1 : len2;
for (int i = 0; i < len; i++) {
if (s1.charAt(i) != s2.charAt(i)) {
return i;
}
}
return len;
}
private StringHelper() { private StringHelper() {
} }
} }

View File

@ -28,29 +28,18 @@ package org.apache.lucene.util;
* your indexing code to match, and re-index. * your indexing code to match, and re-index.
*/ */
public enum Version { public enum Version {
/**
/** Match settings and bugs in Lucene's 2.0 release. */ * Match settings and bugs in Lucene's 3.0 release.
LUCENE_20, * @deprecated (4.0) Use latest
*/
/** Match settings and bugs in Lucene's 2.1 release. */ @Deprecated
LUCENE_21,
/** Match settings and bugs in Lucene's 2.2 release. */
LUCENE_22,
/** Match settings and bugs in Lucene's 2.3 release. */
LUCENE_23,
/** Match settings and bugs in Lucene's 2.4 release. */
LUCENE_24,
/** Match settings and bugs in Lucene's 2.9 release. */
LUCENE_29,
/** Match settings and bugs in Lucene's 3.0 release. */
LUCENE_30, LUCENE_30,
/** Match settings and bugs in Lucene's 3.1 release. */ /**
* Match settings and bugs in Lucene's 3.1 release.
* @deprecated (4.0) Use latest
*/
@Deprecated
LUCENE_31, LUCENE_31,
/** Match settings and bugs in Lucene's 4.0 release. /** Match settings and bugs in Lucene's 4.0 release.

View File

@ -620,10 +620,12 @@ public class TestExternalCodecs extends LuceneTestCase {
final int NUM_DOCS = 173; final int NUM_DOCS = 173;
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter w = new IndexWriter(dir, IndexWriter w = new IndexWriter(
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer(MockTokenizer.WHITESPACE, true, true)).setCodecProvider(provider)); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer(MockTokenizer.WHITESPACE, true, true)).
w.setMergeFactor(3); setCodecProvider(provider).
setMergePolicy(newLogMergePolicy(3))
);
Document doc = new Document(); Document doc = new Document();
// uses default codec: // uses default codec:
doc.add(newField("field1", "this field uses the standard codec as the test", Field.Store.NO, Field.Index.ANALYZED)); doc.add(newField("field1", "this field uses the standard codec as the test", Field.Store.NO, Field.Index.ANALYZED));

View File

@ -114,29 +114,15 @@ public class TestSearch extends LuceneTestCase {
Query query = parser.parse(queries[j]); Query query = parser.parse(queries[j]);
out.println("Query: " + query.toString("contents")); out.println("Query: " + query.toString("contents"));
//DateFilter filter =
// new DateFilter("modified", Time(1997,0,1), Time(1998,0,1));
//DateFilter filter = DateFilter.Before("modified", Time(1997,00,01));
//System.out.println(filter);
hits = searcher.search(query, null, 1000).scoreDocs; hits = searcher.search(query, null, 1000).scoreDocs;
out.println(hits.length + " total results"); out.println(hits.length + " total results");
for (int i = 0 ; i < hits.length && i < 10; i++) { for (int i = 0 ; i < hits.length && i < 10; i++) {
Document d = searcher.doc(hits[i].doc); Document d = searcher.doc(hits[i].doc);
out.println(i + " " + hits[i].score out.println(i + " " + hits[i].score + " " + d.get("contents"));
// + " " + DateField.stringToDate(d.get("modified"))
+ " " + d.get("contents"));
} }
} }
searcher.close(); searcher.close();
directory.close(); directory.close();
} }
static long Time(int year, int month, int day) {
GregorianCalendar calendar = new GregorianCalendar();
calendar.clear();
calendar.set(year, month, day);
return calendar.getTime().getTime();
}
} }

View File

@ -18,10 +18,8 @@ package org.apache.lucene.analysis;
*/ */
import java.io.IOException; import java.io.IOException;
import java.io.Reader;
import java.io.StringReader; import java.io.StringReader;
import org.apache.lucene.util.Version;
/** /**
* Testcase for {@link CharTokenizer} subclasses * Testcase for {@link CharTokenizer} subclasses
@ -92,96 +90,4 @@ public class TestCharTokenizers extends BaseTokenStreamTestCase {
MockTokenizer tokenizer = new MockTokenizer(new StringReader(builder.toString() + builder.toString()), MockTokenizer.SIMPLE, true); MockTokenizer tokenizer = new MockTokenizer(new StringReader(builder.toString() + builder.toString()), MockTokenizer.SIMPLE, true);
assertTokenStreamContents(tokenizer, new String[] {builder.toString().toLowerCase(), builder.toString().toLowerCase()}); assertTokenStreamContents(tokenizer, new String[] {builder.toString().toLowerCase(), builder.toString().toLowerCase()});
} }
public void testIsTokenCharCharInSubclass() {
new TestingCharTokenizer(Version.LUCENE_30, new StringReader(""));
try {
new TestingCharTokenizer(TEST_VERSION_CURRENT, new StringReader(""));
fail("version 3.1 is not permitted if char based method is implemented");
} catch (IllegalArgumentException e) {
// expected
}
}
public void testNormalizeCharInSubclass() {
new TestingCharTokenizerNormalize(Version.LUCENE_30, new StringReader(""));
try {
new TestingCharTokenizerNormalize(TEST_VERSION_CURRENT,
new StringReader(""));
fail("version 3.1 is not permitted if char based method is implemented");
} catch (IllegalArgumentException e) {
// expected
}
}
public void testNormalizeAndIsTokenCharCharInSubclass() {
new TestingCharTokenizerNormalizeIsTokenChar(Version.LUCENE_30,
new StringReader(""));
try {
new TestingCharTokenizerNormalizeIsTokenChar(TEST_VERSION_CURRENT,
new StringReader(""));
fail("version 3.1 is not permitted if char based method is implemented");
} catch (IllegalArgumentException e) {
// expected
}
}
static final class TestingCharTokenizer extends CharTokenizer {
public TestingCharTokenizer(Version matchVersion, Reader input) {
super(matchVersion, input);
}
@Override
protected boolean isTokenChar(int c) {
return Character.isLetter(c);
}
@Deprecated @Override
protected boolean isTokenChar(char c) {
return Character.isLetter(c);
}
}
static final class TestingCharTokenizerNormalize extends CharTokenizer {
public TestingCharTokenizerNormalize(Version matchVersion, Reader input) {
super(matchVersion, input);
}
@Deprecated @Override
protected char normalize(char c) {
return c;
}
@Override
protected int normalize(int c) {
return c;
}
}
static final class TestingCharTokenizerNormalizeIsTokenChar extends CharTokenizer {
public TestingCharTokenizerNormalizeIsTokenChar(Version matchVersion,
Reader input) {
super(matchVersion, input);
}
@Deprecated @Override
protected char normalize(char c) {
return c;
}
@Override
protected int normalize(int c) {
return c;
}
@Override
protected boolean isTokenChar(int c) {
return Character.isLetter(c);
}
@Deprecated @Override
protected boolean isTokenChar(char c) {
return Character.isLetter(c);
}
}
} }

View File

@ -176,20 +176,20 @@ public class TestToken extends LuceneTestCase {
char[] content = "hello".toCharArray(); char[] content = "hello".toCharArray();
t.copyBuffer(content, 0, 5); t.copyBuffer(content, 0, 5);
char[] buf = t.buffer(); char[] buf = t.buffer();
Token copy = (Token) TestSimpleAttributeImpls.assertCloneIsEqual(t); Token copy = assertCloneIsEqual(t);
assertEquals(t.toString(), copy.toString()); assertEquals(t.toString(), copy.toString());
assertNotSame(buf, copy.buffer()); assertNotSame(buf, copy.buffer());
Payload pl = new Payload(new byte[]{1,2,3,4}); Payload pl = new Payload(new byte[]{1,2,3,4});
t.setPayload(pl); t.setPayload(pl);
copy = (Token) TestSimpleAttributeImpls.assertCloneIsEqual(t); copy = assertCloneIsEqual(t);
assertEquals(pl, copy.getPayload()); assertEquals(pl, copy.getPayload());
assertNotSame(pl, copy.getPayload()); assertNotSame(pl, copy.getPayload());
} }
public void testCopyTo() throws Exception { public void testCopyTo() throws Exception {
Token t = new Token(); Token t = new Token();
Token copy = (Token) TestSimpleAttributeImpls.assertCopyIsEqual(t); Token copy = assertCopyIsEqual(t);
assertEquals("", t.toString()); assertEquals("", t.toString());
assertEquals("", copy.toString()); assertEquals("", copy.toString());
@ -197,13 +197,13 @@ public class TestToken extends LuceneTestCase {
char[] content = "hello".toCharArray(); char[] content = "hello".toCharArray();
t.copyBuffer(content, 0, 5); t.copyBuffer(content, 0, 5);
char[] buf = t.buffer(); char[] buf = t.buffer();
copy = (Token) TestSimpleAttributeImpls.assertCopyIsEqual(t); copy = assertCopyIsEqual(t);
assertEquals(t.toString(), copy.toString()); assertEquals(t.toString(), copy.toString());
assertNotSame(buf, copy.buffer()); assertNotSame(buf, copy.buffer());
Payload pl = new Payload(new byte[]{1,2,3,4}); Payload pl = new Payload(new byte[]{1,2,3,4});
t.setPayload(pl); t.setPayload(pl);
copy = (Token) TestSimpleAttributeImpls.assertCopyIsEqual(t); copy = assertCopyIsEqual(t);
assertEquals(pl, copy.getPayload()); assertEquals(pl, copy.getPayload());
assertNotSame(pl, copy.getPayload()); assertNotSame(pl, copy.getPayload());
} }
@ -240,4 +240,21 @@ public class TestToken extends LuceneTestCase {
assertTrue("TypeAttribute is not implemented by Token", assertTrue("TypeAttribute is not implemented by Token",
ts.addAttribute(TypeAttribute.class) instanceof Token); ts.addAttribute(TypeAttribute.class) instanceof Token);
} }
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;
}
} }

View File

@ -17,6 +17,7 @@ package org.apache.lucene.analysis.tokenattributes;
* limitations under the License. * limitations under the License.
*/ */
import org.apache.lucene.analysis.TestToken;
import org.apache.lucene.util.LuceneTestCase; import org.apache.lucene.util.LuceneTestCase;
import java.nio.CharBuffer; import java.nio.CharBuffer;
import java.util.Formatter; import java.util.Formatter;
@ -91,7 +92,7 @@ public class TestCharTermAttributeImpl extends LuceneTestCase {
char[] content = "hello".toCharArray(); char[] content = "hello".toCharArray();
t.copyBuffer(content, 0, 5); t.copyBuffer(content, 0, 5);
char[] buf = t.buffer(); char[] buf = t.buffer();
CharTermAttributeImpl copy = (CharTermAttributeImpl) TestSimpleAttributeImpls.assertCloneIsEqual(t); CharTermAttributeImpl copy = TestToken.assertCloneIsEqual(t);
assertEquals(t.toString(), copy.toString()); assertEquals(t.toString(), copy.toString());
assertNotSame(buf, copy.buffer()); assertNotSame(buf, copy.buffer());
} }
@ -113,7 +114,7 @@ public class TestCharTermAttributeImpl extends LuceneTestCase {
public void testCopyTo() throws Exception { public void testCopyTo() throws Exception {
CharTermAttributeImpl t = new CharTermAttributeImpl(); CharTermAttributeImpl t = new CharTermAttributeImpl();
CharTermAttributeImpl copy = (CharTermAttributeImpl) TestSimpleAttributeImpls.assertCopyIsEqual(t); CharTermAttributeImpl copy = TestToken.assertCopyIsEqual(t);
assertEquals("", t.toString()); assertEquals("", t.toString());
assertEquals("", copy.toString()); assertEquals("", copy.toString());
@ -121,7 +122,7 @@ public class TestCharTermAttributeImpl extends LuceneTestCase {
char[] content = "hello".toCharArray(); char[] content = "hello".toCharArray();
t.copyBuffer(content, 0, 5); t.copyBuffer(content, 0, 5);
char[] buf = t.buffer(); char[] buf = t.buffer();
copy = (CharTermAttributeImpl) TestSimpleAttributeImpls.assertCopyIsEqual(t); copy = TestToken.assertCopyIsEqual(t);
assertEquals(t.toString(), copy.toString()); assertEquals(t.toString(), copy.toString());
assertNotSame(buf, copy.buffer()); assertNotSame(buf, copy.buffer());
} }

View File

@ -1,153 +0,0 @@
package org.apache.lucene.analysis.tokenattributes;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.index.Payload;
import org.apache.lucene.util.AttributeImpl;
import org.apache.lucene.util.LuceneTestCase;
import org.apache.lucene.util.AttributeSource.AttributeFactory;
@Deprecated
public class TestSimpleAttributeImpls extends LuceneTestCase {
public void testFlagsAttribute() throws Exception {
FlagsAttributeImpl att = new FlagsAttributeImpl();
assertEquals(0, att.getFlags());
att.setFlags(1234);
assertEquals("flags=1234", att.toString());
FlagsAttributeImpl att2 = (FlagsAttributeImpl) assertCloneIsEqual(att);
assertEquals(1234, att2.getFlags());
att2 = (FlagsAttributeImpl) assertCopyIsEqual(att);
assertEquals(1234, att2.getFlags());
att.clear();
assertEquals(0, att.getFlags());
}
public void testPositionIncrementAttribute() throws Exception {
PositionIncrementAttributeImpl att = new PositionIncrementAttributeImpl();
assertEquals(1, att.getPositionIncrement());
att.setPositionIncrement(1234);
assertEquals("positionIncrement=1234", att.toString());
PositionIncrementAttributeImpl att2 = (PositionIncrementAttributeImpl) assertCloneIsEqual(att);
assertEquals(1234, att2.getPositionIncrement());
att2 = (PositionIncrementAttributeImpl) assertCopyIsEqual(att);
assertEquals(1234, att2.getPositionIncrement());
att.clear();
assertEquals(1, att.getPositionIncrement());
}
public void testTypeAttribute() throws Exception {
TypeAttributeImpl att = new TypeAttributeImpl();
assertEquals(TypeAttribute.DEFAULT_TYPE, att.type());
att.setType("hallo");
assertEquals("type=hallo", att.toString());
TypeAttributeImpl att2 = (TypeAttributeImpl) assertCloneIsEqual(att);
assertEquals("hallo", att2.type());
att2 = (TypeAttributeImpl) assertCopyIsEqual(att);
assertEquals("hallo", att2.type());
att.clear();
assertEquals(TypeAttribute.DEFAULT_TYPE, att.type());
}
public void testPayloadAttribute() throws Exception {
PayloadAttributeImpl att = new PayloadAttributeImpl();
assertNull(att.getPayload());
Payload pl = new Payload(new byte[]{1,2,3,4});
att.setPayload(pl);
PayloadAttributeImpl att2 = (PayloadAttributeImpl) assertCloneIsEqual(att);
assertEquals(pl, att2.getPayload());
assertNotSame(pl, att2.getPayload());
att2 = (PayloadAttributeImpl) assertCopyIsEqual(att);
assertEquals(pl, att2.getPayload());
assertNotSame(pl, att2.getPayload());
att.clear();
assertNull(att.getPayload());
}
public void testOffsetAttribute() throws Exception {
OffsetAttributeImpl att = new OffsetAttributeImpl();
assertEquals(0, att.startOffset());
assertEquals(0, att.endOffset());
att.setOffset(12, 34);
// no string test here, because order unknown
OffsetAttributeImpl att2 = (OffsetAttributeImpl) assertCloneIsEqual(att);
assertEquals(12, att2.startOffset());
assertEquals(34, att2.endOffset());
att2 = (OffsetAttributeImpl) assertCopyIsEqual(att);
assertEquals(12, att2.startOffset());
assertEquals(34, att2.endOffset());
att.clear();
assertEquals(0, att.startOffset());
assertEquals(0, att.endOffset());
}
public void testKeywordAttribute() {
AttributeImpl attrImpl = AttributeFactory.DEFAULT_ATTRIBUTE_FACTORY.createAttributeInstance(KeywordAttribute.class);
assertSame(KeywordAttributeImpl.class, attrImpl.getClass());
KeywordAttributeImpl att = (KeywordAttributeImpl) attrImpl;
assertFalse(att.isKeyword());
att.setKeyword(true);
assertTrue(att.isKeyword());
KeywordAttributeImpl assertCloneIsEqual = (KeywordAttributeImpl) assertCloneIsEqual(att);
assertTrue(assertCloneIsEqual.isKeyword());
assertCloneIsEqual.clear();
assertFalse(assertCloneIsEqual.isKeyword());
assertTrue(att.isKeyword());
att.copyTo(assertCloneIsEqual);
assertTrue(assertCloneIsEqual.isKeyword());
assertTrue(att.isKeyword());
}
public static final AttributeImpl assertCloneIsEqual(AttributeImpl att) {
AttributeImpl clone = (AttributeImpl) att.clone();
assertEquals("Clone must be equal", att, clone);
assertEquals("Clone's hashcode must be equal", att.hashCode(), clone.hashCode());
return clone;
}
public static final AttributeImpl assertCopyIsEqual(AttributeImpl att) throws Exception {
AttributeImpl copy = 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;
}
}

View File

@ -37,14 +37,6 @@ public class TestBinaryDocument extends LuceneTestCase {
Fieldable binaryFldStored = new Field("binaryStored", binaryValStored.getBytes()); Fieldable binaryFldStored = new Field("binaryStored", binaryValStored.getBytes());
Fieldable stringFldStored = new Field("stringStored", binaryValStored, Field.Store.YES, Field.Index.NO, Field.TermVector.NO); Fieldable stringFldStored = new Field("stringStored", binaryValStored, Field.Store.YES, Field.Index.NO, Field.TermVector.NO);
try {
// binary fields with store off are not allowed
new Field("fail", binaryValStored.getBytes(), Field.Store.NO);
fail();
}
catch (IllegalArgumentException iae) {
}
Document doc = new Document(); Document doc = new Document();
doc.add(binaryFldStored); doc.add(binaryFldStored);

View File

@ -1,82 +0,0 @@
package org.apache.lucene.document;
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import org.apache.lucene.util.LuceneTestCase;
public class TestNumberTools extends LuceneTestCase {
public void testNearZero() {
for (int i = -100; i <= 100; i++) {
for (int j = -100; j <= 100; j++) {
subtestTwoLongs(i, j);
}
}
}
public void testMax() {
// make sure the constants convert to their equivalents
assertEquals(Long.MAX_VALUE, NumberTools
.stringToLong(NumberTools.MAX_STRING_VALUE));
assertEquals(NumberTools.MAX_STRING_VALUE, NumberTools
.longToString(Long.MAX_VALUE));
// test near MAX, too
for (long l = Long.MAX_VALUE; l > Long.MAX_VALUE - 10000; l--) {
subtestTwoLongs(l, l - 1);
}
}
public void testMin() {
// make sure the constants convert to their equivelents
assertEquals(Long.MIN_VALUE, NumberTools
.stringToLong(NumberTools.MIN_STRING_VALUE));
assertEquals(NumberTools.MIN_STRING_VALUE, NumberTools
.longToString(Long.MIN_VALUE));
// test near MIN, too
for (long l = Long.MIN_VALUE; l < Long.MIN_VALUE + 10000; l++) {
subtestTwoLongs(l, l + 1);
}
}
private static void subtestTwoLongs(long i, long j) {
// convert to strings
String a = NumberTools.longToString(i);
String b = NumberTools.longToString(j);
// are they the right length?
assertEquals(NumberTools.STR_SIZE, a.length());
assertEquals(NumberTools.STR_SIZE, b.length());
// are they the right order?
if (i < j) {
assertTrue(a.compareTo(b) < 0);
} else if (i > j) {
assertTrue(a.compareTo(b) > 0);
} else {
assertEquals(a, b);
}
// can we convert them back to longs?
long i2 = NumberTools.stringToLong(a);
long j2 = NumberTools.stringToLong(b);
assertEquals(i, i2);
assertEquals(j, j2);
}
}

View File

@ -132,13 +132,14 @@ public class Test2BTerms extends LuceneTestCase {
int TERMS_PER_DOC = 1000000; int TERMS_PER_DOC = 1000000;
Directory dir = FSDirectory.open(_TestUtil.getTempDir("2BTerms")); Directory dir = FSDirectory.open(_TestUtil.getTempDir("2BTerms"));
IndexWriter w = new IndexWriter(dir, IndexWriter w = new IndexWriter(
new IndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setMaxBufferedDocs(IndexWriterConfig.DISABLE_AUTO_FLUSH) new IndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
.setRAMBufferSizeMB(256.0).setMergeScheduler(new ConcurrentMergeScheduler())); setMaxBufferedDocs(IndexWriterConfig.DISABLE_AUTO_FLUSH).
((LogMergePolicy) w.getConfig().getMergePolicy()).setUseCompoundFile(false); setRAMBufferSizeMB(256.0).
((LogMergePolicy) w.getConfig().getMergePolicy()).setUseCompoundDocStore(false); setMergeScheduler(new ConcurrentMergeScheduler()).
((LogMergePolicy) w.getConfig().getMergePolicy()).setMergeFactor(10); setMergePolicy(newLogMergePolicy(false, 10))
);
Document doc = new Document(); Document doc = new Document();
Field field = new Field("field", new MyTokenStream(TERMS_PER_DOC)); Field field = new Field("field", new MyTokenStream(TERMS_PER_DOC));

View File

@ -58,9 +58,12 @@ public class TestAddIndexes extends LuceneTestCase {
writer.close(); writer.close();
_TestUtil.checkIndex(dir); _TestUtil.checkIndex(dir);
writer = newWriter(aux, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.CREATE)); writer = newWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundFile(false); // use one without a compound file aux,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundDocStore(false); // use one without a compound file newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.CREATE).
setMergePolicy(newLogMergePolicy(false))
);
// add 40 documents in separate files // add 40 documents in separate files
addDocs(writer, 40); addDocs(writer, 40);
assertEquals(40, writer.maxDoc()); assertEquals(40, writer.maxDoc());
@ -75,7 +78,7 @@ public class TestAddIndexes extends LuceneTestCase {
// test doc count before segments are merged // test doc count before segments are merged
writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND)); writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND));
assertEquals(100, writer.maxDoc()); assertEquals(100, writer.maxDoc());
writer.addIndexes(new Directory[] { aux, aux2 }); writer.addIndexes(aux, aux2);
assertEquals(190, writer.maxDoc()); assertEquals(190, writer.maxDoc());
writer.close(); writer.close();
_TestUtil.checkIndex(dir); _TestUtil.checkIndex(dir);
@ -97,7 +100,7 @@ public class TestAddIndexes extends LuceneTestCase {
// test doc count before segments are merged/index is optimized // test doc count before segments are merged/index is optimized
writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND)); writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND));
assertEquals(190, writer.maxDoc()); assertEquals(190, writer.maxDoc());
writer.addIndexes(new Directory[] { aux3 }); writer.addIndexes(aux3);
assertEquals(230, writer.maxDoc()); assertEquals(230, writer.maxDoc());
writer.close(); writer.close();
@ -128,7 +131,7 @@ public class TestAddIndexes extends LuceneTestCase {
writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND)); writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND));
assertEquals(230, writer.maxDoc()); assertEquals(230, writer.maxDoc());
writer.addIndexes(new Directory[] { aux4 }); writer.addIndexes(aux4);
assertEquals(231, writer.maxDoc()); assertEquals(231, writer.maxDoc());
writer.close(); writer.close();
@ -150,7 +153,7 @@ public class TestAddIndexes extends LuceneTestCase {
setUpDirs(dir, aux); setUpDirs(dir, aux);
IndexWriter writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND)); IndexWriter writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND));
writer.addIndexes(new Directory[] {aux}); writer.addIndexes(aux);
// Adds 10 docs, then replaces them with another 10 // Adds 10 docs, then replaces them with another 10
// docs, so 10 pending deletes: // docs, so 10 pending deletes:
@ -197,7 +200,7 @@ public class TestAddIndexes extends LuceneTestCase {
writer.updateDocument(new Term("id", "" + (i%10)), doc); writer.updateDocument(new Term("id", "" + (i%10)), doc);
} }
writer.addIndexes(new Directory[] {aux}); writer.addIndexes(aux);
// Deletes one of the 10 added docs, leaving 9: // Deletes one of the 10 added docs, leaving 9:
PhraseQuery q = new PhraseQuery(); PhraseQuery q = new PhraseQuery();
@ -242,7 +245,7 @@ public class TestAddIndexes extends LuceneTestCase {
q.add(new Term("content", "14")); q.add(new Term("content", "14"));
writer.deleteDocuments(q); writer.deleteDocuments(q);
writer.addIndexes(new Directory[] {aux}); writer.addIndexes(aux);
writer.optimize(); writer.optimize();
writer.commit(); writer.commit();
@ -271,22 +274,30 @@ public class TestAddIndexes extends LuceneTestCase {
assertEquals(100, writer.maxDoc()); assertEquals(100, writer.maxDoc());
writer.close(); writer.close();
writer = newWriter(aux, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.CREATE).setMaxBufferedDocs(1000)); writer = newWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundFile(false); // use one without a compound file aux,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundDocStore(false); // use one without a compound file newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.CREATE).
setMaxBufferedDocs(1000).
setMergePolicy(newLogMergePolicy(false))
);
// add 140 documents in separate files // add 140 documents in separate files
addDocs(writer, 40); addDocs(writer, 40);
writer.close(); writer.close();
writer = newWriter(aux, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.CREATE).setMaxBufferedDocs(1000)); writer = newWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundFile(false); // use one without a compound file aux,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundDocStore(false); // use one without a compound file newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.CREATE).
setMaxBufferedDocs(1000).
setMergePolicy(newLogMergePolicy(false))
);
addDocs(writer, 100); addDocs(writer, 100);
writer.close(); writer.close();
writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND)); writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND));
try { try {
// cannot add self // cannot add self
writer.addIndexes(new Directory[] { aux, dir }); writer.addIndexes(aux, dir);
assertTrue(false); assertTrue(false);
} }
catch (IllegalArgumentException e) { catch (IllegalArgumentException e) {
@ -311,13 +322,16 @@ public class TestAddIndexes extends LuceneTestCase {
setUpDirs(dir, aux); setUpDirs(dir, aux);
IndexWriter writer = newWriter(dir, newIndexWriterConfig( IndexWriter writer = newWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(10)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(4); setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(10).
setMergePolicy(newLogMergePolicy(4))
);
addDocs(writer, 10); addDocs(writer, 10);
writer.addIndexes(new Directory[] { aux }); writer.addIndexes(aux);
assertEquals(1040, writer.maxDoc()); assertEquals(1040, writer.maxDoc());
assertEquals(1000, writer.getDocCount(0)); assertEquals(1000, writer.getDocCount(0));
writer.close(); writer.close();
@ -337,11 +351,16 @@ public class TestAddIndexes extends LuceneTestCase {
setUpDirs(dir, aux); setUpDirs(dir, aux);
IndexWriter writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(9)); IndexWriter writer = newWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(4); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(9).
setMergePolicy(newLogMergePolicy(4))
);
addDocs(writer, 2); addDocs(writer, 2);
writer.addIndexes(new Directory[] { aux }); writer.addIndexes(aux);
assertEquals(1032, writer.maxDoc()); assertEquals(1032, writer.maxDoc());
assertEquals(1000, writer.getDocCount(0)); assertEquals(1000, writer.getDocCount(0));
writer.close(); writer.close();
@ -361,12 +380,15 @@ public class TestAddIndexes extends LuceneTestCase {
setUpDirs(dir, aux); setUpDirs(dir, aux);
IndexWriter writer = newWriter(dir, newIndexWriterConfig( IndexWriter writer = newWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(10)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(4); setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(10).
setMergePolicy(newLogMergePolicy(4))
);
writer.addIndexes(new Directory[] { aux, new MockDirectoryWrapper(random, new RAMDirectory(aux)) }); writer.addIndexes(aux, new MockDirectoryWrapper(random, new RAMDirectory(aux)));
assertEquals(1060, writer.maxDoc()); assertEquals(1060, writer.maxDoc());
assertEquals(1000, writer.getDocCount(0)); assertEquals(1000, writer.getDocCount(0));
writer.close(); writer.close();
@ -393,12 +415,15 @@ public class TestAddIndexes extends LuceneTestCase {
assertEquals(10, reader.numDocs()); assertEquals(10, reader.numDocs());
reader.close(); reader.close();
IndexWriter writer = newWriter(dir, newIndexWriterConfig( IndexWriter writer = newWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(4)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(4); setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(4).
setMergePolicy(newLogMergePolicy(4))
);
writer.addIndexes(new Directory[] { aux, new MockDirectoryWrapper(random, new RAMDirectory(aux)) }); writer.addIndexes(aux, new MockDirectoryWrapper(random, new RAMDirectory(aux)));
assertEquals(1060, writer.maxDoc()); assertEquals(1060, writer.maxDoc());
assertEquals(1000, writer.getDocCount(0)); assertEquals(1000, writer.getDocCount(0));
writer.close(); writer.close();
@ -416,11 +441,14 @@ public class TestAddIndexes extends LuceneTestCase {
setUpDirs(dir, aux); setUpDirs(dir, aux);
IndexWriter writer = newWriter(aux2, newIndexWriterConfig( IndexWriter writer = newWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) aux2,
.setOpenMode(OpenMode.CREATE).setMaxBufferedDocs(100)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(10); setOpenMode(OpenMode.CREATE).
writer.addIndexes(new Directory[] { aux }); setMaxBufferedDocs(100).
setMergePolicy(newLogMergePolicy(10))
);
writer.addIndexes(aux);
assertEquals(30, writer.maxDoc()); assertEquals(30, writer.maxDoc());
assertEquals(3, writer.getSegmentCount()); assertEquals(3, writer.getSegmentCount());
writer.close(); writer.close();
@ -439,11 +467,15 @@ public class TestAddIndexes extends LuceneTestCase {
assertEquals(22, reader.numDocs()); assertEquals(22, reader.numDocs());
reader.close(); reader.close();
writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()) writer = newWriter(
.setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(6)); dir,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(4); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(6).
setMergePolicy(newLogMergePolicy(4))
);
writer.addIndexes(new Directory[] { aux, aux2 }); writer.addIndexes(aux, aux2);
assertEquals(1060, writer.maxDoc()); assertEquals(1060, writer.maxDoc());
assertEquals(1000, writer.getDocCount(0)); assertEquals(1000, writer.getDocCount(0));
writer.close(); writer.close();
@ -505,18 +537,24 @@ public class TestAddIndexes extends LuceneTestCase {
assertEquals(1, writer.getSegmentCount()); assertEquals(1, writer.getSegmentCount());
writer.close(); writer.close();
writer = newWriter(aux, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.CREATE).setMaxBufferedDocs(100)); writer = newWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundFile(false); // use one without a compound file aux,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundDocStore(false); // use one without a compound file newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(10); setOpenMode(OpenMode.CREATE).
setMaxBufferedDocs(1000).
setMergePolicy(newLogMergePolicy(false, 10))
);
// add 30 documents in 3 segments // add 30 documents in 3 segments
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
addDocs(writer, 10); addDocs(writer, 10);
writer.close(); writer.close();
writer = newWriter(aux, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(100)); writer = newWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundFile(false); // use one without a compound file aux,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundDocStore(false); // use one without a compound file newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(10); setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(1000).
setMergePolicy(newLogMergePolicy(false, 10))
);
} }
assertEquals(30, writer.maxDoc()); assertEquals(30, writer.maxDoc());
assertEquals(3, writer.getSegmentCount()); assertEquals(3, writer.getSegmentCount());
@ -563,7 +601,7 @@ public class TestAddIndexes extends LuceneTestCase {
writer = new IndexWriter(dir2, newIndexWriterConfig(TEST_VERSION_CURRENT, writer = new IndexWriter(dir2, newIndexWriterConfig(TEST_VERSION_CURRENT,
new MockAnalyzer()) new MockAnalyzer())
.setMergeScheduler(new SerialMergeScheduler()).setMergePolicy(lmp)); .setMergeScheduler(new SerialMergeScheduler()).setMergePolicy(lmp));
writer.addIndexes(new Directory[] {dir}); writer.addIndexes(dir);
writer.close(); writer.close();
dir.close(); dir.close();
dir2.close(); dir2.close();
@ -920,22 +958,26 @@ public class TestAddIndexes extends LuceneTestCase {
writer.close(); writer.close();
_TestUtil.checkIndex(dir, provider); _TestUtil.checkIndex(dir, provider);
writer = newWriter(aux, newIndexWriterConfig(TEST_VERSION_CURRENT, writer = newWriter(
new MockAnalyzer()).setOpenMode(OpenMode.CREATE).setCodecProvider( aux,
provider)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()) setOpenMode(OpenMode.CREATE).
.setUseCompoundFile(false); // use one without a compound file setCodecProvider(provider).
((LogMergePolicy) writer.getConfig().getMergePolicy()) setMaxBufferedDocs(10).
.setUseCompoundDocStore(false); // use one without a compound file setMergePolicy(newLogMergePolicy(false))
);
// add 40 documents in separate files // add 40 documents in separate files
addDocs(writer, 40); addDocs(writer, 40);
assertEquals(40, writer.maxDoc()); assertEquals(40, writer.maxDoc());
writer.commit(); writer.commit();
writer.close(); writer.close();
writer = newWriter(aux2, newIndexWriterConfig(TEST_VERSION_CURRENT, writer = newWriter(
new MockAnalyzer()).setOpenMode(OpenMode.CREATE).setCodecProvider( aux2,
provider)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.CREATE).
setCodecProvider(provider)
);
// add 40 documents in compound files // add 40 documents in compound files
addDocs2(writer, 50); addDocs2(writer, 50);
assertEquals(50, writer.maxDoc()); assertEquals(50, writer.maxDoc());
@ -943,11 +985,14 @@ public class TestAddIndexes extends LuceneTestCase {
writer.close(); writer.close();
// test doc count before segments are merged // test doc count before segments are merged
writer = newWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, writer = newWriter(
new MockAnalyzer()).setOpenMode(OpenMode.APPEND).setCodecProvider( dir,
provider)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.APPEND).
setCodecProvider(provider)
);
assertEquals(100, writer.maxDoc()); assertEquals(100, writer.maxDoc());
writer.addIndexes(new Directory[] { aux, aux2 }); writer.addIndexes(aux, aux2);
assertEquals(190, writer.maxDoc()); assertEquals(190, writer.maxDoc());
writer.close(); writer.close();
_TestUtil.checkIndex(dir, provider); _TestUtil.checkIndex(dir, provider);

View File

@ -235,7 +235,7 @@ public class TestBackwardsCompatibility extends LuceneTestCase {
Directory targetDir = newDirectory(); Directory targetDir = newDirectory();
IndexWriter w = new IndexWriter(targetDir, newIndexWriterConfig( IndexWriter w = new IndexWriter(targetDir, newIndexWriterConfig(
TEST_VERSION_CURRENT, new MockAnalyzer())); TEST_VERSION_CURRENT, new MockAnalyzer()));
w.addIndexes(new Directory[] { dir }); w.addIndexes(dir);
w.close(); w.close();
_TestUtil.checkIndex(targetDir); _TestUtil.checkIndex(targetDir);
@ -256,7 +256,7 @@ public class TestBackwardsCompatibility extends LuceneTestCase {
Directory targetDir = newDirectory(); Directory targetDir = newDirectory();
IndexWriter w = new IndexWriter(targetDir, newIndexWriterConfig( IndexWriter w = new IndexWriter(targetDir, newIndexWriterConfig(
TEST_VERSION_CURRENT, new MockAnalyzer())); TEST_VERSION_CURRENT, new MockAnalyzer()));
w.addIndexes(new IndexReader[] { reader }); w.addIndexes(reader);
w.close(); w.close();
reader.close(); reader.close();
@ -527,9 +527,13 @@ public class TestBackwardsCompatibility extends LuceneTestCase {
try { try {
Directory dir = FSDirectory.open(new File(fullDir(outputDir))); Directory dir = FSDirectory.open(new File(fullDir(outputDir)));
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(-1).setRAMBufferSizeMB(16.0)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getMergePolicy()).setUseCompoundFile(true); dir,
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(-1).
setRAMBufferSizeMB(16.0).
setMergePolicy(newLogMergePolicy(true, 10))
);
for(int i=0;i<35;i++) { for(int i=0;i<35;i++) {
addDoc(writer, i); addDoc(writer, i);
} }

View File

@ -184,8 +184,12 @@ public class TestConcurrentMergeScheduler extends LuceneTestCase {
Field idField = newField("id", "", Field.Store.YES, Field.Index.NOT_ANALYZED); Field idField = newField("id", "", Field.Store.YES, Field.Index.NOT_ANALYZED);
doc.add(idField); doc.add(idField);
IndexWriter writer = new IndexWriter(directory, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(2)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(100); directory,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(100))
);
for(int iter=0;iter<10;iter++) { for(int iter=0;iter<10;iter++) {
@ -213,8 +217,12 @@ public class TestConcurrentMergeScheduler extends LuceneTestCase {
reader.close(); reader.close();
// Reopen // Reopen
writer = new IndexWriter(directory, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.APPEND)); writer = new IndexWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(100); directory,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.APPEND).
setMergePolicy(newLogMergePolicy(100))
);
} }
writer.close(); writer.close();

View File

@ -373,10 +373,13 @@ public class TestDeletionPolicy extends LuceneTestCase {
Directory dir = newDirectory(); Directory dir = newDirectory();
policy.dir = dir; policy.dir = dir;
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setIndexDeletionPolicy(policy).setMaxBufferedDocs(2)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); setIndexDeletionPolicy(policy).
setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(10))
);
for(int i=0;i<10;i++) { for(int i=0;i<10;i++) {
addDoc(writer); addDoc(writer);
if ((1+i)%2 == 0) if ((1+i)%2 == 0)

View File

@ -111,10 +111,13 @@ public class TestDoc extends LuceneTestCase {
PrintWriter out = new PrintWriter(sw, true); PrintWriter out = new PrintWriter(sw, true);
Directory directory = FSDirectory.open(indexDir); Directory directory = FSDirectory.open(indexDir);
IndexWriter writer = new IndexWriter(directory, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) directory,
.setOpenMode(OpenMode.CREATE).setMaxBufferedDocs(-1)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); setOpenMode(OpenMode.CREATE).
setMaxBufferedDocs(-1).
setMergePolicy(newLogMergePolicy(10))
);
SegmentInfo si1 = indexDoc(writer, "test.txt"); SegmentInfo si1 = indexDoc(writer, "test.txt");
printSegment(out, si1); printSegment(out, si1);
@ -142,10 +145,13 @@ public class TestDoc extends LuceneTestCase {
out = new PrintWriter(sw, true); out = new PrintWriter(sw, true);
directory = FSDirectory.open(indexDir); directory = FSDirectory.open(indexDir);
writer = new IndexWriter(directory, newIndexWriterConfig( writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) directory,
.setOpenMode(OpenMode.CREATE).setMaxBufferedDocs(-1)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); setOpenMode(OpenMode.CREATE).
setMaxBufferedDocs(-1).
setMergePolicy(newLogMergePolicy(10))
);
si1 = indexDoc(writer, "test.txt"); si1 = indexDoc(writer, "test.txt");
printSegment(out, si1); printSegment(out, si1);
@ -188,7 +194,7 @@ public class TestDoc extends LuceneTestCase {
SegmentReader r1 = SegmentReader.get(true, si1, IndexReader.DEFAULT_TERMS_INDEX_DIVISOR); SegmentReader r1 = SegmentReader.get(true, si1, IndexReader.DEFAULT_TERMS_INDEX_DIVISOR);
SegmentReader r2 = SegmentReader.get(true, si2, IndexReader.DEFAULT_TERMS_INDEX_DIVISOR); SegmentReader r2 = SegmentReader.get(true, si2, IndexReader.DEFAULT_TERMS_INDEX_DIVISOR);
SegmentMerger merger = new SegmentMerger(si1.dir, IndexWriter.DEFAULT_TERM_INDEX_INTERVAL, merged, null, CodecProvider.getDefault(), null); SegmentMerger merger = new SegmentMerger(si1.dir, IndexWriterConfig.DEFAULT_TERM_INDEX_INTERVAL, merged, null, CodecProvider.getDefault(), null);
merger.add(r1); merger.add(r1);
merger.add(r2); merger.add(r2);

View File

@ -314,7 +314,7 @@ public class TestDocumentWriter extends LuceneTestCase {
_TestUtil.checkIndex(dir); _TestUtil.checkIndex(dir);
SegmentReader reader = SegmentReader.getOnlySegmentReader(dir); SegmentReader reader = getOnlySegmentReader(IndexReader.open(dir, false));
FieldInfos fi = reader.fieldInfos(); FieldInfos fi = reader.fieldInfos();
// f1 // f1
assertFalse("f1 should have no norms", reader.hasNorms("f1")); assertFalse("f1 should have no norms", reader.hasNorms("f1"));

View File

@ -19,10 +19,7 @@ package org.apache.lucene.index;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.Collections; import java.util.*;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import org.apache.lucene.analysis.MockAnalyzer; import org.apache.lucene.analysis.MockAnalyzer;
import org.apache.lucene.document.Document; import org.apache.lucene.document.Document;
@ -429,6 +426,10 @@ public class TestFieldsReader extends LuceneTestCase {
return fsDir.createOutput(name); return fsDir.createOutput(name);
} }
@Override @Override
public void sync(Collection<String> names) throws IOException {
fsDir.sync(names);
}
@Override
public void close() throws IOException { public void close() throws IOException {
fsDir.close(); fsDir.close();
} }

View File

@ -30,12 +30,14 @@ public class TestFlex extends LuceneTestCase {
final int DOC_COUNT = 177; final int DOC_COUNT = 177;
IndexWriter w = new IndexWriter(d, new MockAnalyzer(), IndexWriter w = new IndexWriter(
IndexWriter.MaxFieldLength.UNLIMITED); d,
new IndexWriterConfig(Version.LUCENE_31, new MockAnalyzer()).
setMaxBufferedDocs(7)
);
for(int iter=0;iter<2;iter++) { for(int iter=0;iter<2;iter++) {
if (iter == 0) { if (iter == 0) {
w.setMaxBufferedDocs(7);
Document doc = new Document(); Document doc = new Document();
doc.add(newField("field1", "this is field1", Field.Store.NO, Field.Index.ANALYZED)); doc.add(newField("field1", "this is field1", Field.Store.NO, Field.Index.ANALYZED));
doc.add(newField("field2", "this is field2", Field.Store.NO, Field.Index.ANALYZED)); doc.add(newField("field2", "this is field2", Field.Store.NO, Field.Index.ANALYZED));

View File

@ -40,11 +40,12 @@ public class TestIndexFileDeleter extends LuceneTestCase {
public void testDeleteLeftoverFiles() throws IOException { public void testDeleteLeftoverFiles() throws IOException {
MockDirectoryWrapper dir = newDirectory(); MockDirectoryWrapper dir = newDirectory();
dir.setPreventDoubleWrite(false); dir.setPreventDoubleWrite(false);
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setMaxBufferedDocs(10)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); setMaxBufferedDocs(10).
((LogMergePolicy) writer.getMergePolicy()).setUseCompoundFile(true); setMergePolicy(newLogMergePolicy(true, 10))
);
int i; int i;
for(i=0;i<35;i++) { for(i=0;i<35;i++) {
addDoc(writer, i); addDoc(writer, i);

View File

@ -146,8 +146,10 @@ public class TestIndexReader extends LuceneTestCase
public void testGetFieldNames() throws Exception { public void testGetFieldNames() throws Exception {
Directory d = newDirectory(); Directory d = newDirectory();
// set up writer // set up writer
IndexWriter writer = new IndexWriter(d, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer())); d,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer())
);
Document doc = new Document(); Document doc = new Document();
doc.add(new Field("keyword","test1", Field.Store.YES, Field.Index.NOT_ANALYZED)); doc.add(new Field("keyword","test1", Field.Store.YES, Field.Index.NOT_ANALYZED));
@ -166,8 +168,12 @@ public class TestIndexReader extends LuceneTestCase
assertTrue(fieldNames.contains("unstored")); assertTrue(fieldNames.contains("unstored"));
reader.close(); reader.close();
// add more documents // add more documents
writer = new IndexWriter(d, newIndexWriterConfig(TEST_VERSION_CURRENT, writer = new IndexWriter(
new MockAnalyzer()).setOpenMode(OpenMode.APPEND)); d,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setOpenMode(OpenMode.APPEND).
setMergePolicy(newLogMergePolicy())
);
// want to get some more segments here // want to get some more segments here
int mergeFactor = ((LogMergePolicy) writer.getConfig().getMergePolicy()).getMergeFactor(); int mergeFactor = ((LogMergePolicy) writer.getConfig().getMergePolicy()).getMergeFactor();
for (int i = 0; i < 5*mergeFactor; i++) { for (int i = 0; i < 5*mergeFactor; i++) {
@ -261,8 +267,11 @@ public class TestIndexReader extends LuceneTestCase
public void testTermVectors() throws Exception { public void testTermVectors() throws Exception {
Directory d = newDirectory(); Directory d = newDirectory();
// set up writer // set up writer
IndexWriter writer = new IndexWriter(d, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer())); d,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMergePolicy(newLogMergePolicy())
);
// want to get some more segments here // want to get some more segments here
// new termvector fields // new termvector fields
int mergeFactor = ((LogMergePolicy) writer.getConfig().getMergePolicy()).getMergeFactor(); int mergeFactor = ((LogMergePolicy) writer.getConfig().getMergePolicy()).getMergeFactor();
@ -566,9 +575,11 @@ public class TestIndexReader extends LuceneTestCase
Term searchTerm = new Term("content", "aaa"); Term searchTerm = new Term("content", "aaa");
// add 1 documents with term : aaa // add 1 documents with term : aaa
writer = new IndexWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer())); writer = new IndexWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundFile(false); dir,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundDocStore(false); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMergePolicy(newLogMergePolicy(false))
);
addDoc(writer, searchTerm.text()); addDoc(writer, searchTerm.text());
writer.close(); writer.close();
@ -1410,10 +1421,12 @@ public class TestIndexReader extends LuceneTestCase
Directory d = newDirectory(); Directory d = newDirectory();
// set up writer // set up writer
IndexWriter writer = new IndexWriter(d, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) d,
.setMaxBufferedDocs(2)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(10))
);
for(int i=0;i<27;i++) for(int i=0;i<27;i++)
addDocumentWithFields(writer); addDocumentWithFields(writer);
writer.close(); writer.close();
@ -1428,10 +1441,13 @@ public class TestIndexReader extends LuceneTestCase
assertTrue(c.equals(r.getIndexCommit())); assertTrue(c.equals(r.getIndexCommit()));
// Change the index // Change the index
writer = new IndexWriter(d, newIndexWriterConfig(TEST_VERSION_CURRENT, writer = new IndexWriter(
new MockAnalyzer()).setOpenMode( d,
OpenMode.APPEND).setMaxBufferedDocs(2)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(10))
);
for(int i=0;i<7;i++) for(int i=0;i<7;i++)
addDocumentWithFields(writer); addDocumentWithFields(writer);
writer.close(); writer.close();
@ -1471,11 +1487,13 @@ public class TestIndexReader extends LuceneTestCase
} catch (UnsupportedOperationException uoe) { } catch (UnsupportedOperationException uoe) {
// expected // expected
} }
writer = new IndexWriter(d, newIndexWriterConfig(TEST_VERSION_CURRENT, writer = new IndexWriter(
new MockAnalyzer()) d,
.setOpenMode(OpenMode.APPEND)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); setOpenMode(OpenMode.APPEND).
setMergePolicy(newLogMergePolicy(10))
);
addDocumentWithFields(writer); addDocumentWithFields(writer);
writer.close(); writer.close();
@ -1619,7 +1637,7 @@ public class TestIndexReader extends LuceneTestCase
writer.close(); writer.close();
// Open reader // Open reader
IndexReader r = SegmentReader.getOnlySegmentReader(dir); IndexReader r = getOnlySegmentReader(IndexReader.open(dir, false));
final int[] ints = FieldCache.DEFAULT.getInts(r, "number"); final int[] ints = FieldCache.DEFAULT.getInts(r, "number");
assertEquals(1, ints.length); assertEquals(1, ints.length);
assertEquals(17, ints[0]); assertEquals(17, ints[0]);
@ -1643,16 +1661,19 @@ public class TestIndexReader extends LuceneTestCase
// FieldCache // FieldCache
public void testFieldCacheReuseAfterReopen() throws Exception { public void testFieldCacheReuseAfterReopen() throws Exception {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer())); IndexWriter writer = new IndexWriter(
dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMergePolicy(newLogMergePolicy(10))
);
Document doc = new Document(); Document doc = new Document();
doc.add(newField("number", "17", Field.Store.NO, Field.Index.NOT_ANALYZED)); doc.add(newField("number", "17", Field.Store.NO, Field.Index.NOT_ANALYZED));
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10);
writer.addDocument(doc); writer.addDocument(doc);
writer.commit(); writer.commit();
// Open reader1 // Open reader1
IndexReader r = IndexReader.open(dir, false); IndexReader r = IndexReader.open(dir, false);
IndexReader r1 = SegmentReader.getOnlySegmentReader(r); IndexReader r1 = getOnlySegmentReader(r);
final int[] ints = FieldCache.DEFAULT.getInts(r1, "number"); final int[] ints = FieldCache.DEFAULT.getInts(r1, "number");
assertEquals(1, ints.length); assertEquals(1, ints.length);
assertEquals(17, ints[0]); assertEquals(17, ints[0]);
@ -1676,8 +1697,12 @@ public class TestIndexReader extends LuceneTestCase
// reopen switches readOnly // reopen switches readOnly
public void testReopenChangeReadonly() throws Exception { public void testReopenChangeReadonly() throws Exception {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(-1)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(10); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(-1).
setMergePolicy(newLogMergePolicy(10))
);
Document doc = new Document(); Document doc = new Document();
doc.add(newField("number", "17", Field.Store.NO, Field.Index.NOT_ANALYZED)); doc.add(newField("number", "17", Field.Store.NO, Field.Index.NOT_ANALYZED));
writer.addDocument(doc); writer.addDocument(doc);
@ -1686,7 +1711,7 @@ public class TestIndexReader extends LuceneTestCase
// Open reader1 // Open reader1
IndexReader r = IndexReader.open(dir, false); IndexReader r = IndexReader.open(dir, false);
assertTrue(r instanceof DirectoryReader); assertTrue(r instanceof DirectoryReader);
IndexReader r1 = SegmentReader.getOnlySegmentReader(r); IndexReader r1 = getOnlySegmentReader(r);
final int[] ints = FieldCache.DEFAULT.getInts(r1, "number"); final int[] ints = FieldCache.DEFAULT.getInts(r1, "number");
assertEquals(1, ints.length); assertEquals(1, ints.length);
assertEquals(17, ints[0]); assertEquals(17, ints[0]);
@ -1727,7 +1752,7 @@ public class TestIndexReader extends LuceneTestCase
writer.commit(); writer.commit();
IndexReader r = IndexReader.open(dir, false); IndexReader r = IndexReader.open(dir, false);
IndexReader r1 = SegmentReader.getOnlySegmentReader(r); IndexReader r1 = getOnlySegmentReader(r);
assertEquals(36, r1.getUniqueTermCount()); assertEquals(36, r1.getUniqueTermCount());
writer.addDocument(doc); writer.addDocument(doc);
writer.commit(); writer.commit();
@ -1768,8 +1793,12 @@ public class TestIndexReader extends LuceneTestCase
} }
assertEquals(-1, ((SegmentReader) r.getSequentialSubReaders()[0]).getTermInfosIndexDivisor()); assertEquals(-1, ((SegmentReader) r.getSequentialSubReaders()[0]).getTermInfosIndexDivisor());
writer = new IndexWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setCodecProvider(_TestUtil.alwaysCodec("Standard"))); writer = new IndexWriter(
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setCodecProvider(_TestUtil.alwaysCodec("Standard")).
setMergePolicy(newLogMergePolicy(10))
);
writer.addDocument(doc); writer.addDocument(doc);
writer.close(); writer.close();

View File

@ -302,7 +302,7 @@ public class TestIndexReaderClone extends LuceneTestCase {
IndexReader r1 = IndexReader.open(dir1, false); IndexReader r1 = IndexReader.open(dir1, false);
IndexReader r2 = IndexReader.open(dir2, false); IndexReader r2 = IndexReader.open(dir2, false);
MultiReader multiReader = new MultiReader(new IndexReader[] { r1, r2 }); MultiReader multiReader = new MultiReader(r1, r2);
performDefaultTests(multiReader); performDefaultTests(multiReader);
multiReader.close(); multiReader.close();
dir1.close(); dir1.close();
@ -312,7 +312,7 @@ public class TestIndexReaderClone extends LuceneTestCase {
public void testSegmentReaderUndeleteall() throws Exception { public void testSegmentReaderUndeleteall() throws Exception {
final Directory dir1 = newDirectory(); final Directory dir1 = newDirectory();
TestIndexReaderReopen.createIndex(random, dir1, false); TestIndexReaderReopen.createIndex(random, dir1, false);
SegmentReader origSegmentReader = SegmentReader.getOnlySegmentReader(dir1); SegmentReader origSegmentReader = getOnlySegmentReader(IndexReader.open(dir1, false));
origSegmentReader.deleteDocument(10); origSegmentReader.deleteDocument(10);
assertDelDocsRefCountEquals(1, origSegmentReader); assertDelDocsRefCountEquals(1, origSegmentReader);
origSegmentReader.undeleteAll(); origSegmentReader.undeleteAll();
@ -325,7 +325,7 @@ public class TestIndexReaderClone extends LuceneTestCase {
public void testSegmentReaderCloseReferencing() throws Exception { public void testSegmentReaderCloseReferencing() throws Exception {
final Directory dir1 = newDirectory(); final Directory dir1 = newDirectory();
TestIndexReaderReopen.createIndex(random, dir1, false); TestIndexReaderReopen.createIndex(random, dir1, false);
SegmentReader origSegmentReader = SegmentReader.getOnlySegmentReader(dir1); SegmentReader origSegmentReader = getOnlySegmentReader(IndexReader.open(dir1, false));
origSegmentReader.deleteDocument(1); origSegmentReader.deleteDocument(1);
origSegmentReader.setNorm(4, "field1", 0.5f); origSegmentReader.setNorm(4, "field1", 0.5f);
@ -346,7 +346,7 @@ public class TestIndexReaderClone extends LuceneTestCase {
TestIndexReaderReopen.createIndex(random, dir1, false); TestIndexReaderReopen.createIndex(random, dir1, false);
IndexReader origReader = IndexReader.open(dir1, false); IndexReader origReader = IndexReader.open(dir1, false);
SegmentReader origSegmentReader = SegmentReader.getOnlySegmentReader(origReader); SegmentReader origSegmentReader = getOnlySegmentReader(origReader);
// deletedDocsRef should be null because nothing has updated yet // deletedDocsRef should be null because nothing has updated yet
assertNull(origSegmentReader.deletedDocsRef); assertNull(origSegmentReader.deletedDocsRef);
@ -358,7 +358,7 @@ public class TestIndexReaderClone extends LuceneTestCase {
// the cloned segmentreader should have 2 references, 1 to itself, and 1 to // the cloned segmentreader should have 2 references, 1 to itself, and 1 to
// the original segmentreader // the original segmentreader
IndexReader clonedReader = (IndexReader) origReader.clone(); IndexReader clonedReader = (IndexReader) origReader.clone();
SegmentReader clonedSegmentReader = SegmentReader.getOnlySegmentReader(clonedReader); SegmentReader clonedSegmentReader = getOnlySegmentReader(clonedReader);
assertDelDocsRefCountEquals(2, origSegmentReader); assertDelDocsRefCountEquals(2, origSegmentReader);
// deleting a document creates a new deletedDocs bitvector, the refs goes to // deleting a document creates a new deletedDocs bitvector, the refs goes to
// 1 // 1
@ -395,7 +395,7 @@ public class TestIndexReaderClone extends LuceneTestCase {
// test a reopened reader // test a reopened reader
IndexReader reopenedReader = clonedReader.reopen(); IndexReader reopenedReader = clonedReader.reopen();
IndexReader cloneReader2 = (IndexReader) reopenedReader.clone(); IndexReader cloneReader2 = (IndexReader) reopenedReader.clone();
SegmentReader cloneSegmentReader2 = SegmentReader.getOnlySegmentReader(cloneReader2); SegmentReader cloneSegmentReader2 = getOnlySegmentReader(cloneReader2);
assertDelDocsRefCountEquals(2, cloneSegmentReader2); assertDelDocsRefCountEquals(2, cloneSegmentReader2);
clonedReader.close(); clonedReader.close();
reopenedReader.close(); reopenedReader.close();
@ -490,10 +490,11 @@ public class TestIndexReaderClone extends LuceneTestCase {
public void testCloseStoredFields() throws Exception { public void testCloseStoredFields() throws Exception {
final Directory dir = newDirectory(); final Directory dir = newDirectory();
IndexWriter w = new IndexWriter(dir, newIndexWriterConfig( IndexWriter w = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer())); dir,
((LogMergePolicy) w.getConfig().getMergePolicy()).setUseCompoundFile(false); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) w.getConfig().getMergePolicy()).setUseCompoundDocStore(false); setMergePolicy(newLogMergePolicy(false))
);
Document doc = new Document(); Document doc = new Document();
doc.add(newField("field", "yes it's stored", Field.Store.YES, Field.Index.ANALYZED)); doc.add(newField("field", "yes it's stored", Field.Store.YES, Field.Index.ANALYZED));
w.addDocument(doc); w.addDocument(doc);

View File

@ -109,11 +109,14 @@ public class TestIndexReaderCloneNorms extends LuceneTestCase {
Directory dir3 = FSDirectory.open(indexDir3); Directory dir3 = FSDirectory.open(indexDir3);
createIndex(random, dir3); createIndex(random, dir3);
IndexWriter iw = new IndexWriter(dir3, newIndexWriterConfig( IndexWriter iw = new IndexWriter(
TEST_VERSION_CURRENT, anlzr).setOpenMode(OpenMode.APPEND) dir3,
.setMaxBufferedDocs(5)); newIndexWriterConfig(TEST_VERSION_CURRENT, anlzr).
((LogMergePolicy) iw.getConfig().getMergePolicy()).setMergeFactor(3); setOpenMode(OpenMode.APPEND).
iw.addIndexes(new Directory[] { dir1, dir2 }); setMaxBufferedDocs(5).
setMergePolicy(newLogMergePolicy(3))
);
iw.addIndexes(dir1, dir2);
iw.optimize(); iw.optimize();
iw.close(); iw.close();
@ -128,9 +131,13 @@ public class TestIndexReaderCloneNorms extends LuceneTestCase {
doTestNorms(random, dir3); doTestNorms(random, dir3);
// now with optimize // now with optimize
iw = new IndexWriter(dir3, newIndexWriterConfig( TEST_VERSION_CURRENT, iw = new IndexWriter(
anlzr).setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(5)); dir3,
((LogMergePolicy) iw.getConfig().getMergePolicy()).setMergeFactor(3); newIndexWriterConfig(TEST_VERSION_CURRENT, anlzr).
setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(5).
setMergePolicy(newLogMergePolicy(3))
);
iw.optimize(); iw.optimize();
iw.close(); iw.close();
verifyIndex(dir3); verifyIndex(dir3);
@ -162,7 +169,7 @@ public class TestIndexReaderCloneNorms extends LuceneTestCase {
public void testNormsClose() throws IOException { public void testNormsClose() throws IOException {
Directory dir1 = newDirectory(); Directory dir1 = newDirectory();
TestIndexReaderReopen.createIndex(random, dir1, false); TestIndexReaderReopen.createIndex(random, dir1, false);
SegmentReader reader1 = SegmentReader.getOnlySegmentReader(dir1); SegmentReader reader1 = getOnlySegmentReader(IndexReader.open(dir1, false));
reader1.norms("field1"); reader1.norms("field1");
Norm r1norm = reader1.norms.get("field1"); Norm r1norm = reader1.norms.get("field1");
AtomicInteger r1BytesRef = r1norm.bytesRef(); AtomicInteger r1BytesRef = r1norm.bytesRef();
@ -181,7 +188,7 @@ public class TestIndexReaderCloneNorms extends LuceneTestCase {
IndexReader reader1 = IndexReader.open(dir1, false); IndexReader reader1 = IndexReader.open(dir1, false);
IndexReader reader2C = (IndexReader) reader1.clone(); IndexReader reader2C = (IndexReader) reader1.clone();
SegmentReader segmentReader2C = SegmentReader.getOnlySegmentReader(reader2C); SegmentReader segmentReader2C = getOnlySegmentReader(reader2C);
segmentReader2C.norms("field1"); // load the norms for the field segmentReader2C.norms("field1"); // load the norms for the field
Norm reader2CNorm = segmentReader2C.norms.get("field1"); Norm reader2CNorm = segmentReader2C.norms.get("field1");
assertTrue("reader2CNorm.bytesRef()=" + reader2CNorm.bytesRef(), reader2CNorm.bytesRef().get() == 2); assertTrue("reader2CNorm.bytesRef()=" + reader2CNorm.bytesRef(), reader2CNorm.bytesRef().get() == 2);
@ -189,13 +196,13 @@ public class TestIndexReaderCloneNorms extends LuceneTestCase {
IndexReader reader3C = (IndexReader) reader2C.clone(); IndexReader reader3C = (IndexReader) reader2C.clone();
SegmentReader segmentReader3C = SegmentReader.getOnlySegmentReader(reader3C); SegmentReader segmentReader3C = getOnlySegmentReader(reader3C);
Norm reader3CCNorm = segmentReader3C.norms.get("field1"); Norm reader3CCNorm = segmentReader3C.norms.get("field1");
assertEquals(3, reader3CCNorm.bytesRef().get()); assertEquals(3, reader3CCNorm.bytesRef().get());
// edit a norm and the refcount should be 1 // edit a norm and the refcount should be 1
IndexReader reader4C = (IndexReader) reader3C.clone(); IndexReader reader4C = (IndexReader) reader3C.clone();
SegmentReader segmentReader4C = SegmentReader.getOnlySegmentReader(reader4C); SegmentReader segmentReader4C = getOnlySegmentReader(reader4C);
assertEquals(4, reader3CCNorm.bytesRef().get()); assertEquals(4, reader3CCNorm.bytesRef().get());
reader4C.setNorm(5, "field1", 0.33f); reader4C.setNorm(5, "field1", 0.33f);
@ -215,7 +222,7 @@ public class TestIndexReaderCloneNorms extends LuceneTestCase {
assertEquals(1, reader4CCNorm.bytesRef().get()); assertEquals(1, reader4CCNorm.bytesRef().get());
IndexReader reader5C = (IndexReader) reader4C.clone(); IndexReader reader5C = (IndexReader) reader4C.clone();
SegmentReader segmentReader5C = SegmentReader.getOnlySegmentReader(reader5C); SegmentReader segmentReader5C = getOnlySegmentReader(reader5C);
Norm reader5CCNorm = segmentReader5C.norms.get("field1"); Norm reader5CCNorm = segmentReader5C.norms.get("field1");
reader5C.setNorm(5, "field1", 0.7f); reader5C.setNorm(5, "field1", 0.7f);
assertEquals(1, reader5CCNorm.bytesRef().get()); assertEquals(1, reader5CCNorm.bytesRef().get());

View File

@ -230,9 +230,8 @@ public class TestIndexReaderReopen extends LuceneTestCase {
@Override @Override
protected IndexReader openReader() throws IOException { protected IndexReader openReader() throws IOException {
return new MultiReader(new IndexReader[] return new MultiReader(IndexReader.open(dir1, false),
{IndexReader.open(dir1, false), IndexReader.open(dir2, false));
IndexReader.open(dir2, false)});
} }
}); });
@ -256,12 +255,11 @@ public class TestIndexReaderReopen extends LuceneTestCase {
@Override @Override
protected IndexReader openReader() throws IOException { protected IndexReader openReader() throws IOException {
return new MultiReader(new IndexReader[] return new MultiReader(IndexReader.open(dir3, false),
{IndexReader.open(dir3, false), IndexReader.open(dir4, false),
IndexReader.open(dir4, false), // Does not implement reopen, so
// Does not implement reopen, so // hits exception:
// hits exception: new FilterIndexReader(IndexReader.open(dir3, false)));
new FilterIndexReader(IndexReader.open(dir3, false))});
} }
}); });
@ -297,10 +295,8 @@ public class TestIndexReaderReopen extends LuceneTestCase {
ParallelReader pr = new ParallelReader(); ParallelReader pr = new ParallelReader();
pr.add(IndexReader.open(dir1, false)); pr.add(IndexReader.open(dir1, false));
pr.add(IndexReader.open(dir2, false)); pr.add(IndexReader.open(dir2, false));
MultiReader mr = new MultiReader(new IndexReader[] { MultiReader mr = new MultiReader(IndexReader.open(dir3, false), IndexReader.open(dir4, false));
IndexReader.open(dir3, false), IndexReader.open(dir4, false)}); return new MultiReader(pr, mr, IndexReader.open(dir5, false));
return new MultiReader(new IndexReader[] {
pr, mr, IndexReader.open(dir5, false)});
} }
}); });
dir1.close(); dir1.close();
@ -612,7 +608,7 @@ public class TestIndexReaderReopen extends LuceneTestCase {
createIndex(random, dir1, false); createIndex(random, dir1, false);
IndexReader reader1 = IndexReader.open(dir1, false); IndexReader reader1 = IndexReader.open(dir1, false);
SegmentReader segmentReader1 = SegmentReader.getOnlySegmentReader(reader1); SegmentReader segmentReader1 = getOnlySegmentReader(reader1);
IndexReader modifier = IndexReader.open(dir1, false); IndexReader modifier = IndexReader.open(dir1, false);
modifier.deleteDocument(0); modifier.deleteDocument(0);
modifier.close(); modifier.close();
@ -624,7 +620,7 @@ public class TestIndexReaderReopen extends LuceneTestCase {
modifier.close(); modifier.close();
IndexReader reader3 = reader2.reopen(); IndexReader reader3 = reader2.reopen();
SegmentReader segmentReader3 = SegmentReader.getOnlySegmentReader(reader3); SegmentReader segmentReader3 = getOnlySegmentReader(reader3);
modifier = IndexReader.open(dir1, false); modifier = IndexReader.open(dir1, false);
modifier.deleteDocument(2); modifier.deleteDocument(2);
modifier.close(); modifier.close();
@ -1167,7 +1163,7 @@ public class TestIndexReaderReopen extends LuceneTestCase {
IndexReader[] rs2 = r2.getSequentialSubReaders(); IndexReader[] rs2 = r2.getSequentialSubReaders();
SegmentReader sr1 = SegmentReader.getOnlySegmentReader(r1); SegmentReader sr1 = getOnlySegmentReader(r1);
SegmentReader sr2 = (SegmentReader) rs2[0]; SegmentReader sr2 = (SegmentReader) rs2[0];
// At this point they share the same BitVector // At this point they share the same BitVector
@ -1190,9 +1186,13 @@ public class TestIndexReaderReopen extends LuceneTestCase {
public void testReopenOnCommit() throws Throwable { public void testReopenOnCommit() throws Throwable {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()).setIndexDeletionPolicy(new KeepAllCommits()).setMaxBufferedDocs(-1)); dir,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(10); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setIndexDeletionPolicy(new KeepAllCommits()).
setMaxBufferedDocs(-1).
setMergePolicy(newLogMergePolicy(10))
);
for(int i=0;i<4;i++) { for(int i=0;i<4;i++) {
Document doc = new Document(); Document doc = new Document();
doc.add(newField("id", ""+i, Field.Store.NO, Field.Index.NOT_ANALYZED)); doc.add(newField("id", ""+i, Field.Store.NO, Field.Index.NOT_ANALYZED));

View File

@ -495,8 +495,13 @@ public class TestIndexWriter extends LuceneTestCase {
*/ */
public void testCommitOnCloseDiskUsage() throws IOException { public void testCommitOnCloseDiskUsage() throws IOException {
MockDirectoryWrapper dir = newDirectory(); MockDirectoryWrapper dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(10).setReaderPooling(false)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); dir,
newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(10).
setReaderPooling(false).
setMergePolicy(newLogMergePolicy(10))
);
for(int j=0;j<30;j++) { for(int j=0;j<30;j++) {
addDocWithIndex(writer, j); addDocWithIndex(writer, j);
} }
@ -505,10 +510,16 @@ public class TestIndexWriter extends LuceneTestCase {
dir.setTrackDiskUsage(true); dir.setTrackDiskUsage(true);
long startDiskUsage = dir.getMaxUsedSizeInBytes(); long startDiskUsage = dir.getMaxUsedSizeInBytes();
writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()) writer = new IndexWriter(
.setOpenMode(OpenMode.APPEND).setMaxBufferedDocs(10).setMergeScheduler( dir,
new SerialMergeScheduler()).setReaderPooling(false)); newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer())
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); .setOpenMode(OpenMode.APPEND).
setMaxBufferedDocs(10).
setMergeScheduler(new SerialMergeScheduler()).
setReaderPooling(false).
setMergePolicy(newLogMergePolicy(10))
);
for(int j=0;j<1470;j++) { for(int j=0;j<1470;j++) {
addDocWithIndex(writer, j); addDocWithIndex(writer, j);
} }
@ -546,8 +557,12 @@ public class TestIndexWriter extends LuceneTestCase {
// test uses IW.rollback which easily results in // test uses IW.rollback which easily results in
// writing to same file more than once // writing to same file more than once
dir.setPreventDoubleWrite(false); dir.setPreventDoubleWrite(false);
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(10)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(10); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(10).
setMergePolicy(newLogMergePolicy(10))
);
for(int j=0;j<17;j++) { for(int j=0;j<17;j++) {
addDocWithIndex(writer, j); addDocWithIndex(writer, j);
} }
@ -657,8 +672,12 @@ public class TestIndexWriter extends LuceneTestCase {
public void testSmallRAMBuffer() throws IOException { public void testSmallRAMBuffer() throws IOException {
MockDirectoryWrapper dir = newDirectory(); MockDirectoryWrapper dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).setRAMBufferSizeMB(0.000001)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); dir,
newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).
setRAMBufferSizeMB(0.000001).
setMergePolicy(newLogMergePolicy(10))
);
int lastNumFile = dir.listAll().length; int lastNumFile = dir.listAll().length;
for(int j=0;j<9;j++) { for(int j=0;j<9;j++) {
Document doc = new Document(); Document doc = new Document();
@ -674,133 +693,6 @@ public class TestIndexWriter extends LuceneTestCase {
dir.close(); dir.close();
} }
/**
* Make sure it's OK to change RAM buffer size and // maxBufferedDocs in a
* write session
*
* @deprecated after all the setters on IW go away (4.0), this test can be
* removed because changing ram buffer settings during a write
* session won't be possible.
*/
@Deprecated
public void testChangingRAMBuffer() throws IOException {
MockDirectoryWrapper dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig(
TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(10).setRAMBufferSizeMB(
IndexWriterConfig.DISABLE_AUTO_FLUSH));
int lastFlushCount = -1;
for(int j=1;j<52;j++) {
Document doc = new Document();
doc.add(newField("field", "aaa" + j, Field.Store.YES, Field.Index.ANALYZED));
writer.addDocument(doc);
_TestUtil.syncConcurrentMerges(writer);
int flushCount = writer.getFlushCount();
if (j == 1)
lastFlushCount = flushCount;
else if (j < 10)
// No new files should be created
assertEquals(flushCount, lastFlushCount);
else if (10 == j) {
assertTrue(flushCount > lastFlushCount);
lastFlushCount = flushCount;
writer.setRAMBufferSizeMB(0.000001);
writer.setMaxBufferedDocs(IndexWriterConfig.DISABLE_AUTO_FLUSH);
} else if (j < 20) {
assertTrue(flushCount > lastFlushCount);
lastFlushCount = flushCount;
} else if (20 == j) {
writer.setRAMBufferSizeMB(16);
writer.setMaxBufferedDocs(IndexWriterConfig.DISABLE_AUTO_FLUSH);
lastFlushCount = flushCount;
} else if (j < 30) {
assertEquals(flushCount, lastFlushCount);
} else if (30 == j) {
writer.setRAMBufferSizeMB(0.000001);
writer.setMaxBufferedDocs(IndexWriterConfig.DISABLE_AUTO_FLUSH);
} else if (j < 40) {
assertTrue(flushCount> lastFlushCount);
lastFlushCount = flushCount;
} else if (40 == j) {
writer.setMaxBufferedDocs(10);
writer.setRAMBufferSizeMB(IndexWriterConfig.DISABLE_AUTO_FLUSH);
lastFlushCount = flushCount;
} else if (j < 50) {
assertEquals(flushCount, lastFlushCount);
writer.setMaxBufferedDocs(10);
writer.setRAMBufferSizeMB(IndexWriterConfig.DISABLE_AUTO_FLUSH);
} else if (50 == j) {
assertTrue(flushCount > lastFlushCount);
}
}
writer.close();
dir.close();
}
/**
* @deprecated after setters on IW go away, this test can be deleted because
* changing those settings on IW won't be possible.
*/
@Deprecated
public void testChangingRAMBuffer2() throws IOException {
MockDirectoryWrapper dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig(
TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(10).setMaxBufferedDeleteTerms(
10).setRAMBufferSizeMB(IndexWriterConfig.DISABLE_AUTO_FLUSH));
for(int j=1;j<52;j++) {
Document doc = new Document();
doc.add(newField("field", "aaa" + j, Field.Store.YES, Field.Index.ANALYZED));
writer.addDocument(doc);
}
int lastFlushCount = -1;
for(int j=1;j<52;j++) {
writer.deleteDocuments(new Term("field", "aaa" + j));
_TestUtil.syncConcurrentMerges(writer);
int flushCount = writer.getFlushCount();
if (j == 1)
lastFlushCount = flushCount;
else if (j < 10) {
// No new files should be created
assertEquals(flushCount, lastFlushCount);
} else if (10 == j) {
assertTrue(flushCount > lastFlushCount);
lastFlushCount = flushCount;
writer.setRAMBufferSizeMB(0.000001);
writer.setMaxBufferedDeleteTerms(1);
} else if (j < 20) {
assertTrue(flushCount > lastFlushCount);
lastFlushCount = flushCount;
} else if (20 == j) {
writer.setRAMBufferSizeMB(16);
writer.setMaxBufferedDeleteTerms(IndexWriterConfig.DISABLE_AUTO_FLUSH);
lastFlushCount = flushCount;
} else if (j < 30) {
assertEquals(flushCount, lastFlushCount);
} else if (30 == j) {
writer.setRAMBufferSizeMB(0.000001);
writer.setMaxBufferedDeleteTerms(IndexWriterConfig.DISABLE_AUTO_FLUSH);
writer.setMaxBufferedDeleteTerms(1);
} else if (j < 40) {
assertTrue(flushCount> lastFlushCount);
lastFlushCount = flushCount;
} else if (40 == j) {
writer.setMaxBufferedDeleteTerms(10);
writer.setRAMBufferSizeMB(IndexWriterConfig.DISABLE_AUTO_FLUSH);
lastFlushCount = flushCount;
} else if (j < 50) {
assertEquals(flushCount, lastFlushCount);
writer.setMaxBufferedDeleteTerms(10);
writer.setRAMBufferSizeMB(IndexWriterConfig.DISABLE_AUTO_FLUSH);
} else if (50 == j) {
assertTrue(flushCount > lastFlushCount);
}
}
writer.close();
dir.close();
}
public void testDiverseDocs() throws IOException { public void testDiverseDocs() throws IOException {
MockDirectoryWrapper dir = newDirectory(); MockDirectoryWrapper dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).setRAMBufferSizeMB(0.5)); IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).setRAMBufferSizeMB(0.5));
@ -968,11 +860,14 @@ public class TestIndexWriter extends LuceneTestCase {
public void testFlushWithNoMerging() throws IOException { public void testFlushWithNoMerging() throws IOException {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(2)); dir,
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(10))
);
Document doc = new Document(); Document doc = new Document();
doc.add(newField("field", "aaa", Field.Store.YES, Field.Index.ANALYZED, Field.TermVector.WITH_POSITIONS_OFFSETS)); doc.add(newField("field", "aaa", Store.YES, Index.ANALYZED, TermVector.WITH_POSITIONS_OFFSETS));
for(int i=0;i<19;i++) for(int i=0;i<19;i++)
writer.addDocument(doc); writer.addDocument(doc);
writer.flush(false, true, true); writer.flush(false, true, true);
@ -1010,12 +905,15 @@ public class TestIndexWriter extends LuceneTestCase {
Directory dir = newDirectory(); Directory dir = newDirectory();
for(int pass=0;pass<2;pass++) { for(int pass=0;pass<2;pass++) {
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setOpenMode(OpenMode.CREATE).setMaxBufferedDocs(2)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(101); setOpenMode(OpenMode.CREATE).
setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(101))
);
Document doc = new Document(); Document doc = new Document();
doc.add(newField("field", "aaa", Field.Store.YES, Field.Index.ANALYZED, Field.TermVector.WITH_POSITIONS_OFFSETS)); doc.add(newField("field", "aaa", Store.YES, Index.ANALYZED, TermVector.WITH_POSITIONS_OFFSETS));
for(int i=0;i<200;i++) for(int i=0;i<200;i++)
writer.addDocument(doc); writer.addDocument(doc);
writer.optimize(false); writer.optimize(false);
@ -1200,20 +1098,17 @@ public class TestIndexWriter extends LuceneTestCase {
for(int pass=0;pass<2;pass++) { for(int pass=0;pass<2;pass++) {
IndexWriterConfig conf = newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()).setOpenMode(OpenMode.CREATE) directory,
.setMaxBufferedDocs(2); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
if (pass == 2) { setOpenMode(OpenMode.CREATE).
conf.setMergeScheduler(new SerialMergeScheduler()); setMaxBufferedDocs(2).
} // have to use compound file to prevent running out of
IndexWriter writer = new IndexWriter(directory, conf); // descripters when newDirectory returns a file-system
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(100); // backed directory:
setMergePolicy(newLogMergePolicy(false, 10))
);
// have to use compound file to prevent running out of
// descripters when newDirectory returns a file-system
// backed directory:
((LogMergePolicy) writer.getConfig().getMergePolicy()).setUseCompoundFile(true);
//System.out.println("TEST: pass=" + pass + " cms=" + (pass >= 2)); //System.out.println("TEST: pass=" + pass + " cms=" + (pass >= 2));
for(int iter=0;iter<10;iter++) { for(int iter=0;iter<10;iter++) {
//System.out.println("TEST: iter=" + iter); //System.out.println("TEST: iter=" + iter);
@ -1309,10 +1204,12 @@ public class TestIndexWriter extends LuceneTestCase {
public void testForceCommit() throws IOException { public void testForceCommit() throws IOException {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setMaxBufferedDocs(2)); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(5); setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(5))
);
writer.commit(); writer.commit();
for (int i = 0; i < 23; i++) for (int i = 0; i < 23; i++)
@ -1412,21 +1309,23 @@ public class TestIndexWriter extends LuceneTestCase {
// LUCENE-325: test expungeDeletes, when many adjacent merges are required // LUCENE-325: test expungeDeletes, when many adjacent merges are required
public void testExpungeDeletes2() throws IOException { public void testExpungeDeletes2() throws IOException {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setMaxBufferedDocs(2).setRAMBufferSizeMB( newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
IndexWriterConfig.DISABLE_AUTO_FLUSH)); setMaxBufferedDocs(2).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(50); setRAMBufferSizeMB(IndexWriterConfig.DISABLE_AUTO_FLUSH).
setMergePolicy(newLogMergePolicy(50))
);
Document document = new Document(); Document document = new Document();
document = new Document(); document = new Document();
Field storedField = newField("stored", "stored", Field.Store.YES, Field storedField = newField("stored", "stored", Store.YES,
Field.Index.NO); Index.NO);
document.add(storedField); document.add(storedField);
Field termVectorField = newField("termVector", "termVector", Field termVectorField = newField("termVector", "termVector",
Field.Store.NO, Field.Index.NOT_ANALYZED, Store.NO, Index.NOT_ANALYZED,
Field.TermVector.WITH_POSITIONS_OFFSETS); TermVector.WITH_POSITIONS_OFFSETS);
document.add(termVectorField); document.add(termVectorField);
for(int i=0;i<98;i++) for(int i=0;i<98;i++)
writer.addDocument(document); writer.addDocument(document);
@ -1440,9 +1339,11 @@ public class TestIndexWriter extends LuceneTestCase {
assertEquals(49, ir.numDocs()); assertEquals(49, ir.numDocs());
ir.close(); ir.close();
writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, writer = new IndexWriter(
new MockAnalyzer())); dir,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(3); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMergePolicy(newLogMergePolicy(3))
);
assertEquals(49, writer.numDocs()); assertEquals(49, writer.numDocs());
writer.expungeDeletes(); writer.expungeDeletes();
writer.close(); writer.close();
@ -1457,11 +1358,13 @@ public class TestIndexWriter extends LuceneTestCase {
// many adjacent merges are required // many adjacent merges are required
public void testExpungeDeletes3() throws IOException { public void testExpungeDeletes3() throws IOException {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setMaxBufferedDocs(2).setRAMBufferSizeMB( newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
IndexWriterConfig.DISABLE_AUTO_FLUSH)); setMaxBufferedDocs(2).
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(50); setRAMBufferSizeMB(IndexWriterConfig.DISABLE_AUTO_FLUSH).
setMergePolicy(newLogMergePolicy(50))
);
Document document = new Document(); Document document = new Document();
@ -1485,9 +1388,11 @@ public class TestIndexWriter extends LuceneTestCase {
assertEquals(49, ir.numDocs()); assertEquals(49, ir.numDocs());
ir.close(); ir.close();
writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer())); writer = new IndexWriter(
// Force many merges to happen dir,
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(3); newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).
setMergePolicy(newLogMergePolicy(3))
);
writer.expungeDeletes(false); writer.expungeDeletes(false);
writer.close(); writer.close();
ir = IndexReader.open(dir, true); ir = IndexReader.open(dir, true);
@ -1836,8 +1741,12 @@ public class TestIndexWriter extends LuceneTestCase {
public void testPrepareCommit() throws IOException { public void testPrepareCommit() throws IOException {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(2)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(5); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(5))
);
writer.commit(); writer.commit();
for (int i = 0; i < 23; i++) for (int i = 0; i < 23; i++)
@ -1888,8 +1797,12 @@ public class TestIndexWriter extends LuceneTestCase {
MockDirectoryWrapper dir = newDirectory(); MockDirectoryWrapper dir = newDirectory();
dir.setPreventDoubleWrite(false); dir.setPreventDoubleWrite(false);
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()).setMaxBufferedDocs(2)); IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(5); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(2).
setMergePolicy(newLogMergePolicy(5))
);
writer.commit(); writer.commit();
for (int i = 0; i < 23; i++) for (int i = 0; i < 23; i++)
@ -2091,7 +2004,7 @@ public class TestIndexWriter extends LuceneTestCase {
IndexReader r1 = IndexReader.open(dir2, true); IndexReader r1 = IndexReader.open(dir2, true);
IndexReader r2 = (IndexReader) r1.clone(); IndexReader r2 = (IndexReader) r1.clone();
writer.addIndexes(new IndexReader[] {r1, r2}); writer.addIndexes(r1, r2);
writer.close(); writer.close();
IndexReader r3 = IndexReader.open(dir, true); IndexReader r3 = IndexReader.open(dir, true);
@ -2564,11 +2477,13 @@ public class TestIndexWriter extends LuceneTestCase {
} }
public void testDeleteUnusedFiles() throws Exception { public void testDeleteUnusedFiles() throws Exception {
for(int iter=0;iter<2;iter++) { for(int iter=0;iter<2;iter++) {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter w = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer())); IndexWriter w = new IndexWriter(
((LogMergePolicy) w.getMergePolicy()).setUseCompoundFile(true); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMergePolicy(newLogMergePolicy(true))
);
Document doc = new Document(); Document doc = new Document();
doc.add(newField("field", "go", Field.Store.NO, Field.Index.ANALYZED)); doc.add(newField("field", "go", Field.Store.NO, Field.Index.ANALYZED));
w.addDocument(doc); w.addDocument(doc);
@ -2965,7 +2880,7 @@ public class TestIndexWriter extends LuceneTestCase {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter indexWriter = new IndexWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setRAMBufferSizeMB(0.01)); IndexWriter indexWriter = new IndexWriter(dir, newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).setRAMBufferSizeMB(0.01));
((LogMergePolicy) indexWriter.getMergePolicy()).setUseCompoundFile(false); ((LogMergePolicy) indexWriter.getConfig().getMergePolicy()).setUseCompoundFile(false);
String BIG="alskjhlaksjghlaksjfhalksvjepgjioefgjnsdfjgefgjhelkgjhqewlrkhgwlekgrhwelkgjhwelkgrhwlkejg"; String BIG="alskjhlaksjghlaksjfhalksvjepgjioefgjnsdfjgefgjhelkgjhqewlrkhgwlekgrhwelkgjhwelkgrhwlkejg";
BIG=BIG+BIG+BIG+BIG; BIG=BIG+BIG+BIG+BIG;

View File

@ -249,52 +249,4 @@ public class TestIndexWriterConfig extends LuceneTestCase {
conf.setMergePolicy(null); conf.setMergePolicy(null);
assertEquals(LogByteSizeMergePolicy.class, conf.getMergePolicy().getClass()); assertEquals(LogByteSizeMergePolicy.class, conf.getMergePolicy().getClass());
} }
/**
* @deprecated should be removed once all the deprecated setters are removed
* from IndexWriter.
*/
@Test @Deprecated
public void testIndexWriterSetters() throws Exception {
// This test intentionally tests deprecated methods. The purpose is to pass
// whatever the user set on IW to IWC, so that if the user calls
// iw.getConfig().getXYZ(), he'll get the same value he passed to
// iw.setXYZ().
IndexWriterConfig conf = new IndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer());
Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, conf);
writer.setSimilarity(new MySimilarity());
assertEquals(MySimilarity.class, writer.getConfig().getSimilarity().getClass());
writer.setMaxBufferedDeleteTerms(4);
assertEquals(4, writer.getConfig().getMaxBufferedDeleteTerms());
writer.setMaxBufferedDocs(10);
assertEquals(10, writer.getConfig().getMaxBufferedDocs());
writer.setMaxFieldLength(10);
assertEquals(10, writer.getConfig().getMaxFieldLength());
writer.setMergeScheduler(new SerialMergeScheduler());
assertEquals(SerialMergeScheduler.class, writer.getConfig().getMergeScheduler().getClass());
writer.setRAMBufferSizeMB(1.5);
assertEquals(1.5, writer.getConfig().getRAMBufferSizeMB(), 0.0);
writer.setTermIndexInterval(40);
assertEquals(40, writer.getConfig().getTermIndexInterval());
writer.setWriteLockTimeout(100);
assertEquals(100, writer.getConfig().getWriteLockTimeout());
writer.setMergedSegmentWarmer(new MyWarmer());
assertEquals(MyWarmer.class, writer.getConfig().getMergedSegmentWarmer().getClass());
writer.setMergePolicy(new LogDocMergePolicy());
assertEquals(LogDocMergePolicy.class, writer.getConfig().getMergePolicy().getClass());
writer.close();
dir.close();
}
} }

View File

@ -794,7 +794,7 @@ public class TestIndexWriterDelete extends LuceneTestCase {
public void testDeleteNullQuery() throws IOException { public void testDeleteNullQuery() throws IOException {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter modifier = new IndexWriter(dir, new MockAnalyzer(MockTokenizer.WHITESPACE, false), IndexWriter.MaxFieldLength.UNLIMITED); IndexWriter modifier = new IndexWriter(dir, new IndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer(MockTokenizer.WHITESPACE, false)));
for (int i = 0; i < 5; i++) { for (int i = 0; i < 5; i++) {
addDoc(modifier, i, 2*i); addDoc(modifier, i, 2*i);

View File

@ -612,8 +612,12 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
MockDirectoryWrapper dir = newDirectory(); MockDirectoryWrapper dir = newDirectory();
{ {
final IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, analyzer).setMaxBufferedDocs(-1)); final IndexWriter writer = new IndexWriter(
((LogMergePolicy) writer.getMergePolicy()).setMergeFactor(10); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, analyzer).
setMaxBufferedDocs(-1).
setMergePolicy(newLogMergePolicy(10))
);
final int finalI = i; final int finalI = i;
Thread[] threads = new Thread[NUM_THREAD]; Thread[] threads = new Thread[NUM_THREAD];
@ -740,10 +744,14 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
FailOnlyInSync failure = new FailOnlyInSync(); FailOnlyInSync failure = new FailOnlyInSync();
dir.failOn(failure); dir.failOn(failure);
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer()) IndexWriter writer = new IndexWriter(
.setMaxBufferedDocs(2).setMergeScheduler(new ConcurrentMergeScheduler())); dir,
newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(2).
setMergeScheduler(new ConcurrentMergeScheduler()).
setMergePolicy(newLogMergePolicy(5))
);
failure.setDoFail(); failure.setDoFail();
((LogMergePolicy) writer.getConfig().getMergePolicy()).setMergeFactor(5);
for (int i = 0; i < 23; i++) { for (int i = 0; i < 23; i++) {
addDoc(writer); addDoc(writer);
@ -1005,9 +1013,12 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
IndexWriter writer = null; IndexWriter writer = null;
writer = new IndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer())); writer = new IndexWriter(
((LogMergePolicy) writer.getMergePolicy()).setUseCompoundFile(true); dir,
((LogMergePolicy) writer.getMergePolicy()).setNoCFSRatio(1.0); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMergePolicy(newLogMergePolicy(true))
);
((LogMergePolicy) writer.getConfig().getMergePolicy()).setNoCFSRatio(1.0);
// add 100 documents // add 100 documents
for (int i = 0; i < 100; i++) { for (int i = 0; i < 100; i++) {

View File

@ -100,9 +100,12 @@ public class TestIndexWriterMergePolicy extends LuceneTestCase {
public void testMergeFactorChange() throws IOException { public void testMergeFactorChange() throws IOException {
Directory dir = newDirectory(); Directory dir = newDirectory();
IndexWriter writer = new IndexWriter(dir, newIndexWriterConfig( IndexWriter writer = new IndexWriter(
TEST_VERSION_CURRENT, new MockAnalyzer()) dir,
.setMaxBufferedDocs(10).setMergePolicy(new LogDocMergePolicy())); newIndexWriterConfig(TEST_VERSION_CURRENT, new MockAnalyzer()).
setMaxBufferedDocs(10).
setMergePolicy(newLogMergePolicy())
);
for (int i = 0; i < 250; i++) { for (int i = 0; i < 250; i++) {
addDoc(writer); addDoc(writer);

Some files were not shown because too many files have changed in this diff Show More