001 /*
002 // $Id: DimensionNode.java 229 2009-05-08 19:11:29Z jhyde $
003 // This software is subject to the terms of the Eclipse Public License v1.0
004 // Agreement, available at the following URL:
005 // http://www.eclipse.org/legal/epl-v10.html.
006 // Copyright (C) 2007-2008 Julian Hyde
007 // All Rights Reserved.
008 // You must accept the terms of that agreement to use this software.
009 */
010 package org.olap4j.mdx;
011
012 import org.olap4j.metadata.Dimension;
013 import org.olap4j.type.Type;
014 import org.olap4j.type.DimensionType;
015
016 /**
017 * Usage of a {@link org.olap4j.metadata.Dimension} as an expression in an MDX
018 * parse tree.
019 *
020 * @author jhyde
021 * @version $Id: DimensionNode.java 229 2009-05-08 19:11:29Z jhyde $
022 * @since Jun 4, 2007
023 */
024 public class DimensionNode implements ParseTreeNode {
025 private final ParseRegion region;
026 private final Dimension dimension;
027
028 /**
029 * Creates a DimensionNode.
030 *
031 * @param region Region of source code
032 * @param dimension Dimension which is used in the expression
033 */
034 public DimensionNode(
035 ParseRegion region,
036 Dimension dimension)
037 {
038 this.region = region;
039 this.dimension = dimension;
040 }
041
042 public ParseRegion getRegion() {
043 return region;
044 }
045
046 /**
047 * Returns the Dimension used in this expression.
048 *
049 * @return dimension used in this expression
050 */
051 public Dimension getDimension() {
052 return dimension;
053 }
054
055 public <T> T accept(ParseTreeVisitor<T> visitor) {
056 return visitor.visit(this);
057 }
058
059 public Type getType() {
060 return new DimensionType(dimension);
061 }
062
063 public void unparse(ParseTreeWriter writer) {
064 writer.getPrintWriter().print(dimension.getUniqueName());
065 }
066
067 public String toString() {
068 return dimension.getUniqueName();
069 }
070
071 public DimensionNode deepCopy() {
072 // DimensionNode is immutable
073 return this;
074 }
075 }
076
077 // End DimensionNode.java