/*******************************************************************************
* Copyright (c) 2010 Bruno Medeiros and other Contributors.
* 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
*
* Contributors:
* Bruno Medeiros - initial API and implementation
*******************************************************************************/
package dtool.ast.expressions;
import static melnorme.utilbox.core.Assert.AssertNamespace.assertNotNull;
import melnorme.lang.tooling.ast.CommonASTNode;
import melnorme.lang.tooling.ast.IASTVisitor;
import melnorme.lang.tooling.ast.util.ASTCodePrinter;
import melnorme.lang.tooling.ast_actual.ASTNodeTypes;
import melnorme.lang.tooling.context.ISemanticContext;
import melnorme.lang.tooling.engine.PickedElement;
import melnorme.lang.tooling.engine.resolver.ExpSemantics;
import melnorme.lang.tooling.engine.resolver.ResolvableUtil;
import melnorme.lang.tooling.engine.resolver.TypeReferenceResult;
import melnorme.lang.tooling.symbols.INamedElement;
import dtool.ast.references.Reference;
public class ExpParentheses extends Expression {
public final boolean isDotAfterParensSyntax;
public final Resolvable resolvable;
public ExpParentheses(boolean isDotAfterParensSyntax, Resolvable resolvable) {
this.isDotAfterParensSyntax = isDotAfterParensSyntax;
this.resolvable = parentize(assertNotNull(resolvable));
}
@Override
public ASTNodeTypes getNodeType() {
return ASTNodeTypes.EXP_PARENTHESES;
}
@Override
public void visitChildren(IASTVisitor visitor) {
acceptVisitor(visitor, resolvable);
}
@Override
protected CommonASTNode doCloneTree() {
return new ExpParentheses(isDotAfterParensSyntax, clone(resolvable));
}
@Override
public void toStringAsCode(ASTCodePrinter cp) {
cp.append("(", resolvable, ")");
}
/* ----------------- ----------------- */
@Override
protected ExpSemantics doCreateSemantics(PickedElement<?> pickedElement) {
return new ExpSemantics(this, pickedElement) {
@Override
public TypeReferenceResult doCreateExpResolution() {
Resolvable parensExp = ExpParentheses.this.resolvable;
if(parensExp instanceof Reference) {
Reference refRoot = (Reference) parensExp;
return ResolvableUtil.resolveTypeOfExpressionReference(refRoot, context);
} else {
Expression expRoot = (Expression) parensExp;
return expRoot.resolveTypeOfUnderlyingValue_nonNull(context);
}
}
};
}
@Override
public INamedElement resolveAsQualifiedRefRoot(ISemanticContext context) {
if(resolvable instanceof Reference) {
Reference reference = (Reference) resolvable;
return reference.resolveTargetElement(context);
} else {
return super.resolveAsQualifiedRefRoot(context);
}
}
}