com.googlecode.paradox.parser.nodes.AbstractConditionalNode Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of paradoxdriver Show documentation
Show all versions of paradoxdriver Show documentation
A Paradox Java Driver (using JDBC 4)
The newest version!
/*
* Copyright (c) 2009 Leonardo Alves da Costa
*
* 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.googlecode.paradox.parser.nodes;
import com.googlecode.paradox.parser.ScannerPosition;
import com.googlecode.paradox.planner.FieldValueUtils;
import com.googlecode.paradox.planner.context.Context;
import com.googlecode.paradox.planner.nodes.FieldNode;
import com.googlecode.paradox.planner.nodes.PlanTableNode;
import com.googlecode.paradox.results.Column;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
/**
* Stores a abstract comparable node.
*
* @since 1.1
*/
public abstract class AbstractConditionalNode extends SQLNode {
/**
* Node childhood.
*/
protected final List children = new ArrayList<>();
/**
* The field node.
*/
protected final FieldNode field;
/**
* Creates a new instance.
*
* @param name the condition name.
* @param field the field node to compare.
* @param position the current Scanner position.
*/
protected AbstractConditionalNode(final String name, final FieldNode field, final ScannerPosition position) {
super(name, position);
this.field = field;
}
/**
* Creates a new instance.
*
* @param name the condition name.
* @param position the current Scanner position.
*/
protected AbstractConditionalNode(final String name, ScannerPosition position) {
this(name, null, position);
}
/**
* Evaluate the conditional.
*
* @param context the context to use.
* @param row the associated row.
* @param columnsLoaded the columns loaded to use.
* @return true
if the conditional expression is valid.
* @throws SQLException in case of failures.
*/
public abstract boolean evaluate(final Context context, final Object[] row, final List columnsLoaded) throws SQLException;
/**
* Sets the field indexes.
*
* @param columns The column list.
* @param tables the table to set.
* @throws SQLException in case of failures.
*/
public void setFieldIndexes(final List columns, final List tables) throws SQLException {
FieldValueUtils.setFieldIndex(field, columns, tables);
}
@Override
public Set getClauseFields() {
final Set set = super.getClauseFields();
if (field != null) {
set.addAll(field.getClauseFields());
}
return set;
}
/**
* Get the field.
*
* @return the field.
*/
public FieldNode getField() {
return field;
}
@Override
public String toString() {
return field.toString();
}
/**
* Add a child node.
*
* @param node the child node to add.
*/
public void addChild(final SQLNode node) {
this.children.add(node);
}
/**
* Gets the child list.
*
* @return the child list.
*/
public List getChildren() {
return children;
}
}