pylucene 3.5.0-3
[pylucene.git] / lucene-java-3.4.0 / lucene / contrib / facet / src / java / org / apache / lucene / facet / search / ScoredDocIdCollector.java
diff --git a/lucene-java-3.4.0/lucene/contrib/facet/src/java/org/apache/lucene/facet/search/ScoredDocIdCollector.java b/lucene-java-3.4.0/lucene/contrib/facet/src/java/org/apache/lucene/facet/search/ScoredDocIdCollector.java
deleted file mode 100644 (file)
index d24aaf2..0000000
+++ /dev/null
@@ -1,223 +0,0 @@
-package org.apache.lucene.facet.search;
-
-import java.io.IOException;
-
-import org.apache.lucene.index.IndexReader;
-import org.apache.lucene.search.Collector;
-import org.apache.lucene.search.DocIdSet;
-import org.apache.lucene.search.DocIdSetIterator;
-import org.apache.lucene.search.Scorer;
-import org.apache.lucene.util.ArrayUtil;
-import org.apache.lucene.util.OpenBitSet;
-
-/**
- * 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.
- */
-
-/**
- * A {@link Collector} which stores all docIDs and their scores in a
- * {@link ScoredDocIDs} instance. If scoring is not enabled, then the default
- * score as set in {@link #setDefaultScore(float)} (or
- * {@link ScoredDocIDsIterator#DEFAULT_SCORE}) will be set for all documents.
- * 
- * @lucene.experimental
- */
-public abstract class ScoredDocIdCollector extends Collector {
-
-  private static final class NonScoringDocIdCollector extends ScoredDocIdCollector {
-
-    float defaultScore = ScoredDocIDsIterator.DEFAULT_SCORE;
-
-    @SuppressWarnings("synthetic-access")
-    public NonScoringDocIdCollector(int maxDoc) {
-      super(maxDoc);
-    }
-
-    @Override
-    public boolean acceptsDocsOutOfOrder() { return true; }
-
-    @Override
-    public void collect(int doc) throws IOException {
-      docIds.fastSet(docBase + doc);
-      ++numDocIds;
-    }
-
-    @Override
-    public float getDefaultScore() {
-      return defaultScore;
-    }
-
-    @Override
-    public ScoredDocIDsIterator scoredDocIdsIterator() throws IOException {
-      return new ScoredDocIDsIterator() {
-
-        private DocIdSetIterator docIdsIter = docIds.iterator();
-        private int nextDoc;
-
-        public int getDocID() { return nextDoc; }
-        public float getScore() { return defaultScore; }
-
-        public boolean next() {
-          try {
-            nextDoc = docIdsIter.nextDoc();
-            return nextDoc != DocIdSetIterator.NO_MORE_DOCS;
-          } catch (IOException e) {
-            // This should not happen as we're iterating over an OpenBitSet. For
-            // completeness, terminate iteration
-            nextDoc = DocIdSetIterator.NO_MORE_DOCS;
-            return false;
-          }
-        }
-
-      };
-    }
-
-    @Override
-    public void setDefaultScore(float defaultScore) {
-      this.defaultScore = defaultScore;
-    }
-
-    @Override
-    public void setScorer(Scorer scorer) throws IOException {}
-  }
-
-  private static final class ScoringDocIdCollector extends ScoredDocIdCollector {
-
-    float[] scores;
-    private Scorer scorer;
-
-    @SuppressWarnings("synthetic-access")
-    public ScoringDocIdCollector(int maxDoc) {
-      super(maxDoc);
-      scores = new float[maxDoc];
-    }
-
-    @Override
-    public boolean acceptsDocsOutOfOrder() { return false; }
-
-    @Override
-    public void collect(int doc) throws IOException {
-      docIds.fastSet(docBase + doc);
-
-      float score = this.scorer.score();
-      if (numDocIds >= scores.length) {
-        float[] newScores = new float[ArrayUtil.oversize(numDocIds + 1, 4)];
-        System.arraycopy(scores, 0, newScores, 0, numDocIds);
-        scores = newScores;
-      }
-      scores[numDocIds] = score;
-      ++numDocIds;
-    }
-
-    @Override
-    public ScoredDocIDsIterator scoredDocIdsIterator() throws IOException {
-      return new ScoredDocIDsIterator() {
-
-        private DocIdSetIterator docIdsIter = docIds.iterator();
-        private int nextDoc;
-        private int scoresIdx = -1;
-
-        public int getDocID() { return nextDoc; }
-        public float getScore() { return scores[scoresIdx]; }
-
-        public boolean next() {
-          try {
-            nextDoc = docIdsIter.nextDoc();
-            if (nextDoc == DocIdSetIterator.NO_MORE_DOCS) {
-              return false;
-            }
-            ++scoresIdx;
-            return true;
-          } catch (IOException e) {
-            // This should not happen as we're iterating over an OpenBitSet. For
-            // completeness, terminate iteration
-            nextDoc = DocIdSetIterator.NO_MORE_DOCS;
-            return false;
-          }
-        }
-
-      };
-    }
-
-    @Override
-    public float getDefaultScore() { return ScoredDocIDsIterator.DEFAULT_SCORE; }
-
-    @Override
-    public void setDefaultScore(float defaultScore) {}
-
-    @Override
-    public void setScorer(Scorer scorer) throws IOException {
-      this.scorer = scorer;
-    }
-  }
-
-  protected int numDocIds;
-  protected int docBase;
-  protected final OpenBitSet docIds;
-
-  /**
-   * Creates a new {@link ScoredDocIdCollector} with the given parameters.
-   * 
-   * @param maxDoc the number of documents that are expected to be collected.
-   *        Note that if more documents are collected, unexpected exceptions may
-   *        be thrown. Usually you should pass {@link IndexReader#maxDoc()} of
-   *        the same IndexReader with which the search is executed.
-   * @param enableScoring if scoring is enabled, a score will be computed for
-   *        every matching document, which might be expensive. Therefore if you
-   *        do not require scoring, it is better to set it to <i>false</i>.
-   */
-  public static ScoredDocIdCollector create(int maxDoc, boolean enableScoring) {
-    return enableScoring   ? new ScoringDocIdCollector(maxDoc)
-                          : new NonScoringDocIdCollector(maxDoc);
-  }
-
-  private ScoredDocIdCollector(int maxDoc) {
-    numDocIds = 0;
-    docIds = new OpenBitSet(maxDoc);
-  }
-
-  /** Returns the default score used when scoring is disabled. */
-  public abstract float getDefaultScore();
-
-  /** Set the default score. Only applicable if scoring is disabled. */
-  public abstract void setDefaultScore(float defaultScore);
-
-  public abstract ScoredDocIDsIterator scoredDocIdsIterator() throws IOException;
-
-  public ScoredDocIDs getScoredDocIDs() {
-    return new ScoredDocIDs() {
-
-      public ScoredDocIDsIterator iterator() throws IOException {
-        return scoredDocIdsIterator();
-      }
-
-      public DocIdSet getDocIDs() {
-        return docIds;
-      }
-
-      public int size() {
-        return numDocIds;
-      }
-
-    };
-  }
-
-  @Override
-  public void setNextReader(IndexReader reader, int base) throws IOException {
-    this.docBase = base;
-  }
-
-}