/**
* Copyright © 2012 Akiban Technologies, Inc. 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
*
* This program may also be available under different license terms.
* For more information, see www.akiban.com or contact
* licensing@akiban.com.
*
* Contributors:
* Akiban Technologies, Inc.
*/
package com.akiban.sql.parser;
import com.akiban.sql.StandardException;
/**
* An IndexColumn is the element of an index definition.
*/
public class IndexColumn extends QueryTreeNode
{
private TableName tableName;
private String columnName;
private boolean ascending = true;
/**
* Initializer.
*
* @param columnName Name of the column
* @param ascending Whether index is ascending
*/
public void init(Object columnName,
Object ascending) {
this.tableName = null;
this.columnName = (String)columnName;
this.ascending = ((Boolean)ascending).booleanValue();
}
/**
* Initializer.
*
* @param tableName Table holding indexed column
* @param columnName Name of the column
* @param ascending Whether index is ascending
*/
public void init(Object tableName,
Object columnName,
Object ascending) {
this.tableName = (TableName)tableName;
this.columnName = (String)columnName;
this.ascending = ((Boolean)ascending).booleanValue();
}
/**
* Fill this node with a deep copy of the given node.
*/
public void copyFrom(QueryTreeNode node) throws StandardException {
super.copyFrom(node);
IndexColumn other = (IndexColumn)node;
this.tableName = (TableName)getNodeFactory().copyNode(other.tableName,
getParserContext());
this.columnName = other.columnName;
this.ascending = other.ascending;
}
/**
* 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 "columnName: " + columnName + "\n" +
"tableName: " + ((tableName != null) ? tableName.toString() : "null") + "\n" +
(ascending ? "ascending" : "descending") + "\n" +
super.toString();
}
public TableName getTableName() {
return tableName;
}
public String getColumnName() {
return columnName;
}
public boolean isPartOfGroupIndex() {
return tableName != null;
}
/**
* @return true if ascending, false if descending
*/
public boolean isAscending() {
return ascending;
}
}