Package org.exist.indexing.lucene

Source Code of org.exist.indexing.lucene.QueryDocuments$DocumentHitCollector

/*
*  eXist Open Source Native XML Database
*  Copyright (C) 2013 The eXist Project
*  http://exist-db.org
*
*  This program is free software; you can redistribute it and/or
*  modify it under the terms of the GNU Lesser General Public License
*  as published by the Free Software Foundation; either version 2
*  of the License, or (at your option) any later version.
*
*  This program is distributed in the hope that it will be useful,
*  but WITHOUT ANY WARRANTY; without even the implied warranty of
*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
*  GNU Lesser General Public License for more details.
*
*  You should have received a copy of the GNU Lesser General Public
*  License along with this library; if not, write to the Free Software
*  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
*
*  $Id$
*/
package org.exist.indexing.lucene;

import java.io.IOException;
import java.util.List;
import java.util.Properties;

import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.facet.params.FacetSearchParams;
import org.apache.lucene.facet.search.FacetResult;
import org.apache.lucene.facet.taxonomy.TaxonomyReader;
import org.apache.lucene.queryparser.classic.ParseException;
import org.apache.lucene.queryparser.classic.QueryParser;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.util.ArrayUtil;
import org.exist.Database;
import org.exist.dom.DocumentImpl;
import org.exist.dom.DocumentSet;
import org.exist.dom.QName;
import org.exist.storage.DBBroker;
import org.exist.xquery.TerminatedException;

/**
* @author <a href="mailto:shabanovd@gmail.com">Dmitriy Shabanov</a>
*
*/
public class QueryDocuments {

    public static List<FacetResult> query(LuceneIndexWorker worker, DocumentSet docs,
            Query query, FacetSearchParams searchParams,
            SearchCallback<DocumentImpl> callback)
                    throws IOException, ParseException, TerminatedException {

        final LuceneIndex index = worker.index;

        IndexSearcher searcher = null;
        try {
            searcher = index.getSearcher();
            final TaxonomyReader taxonomyReader = index.getTaxonomyReader();

            DocumentHitCollector collector = new DocumentHitCollector(docs, callback, searchParams, taxonomyReader);

            searcher.search(query, collector);
           
            return collector.getFacetResults();
        } finally {
            index.releaseSearcher(searcher);
        }
    }

    public static List<FacetResult> query(LuceneIndexWorker worker, DocumentSet docs,
            List<QName> qnames, String queryStr, FacetSearchParams searchParams, Properties options,
            SearchCallback<DocumentImpl> callback) throws IOException, ParseException,
            TerminatedException {

        qnames = worker.getDefinedIndexes(qnames);

        final LuceneIndex index = worker.index;

        final Database db = index.getBrokerPool();
       
        DBBroker broker = db.getActiveBroker();
       
        IndexSearcher searcher = null;
        try {
            searcher = index.getSearcher();
            final TaxonomyReader taxonomyReader = index.getTaxonomyReader();

            DocumentHitCollector collector = new DocumentHitCollector(docs, callback, searchParams, taxonomyReader);

            for (QName qname : qnames) {

                String field = LuceneUtil.encodeQName(qname, db.getSymbols());

                Analyzer analyzer = worker.getAnalyzer(null, qname, broker, docs);

                QueryParser parser = new QueryParser(LuceneIndex.LUCENE_VERSION_IN_USE, field, analyzer);

                worker.setOptions(options, parser);

                Query query = parser.parse(queryStr);

                searcher.search(query, collector);
            }
           
            return collector.getFacetResults();
        } finally {
            index.releaseSearcher(searcher);
        }
    }
   
    private static class DocumentHitCollector extends QueryFacetCollector {

        private final SearchCallback<DocumentImpl> callback;

        private DocumentHitCollector(
                final DocumentSet docs,
                final SearchCallback<DocumentImpl> callback,
               
                final FacetSearchParams searchParams,

                final TaxonomyReader taxonomyReader) {
           
            super(docs, searchParams, taxonomyReader);
           
            this.callback = callback;
        }

        @Override
        public void collect(int doc) {
            try {
                float score = scorer.score();
                int docId = (int) this.docIdValues.get(doc);
               
                if (docbits.contains(docId)) {
                    return;
                }

                DocumentImpl storedDocument = docs.getDoc(docId);
                if (storedDocument == null)
                    return;
               
                docbits.add(storedDocument);

                bits.set(doc);
                if (totalHits >= scores.length) {
                    float[] newScores = new float[ArrayUtil.oversize(
                            totalHits + 1, 4)];
                    System.arraycopy(scores, 0, newScores, 0, totalHits);
                    scores = newScores;
                }
                scores[totalHits] = score;
                totalHits++;

                // XXX: understand: check permissions here? No, it may slowdown, better to check final set

                callback.found(storedDocument, score);

            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}
TOP

Related Classes of org.exist.indexing.lucene.QueryDocuments$DocumentHitCollector

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.