/** * 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; } }