/**
* Copyright 2011-2013 Akiban Technologies, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.akiban.sql.parser;
import com.akiban.sql.StandardException;
/**
* This node represents a COLLATE clause attached to an expression.
*
*/
public class ExplicitCollateNode extends ValueNode
{
private ValueNode operand;
private String collation;
/**
* Initializer for a ExplicitCollateNode
*
* @param operand The operand
* @param collation The explicit collation
*/
public void init(Object operand, Object collation) throws StandardException {
this.operand = (ValueNode)operand;
this.collation = (String)collation;
}
/**
* Fill this node with a deep copy of the given node.
*/
public void copyFrom(QueryTreeNode node) throws StandardException {
super.copyFrom(node);
ExplicitCollateNode other = (ExplicitCollateNode)node;
this.operand = (ValueNode)getNodeFactory().copyNode(other.operand,
getParserContext());
this.collation = other.collation;
}
/**
* Convert this object to a String. See comments in QueryTreeNode.java
* for how this should be done for tree printing.
*
* @return This object as a String
*/
public String toString() {
return "collation: " + collation + "\n" +
super.toString();
}
/**
* Prints the sub-nodes of this object. See QueryTreeNode.java for
* how tree printing is supposed to work.
*
* @param depth The depth of this node in the tree
*/
public void printSubNodes(int depth) {
super.printSubNodes(depth);
if (operand != null) {
printLabel(depth, "operand: ");
operand.treePrint(depth + 1);
}
}
/**
* Get the operand of this unary operator.
*
* @return The operand of this unary operator.
*/
public ValueNode getOperand() {
return operand;
}
public String getCollation() {
return collation;
}
/**
* Accept the visitor for all visitable children of this node.
*
* @param v the visitor
*
* @exception StandardException on error
*/
void acceptChildren(Visitor v) throws StandardException {
super.acceptChildren(v);
if (operand != null) {
operand = (ValueNode)operand.accept(v);
}
}
/**
* @throws StandardException
* {@inheritDoc}
*/
protected boolean isEquivalent(ValueNode o) throws StandardException {
if (isSameNodeType(o)) {
// the first condition in the || covers the case when
// both operands are null.
ExplicitCollateNode other = (ExplicitCollateNode)o;
return (collation.equals(other.collation) &&
((operand == other.operand)||
((operand != null) && operand.isEquivalent(other.operand))));
}
return false;
}
}