All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sindice.siren.solr.qparser.tabular.TabularQParser Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (c) 2009-2011 Sindice Limited. All Rights Reserved.
 *
 * Project and contact information: http://www.siren.sindice.com/
 *
 * This file is part of the SIREn project.
 *
 * SIREn is a free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of
 * the License, or (at your option) any later version.
 *
 * SIREn 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 Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public
 * License along with SIREn. If not, see .
 */
/**
 * @project siren-solr
 * @author Renaud Delbru [ 25 Jul 2010 ]
 * @link http://renaud.delbru.fr/
 * @copyright Copyright (C) 2010 by Renaud Delbru, All rights reserved.
 */
package org.sindice.siren.solr.qparser.tabular;

import java.util.Map;

import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.queryParser.ParseException;
import org.apache.lucene.queryParser.standard.config.DefaultOperatorAttribute;
import org.apache.lucene.search.Query;
import org.apache.lucene.util.Version;
import org.apache.solr.analysis.BaseTokenizerFactory;
import org.apache.solr.common.SolrException;
import org.apache.solr.common.params.SolrParams;
import org.apache.solr.request.SolrQueryRequest;
import org.sindice.siren.qparser.ntriple.NTripleQueryParser;
import org.sindice.siren.qparser.tabular.TabularQueryParser;
import org.sindice.siren.solr.SirenParams;
import org.sindice.siren.solr.analysis.TabularQueryTokenizerFactory;
import org.sindice.siren.solr.qparser.tuple.TupleQParser;

/**
 * The {@link TabularQParser} is in charge of executing a NTriple query request.
 * 

* Instantiate and execute the {@link NTripleQueryParser} based on the Solr * configuration and parameters. */ public class TabularQParser extends TupleQParser { /** * @param boosts * @param qstr * @param localParams * @param params * @param req */ public TabularQParser(Map boosts, String qstr, SolrParams localParams, SolrParams params, SolrQueryRequest req) { super(boosts, qstr, localParams, params, req); } @Override protected BaseTokenizerFactory getTupleTokenizerFactory() { return new TabularQueryTokenizerFactory(); } @Override protected void initTupleQueryFieldOperator(SolrParams solrParams) { String nqfo = null; if ((nqfo = solrParams.get(SirenParams.TQFO)) != null) { if (nqfo.equals("disjunction")) { scattered = false; } else if (nqfo.equals("scattered")) { scattered = true; } else { throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, "Invalid " + "TabularQParser operator"); } } } @Override protected Query parseTupleQuery(String qstr, Version matchVersion, String field, Analyzer tupleAnalyzer, Map datatypeConfig, DefaultOperatorAttribute.Operator op) throws ParseException { return TabularQueryParser.parse(qstr, matchVersion, field, tupleAnalyzer, datatypeConfig, op); } @Override protected Query parseTupleQuery(String qstr, Version matchVersion, Map boosts, Analyzer tupleAnalyzer, Map> datatypeConfigs, DefaultOperatorAttribute.Operator op) throws ParseException { return TabularQueryParser.parse(qstr, matchVersion, boosts, tupleAnalyzer, datatypeConfigs, op, scattered); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy