1 /*******************************************************************************
2 * Copyright (c) 2000, 2003 IBM Corporation and others.
3 * All rights reserved. This program and the accompanying materials
4 * are made available under the terms of the Common Public License v1.0
5 * which accompanies this distribution, and is available at
6 * http://www.eclipse.org/legal/cpl-v10.html
9 * IBM Corporation - initial API and implementation
10 *******************************************************************************/
11 package net.sourceforge.phpdt.internal.compiler.ast;
13 import net.sourceforge.phpdt.internal.compiler.IAbstractSyntaxTreeVisitor;
14 import net.sourceforge.phpdt.internal.compiler.lookup.BlockScope;
15 import net.sourceforge.phpdt.internal.compiler.lookup.ClassScope;
16 import net.sourceforge.phpdt.internal.compiler.lookup.Scope;
17 import net.sourceforge.phpdt.internal.compiler.lookup.TypeBinding;
19 public class ArrayQualifiedTypeReference extends QualifiedTypeReference {
22 public ArrayQualifiedTypeReference(char[][] sources, int dim, long[] poss) {
27 public ArrayQualifiedTypeReference(char[][] sources, TypeBinding tb,
28 int dim, long[] poss) {
29 super(sources, tb, poss);
33 public int dimensions() {
37 public TypeBinding getTypeBinding(Scope scope) {
38 if (this.resolvedType != null)
39 return this.resolvedType;
40 if (dimensions > 255) {
41 scope.problemReporter().tooManyDimensions(this);
43 return scope.createArray(scope.getType(tokens), dimensions);
46 public String toStringExpression(int tab) {
49 String s = super.toStringExpression(tab);
51 return s + "[]"; //$NON-NLS-1$
52 for (int i = 1; i <= dimensions; i++)
53 s = s + "[]"; //$NON-NLS-1$
57 public void traverse(IAbstractSyntaxTreeVisitor visitor, BlockScope scope) {
58 visitor.visit(this, scope);
59 visitor.endVisit(this, scope);
62 public void traverse(IAbstractSyntaxTreeVisitor visitor, ClassScope scope) {
63 visitor.visit(this, scope);
64 visitor.endVisit(this, scope);