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

src.it.unimi.dsi.big.mg4j.query.nodes.Query Maven / Gradle / Ivy

Go to download

MG4J (Managing Gigabytes for Java) is a free full-text search engine for large document collections written in Java. The big version is a fork of the original MG4J that can handle more than 2^31 terms and documents.

The newest version!
package it.unimi.dsi.big.mg4j.query.nodes;

import java.io.Serializable;

/*		 
 * MG4J: Managing Gigabytes for Java (big)
 *
 * Copyright (C) 2006-2011 Sebastiano Vigna 
 *
 *  This library 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 3 of the License, or (at your option)
 *  any later version.
 *
 *  This library 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 program; if not, see .
 *
 */

/** A node of a composite representing a query.
 * 
 * 

A query is abstractly represented by a composite made of implementations * of this interface. The syntax can be different from parser to * parser, but the {@linkplain it.unimi.dsi.big.mg4j.query.parser.QueryParser#parse(String) * result of the parsing process} is an instance of this class. * *

Queries support building visits: invoking {@link #accept(QueryBuilderVisitor)} on * a suitable {@link it.unimi.dsi.big.mg4j.query.nodes.QueryBuilderVisitor} will return an object * that has been built by the visitor. * *

To this purpose, the implementation of * {@link it.unimi.dsi.big.mg4j.query.nodes.Query#accept(QueryBuilderVisitor)} * on internal nodes must gather in an array (or in an element) * the results returned by the recursive calls to * {@link it.unimi.dsi.big.mg4j.query.nodes.Query#accept(QueryBuilderVisitor)} * on subnodes and pass the array (or the element) to the suitable visitPost() * method of {@link it.unimi.dsi.big.mg4j.query.nodes.QueryBuilderVisitor}. * *

Since allocating a generic array is impossible, every visitor must provide an explicit * {@link it.unimi.dsi.big.mg4j.query.nodes.QueryBuilderVisitor#newArray(int)} * method which returns an array of the correct type. * * @see Query * @author Sebastiano Vigna */ public interface Query extends Serializable { /** Accepts a visitor. * * @param visitor the visitor. * @return the result of the visit, or null if the visit should stop. * @see Query */ public T accept( QueryBuilderVisitor visitor ) throws QueryBuilderVisitorException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy