/PHP/Test/vendor/doctrine/orm/lib/Doctrine/ORM/Query/TreeWalker.php
PHP | 409 lines | 53 code | 49 blank | 307 comment | 0 complexity | c9fd2dda7a4fa2c0667fac319307bf5b MD5 | raw file
- <?php
- /*
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- * This software consists of voluntary contributions made by many individuals
- * and is licensed under the MIT license. For more information, see
- * <http://www.doctrine-project.org>.
- */
- namespace Doctrine\ORM\Query;
- /**
- * Interface for walkers of DQL ASTs (abstract syntax trees).
- *
- * @author Roman Borschel <roman@code-factory.org>
- * @since 2.0
- */
- interface TreeWalker
- {
- /**
- * Initializes TreeWalker with important information about the ASTs to be walked
- *
- * @param Query $query The parsed Query.
- * @param ParserResult $parserResult The result of the parsing process.
- * @param array $queryComponents Query components (symbol table)
- */
- public function __construct($query, $parserResult, array $queryComponents);
- /**
- * Walks down a SelectStatement AST node, thereby generating the appropriate SQL.
- *
- * @return string The SQL.
- */
- function walkSelectStatement(AST\SelectStatement $AST);
- /**
- * Walks down a SelectClause AST node, thereby generating the appropriate SQL.
- *
- * @return string The SQL.
- */
- function walkSelectClause($selectClause);
- /**
- * Walks down a FromClause AST node, thereby generating the appropriate SQL.
- *
- * @return string The SQL.
- */
- function walkFromClause($fromClause);
- /**
- * Walks down a FunctionNode AST node, thereby generating the appropriate SQL.
- *
- * @return string The SQL.
- */
- function walkFunction($function);
- /**
- * Walks down an OrderByClause AST node, thereby generating the appropriate SQL.
- *
- * @param OrderByClause
- * @return string The SQL.
- */
- function walkOrderByClause($orderByClause);
- /**
- * Walks down an OrderByItem AST node, thereby generating the appropriate SQL.
- *
- * @param OrderByItem
- * @return string The SQL.
- */
- function walkOrderByItem($orderByItem);
- /**
- * Walks down a HavingClause AST node, thereby generating the appropriate SQL.
- *
- * @param HavingClause
- * @return string The SQL.
- */
- function walkHavingClause($havingClause);
- /**
- * Walks down a Join AST node and creates the corresponding SQL.
- *
- * @param Join $joinVarDecl
- * @return string The SQL.
- */
- function walkJoin($join);
- /**
- * Walks down a SelectExpression AST node and generates the corresponding SQL.
- *
- * @param SelectExpression $selectExpression
- * @return string The SQL.
- */
- function walkSelectExpression($selectExpression);
- /**
- * Walks down a QuantifiedExpression AST node, thereby generating the appropriate SQL.
- *
- * @param QuantifiedExpression
- * @return string The SQL.
- */
- function walkQuantifiedExpression($qExpr);
- /**
- * Walks down a Subselect AST node, thereby generating the appropriate SQL.
- *
- * @param Subselect
- * @return string The SQL.
- */
- function walkSubselect($subselect);
- /**
- * Walks down a SubselectFromClause AST node, thereby generating the appropriate SQL.
- *
- * @param SubselectFromClause
- * @return string The SQL.
- */
- function walkSubselectFromClause($subselectFromClause);
- /**
- * Walks down a SimpleSelectClause AST node, thereby generating the appropriate SQL.
- *
- * @param SimpleSelectClause
- * @return string The SQL.
- */
- function walkSimpleSelectClause($simpleSelectClause);
- /**
- * Walks down a SimpleSelectExpression AST node, thereby generating the appropriate SQL.
- *
- * @param SimpleSelectExpression
- * @return string The SQL.
- */
- function walkSimpleSelectExpression($simpleSelectExpression);
- /**
- * Walks down an AggregateExpression AST node, thereby generating the appropriate SQL.
- *
- * @param AggregateExpression
- * @return string The SQL.
- */
- function walkAggregateExpression($aggExpression);
- /**
- * Walks down a GroupByClause AST node, thereby generating the appropriate SQL.
- *
- * @param GroupByClause
- * @return string The SQL.
- */
- function walkGroupByClause($groupByClause);
- /**
- * Walks down a GroupByItem AST node, thereby generating the appropriate SQL.
- *
- * @param GroupByItem
- * @return string The SQL.
- */
- function walkGroupByItem($groupByItem);
- /**
- * Walks down an UpdateStatement AST node, thereby generating the appropriate SQL.
- *
- * @param UpdateStatement
- * @return string The SQL.
- */
- function walkUpdateStatement(AST\UpdateStatement $AST);
- /**
- * Walks down a DeleteStatement AST node, thereby generating the appropriate SQL.
- *
- * @param DeleteStatement
- * @return string The SQL.
- */
- function walkDeleteStatement(AST\DeleteStatement $AST);
- /**
- * Walks down a DeleteClause AST node, thereby generating the appropriate SQL.
- *
- * @param DeleteClause
- * @return string The SQL.
- */
- function walkDeleteClause(AST\DeleteClause $deleteClause);
- /**
- * Walks down an UpdateClause AST node, thereby generating the appropriate SQL.
- *
- * @param UpdateClause
- * @return string The SQL.
- */
- function walkUpdateClause($updateClause);
- /**
- * Walks down an UpdateItem AST node, thereby generating the appropriate SQL.
- *
- * @param UpdateItem
- * @return string The SQL.
- */
- function walkUpdateItem($updateItem);
- /**
- * Walks down a WhereClause AST node, thereby generating the appropriate SQL.
- *
- * @param WhereClause
- * @return string The SQL.
- */
- function walkWhereClause($whereClause);
- /**
- * Walks down a ConditionalExpression AST node, thereby generating the appropriate SQL.
- *
- * @param ConditionalExpression
- * @return string The SQL.
- */
- function walkConditionalExpression($condExpr);
- /**
- * Walks down a ConditionalTerm AST node, thereby generating the appropriate SQL.
- *
- * @param ConditionalTerm
- * @return string The SQL.
- */
- function walkConditionalTerm($condTerm);
- /**
- * Walks down a ConditionalFactor AST node, thereby generating the appropriate SQL.
- *
- * @param ConditionalFactor
- * @return string The SQL.
- */
- function walkConditionalFactor($factor);
- /**
- * Walks down a ConditionalPrimary AST node, thereby generating the appropriate SQL.
- *
- * @param ConditionalPrimary
- * @return string The SQL.