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

com.redhat.lightblue.assoc.QueryPlanIterator Maven / Gradle / Ivy

There is a newer version: 2.18.0
Show newest version
/*
 Copyright 2013 Red Hat, Inc. and/or its affiliates.

 This file is part of lightblue.

 This program is free software: you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
 the Free Software Foundation, either version 3 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 General Public License for more details.

 You should have received a copy of the GNU General Public License
 along with this program.  If not, see .
 */
package com.redhat.lightblue.assoc;

/**
 * Iterates over possible query plans by rearranging the query plan graph.
 *
 * The given query plan is taken as an initial state. Every successive call to
 * next will modify the query plan into a unique tree. Once all
 * possible query plans are iterated, next returns false.
 */
public interface QueryPlanIterator {

    /**
     * Resets the query plan iterator with the given copy of the query plan. The
     * query iterator must assume that this given query plan is in its initial
     * state, and should iterate through different query plans, modifying the
     * given copy.
     */
    void reset(QueryPlan p);

    /**
     * Modifies the query plan into a unique tree.
     *
     * @return If true, tne query plan is configured into a unique tree. If
     * false, query plan is now returned back to its original state during
     * iterator construction, and the iteration is expected to stop.
     */
    public boolean next();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy