/*
* Copyright (c) 2006-2011 Nuxeo SA (http://nuxeo.com/) and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Florent Guillaume
*/
package org.eclipse.ecr.core.query.sql.model;
/**
* A default implementation of a visitor that visits depth-first in standard
* expression order.
*
* @author Florent Guillaume
*/
public class DefaultQueryVisitor implements IVisitor {
private static final long serialVersionUID = 1L;
@Override
public void visitQuery(SQLQuery node) {
node.select.accept(this);
node.from.accept(this);
if (node.where != null) {
node.where.accept(this);
}
if (node.orderBy != null) {
node.orderBy.accept(this);
}
if (node.groupBy != null) {
node.groupBy.accept(this);
}
if (node.having != null) {
node.having.accept(this);
}
}
@Override
public void visitSelectClause(SelectClause node) {
SelectList elements = node.elements;
for (int i = 0; i < elements.size(); i++) {
elements.get(i).accept(this);
}
}
@Override
public void visitFromClause(FromClause node) {
}
@Override
public void visitWhereClause(WhereClause node) {
node.predicate.accept(this);
}
@Override
public void visitGroupByClause(GroupByClause node) {
}
@Override
public void visitHavingClause(HavingClause node) {
if (node.predicate != null) {
node.predicate.accept(this);
}
}
@Override
public void visitOrderByClause(OrderByClause node) {
node.elements.accept(this);
}
@Override
public void visitOrderByList(OrderByList node) {
for (OrderByExpr aNode : node) {
aNode.accept(this);
}
}
@Override
public void visitOrderByExpr(OrderByExpr node) {
node.reference.accept(this);
}
@Override
public void visitExpression(Expression node) {
if (node.rvalue == null) {
if (node.isSuffix()) {
// IS NULL, IS NOT NULL
node.lvalue.accept(this);
node.operator.accept(this);
} else {
// NOT
node.operator.accept(this);
node.lvalue.accept(this);
}
} else {
node.lvalue.accept(this);
node.operator.accept(this);
node.rvalue.accept(this);
}
}
@Override
public void visitMultiExpression(MultiExpression node) {
for (Operand operand : node.values) {
operand.accept(this);
}
}
@Override
public void visitOperator(Operator node) {
}
@Override
public void visitReference(Reference node) {
}
@Override
public void visitReferenceList(ReferenceList node) {
for (Reference reference : node) {
reference.accept(this);
}
}
@Override
public void visitLiteral(Literal node) {
}
@Override
public void visitLiteralList(LiteralList node) {
for (Literal literal : node) {
literal.accept(this);
}
}
@Override
public void visitDateLiteral(DateLiteral node) {
visitLiteral(node);
}
@Override
public void visitStringLiteral(StringLiteral node) {
visitLiteral(node);
}
@Override
public void visitDoubleLiteral(DoubleLiteral node) {
visitLiteral(node);
}
@Override
public void visitIntegerLiteral(IntegerLiteral node) {
visitLiteral(node);
}
@Override
public void visitFunction(Function node) {
for (Operand operand : node.args) {
operand.accept(this);
}
}
@Override
public void visitOperandList(OperandList node) {
for (Operand operand : node) {
operand.accept(this);
}
}
}