All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.eclipse.jdt.astview.views.ASTViewContentProvider Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (c) 2000, 2017 IBM Corporation and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.jdt.astview.views;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.jdt.astview.ASTViewPlugin;
import org.eclipse.jface.viewers.ITreeContentProvider;
import org.eclipse.jface.viewers.Viewer;
import org.eclipse.jdt.core.dom.ASTNode;
import org.eclipse.jdt.core.dom.AbstractTypeDeclaration;
import org.eclipse.jdt.core.dom.Annotation;
import org.eclipse.jdt.core.dom.AnnotationTypeMemberDeclaration;
import org.eclipse.jdt.core.dom.AnonymousClassDeclaration;
import org.eclipse.jdt.core.dom.ClassInstanceCreation;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jdt.core.dom.ConstructorInvocation;
import org.eclipse.jdt.core.dom.EnumConstantDeclaration;
import org.eclipse.jdt.core.dom.Expression;
import org.eclipse.jdt.core.dom.FieldAccess;
import org.eclipse.jdt.core.dom.IAnnotationBinding;
import org.eclipse.jdt.core.dom.IBinding;
import org.eclipse.jdt.core.dom.IMethodBinding;
import org.eclipse.jdt.core.dom.ITypeBinding;
import org.eclipse.jdt.core.dom.IVariableBinding;
import org.eclipse.jdt.core.dom.ImportDeclaration;
import org.eclipse.jdt.core.dom.LambdaExpression;
import org.eclipse.jdt.core.dom.MemberRef;
import org.eclipse.jdt.core.dom.MemberValuePair;
import org.eclipse.jdt.core.dom.MethodDeclaration;
import org.eclipse.jdt.core.dom.MethodInvocation;
import org.eclipse.jdt.core.dom.MethodRef;
import org.eclipse.jdt.core.dom.MethodReference;
import org.eclipse.jdt.core.dom.ModuleDeclaration;
import org.eclipse.jdt.core.dom.Name;
import org.eclipse.jdt.core.dom.PackageDeclaration;
import org.eclipse.jdt.core.dom.StructuralPropertyDescriptor;
import org.eclipse.jdt.core.dom.SuperConstructorInvocation;
import org.eclipse.jdt.core.dom.SuperFieldAccess;
import org.eclipse.jdt.core.dom.SuperMethodInvocation;
import org.eclipse.jdt.core.dom.Type;
import org.eclipse.jdt.core.dom.TypeParameter;
import org.eclipse.jdt.core.dom.VariableDeclaration;
public class ASTViewContentProvider implements ITreeContentProvider {
@Override
public void inputChanged(Viewer v, Object oldInput, Object newInput) {
}
@Override
public void dispose() {
}
@Override
public Object[] getElements(Object parent) {
return getChildren(parent);
}
@Override
public Object getParent(Object child) {
if (child instanceof ASTNode) {
ASTNode node= (ASTNode) child;
ASTNode parent= node.getParent();
if (parent != null) {
StructuralPropertyDescriptor prop= node.getLocationInParent();
return new NodeProperty(parent, prop);
}
} else if (child instanceof ASTAttribute) {
return ((ASTAttribute) child).getParent();
}
return null;
}
@Override
public Object[] getChildren(Object parent) {
if (parent instanceof ASTAttribute) {
return ((ASTAttribute) parent).getChildren();
} else if (parent instanceof ASTNode) {
return getNodeChildren((ASTNode) parent);
}
return new Object[0];
}
private Object[] getNodeChildren(ASTNode node) {
ArrayList res= new ArrayList<>();
if (node instanceof Expression) {
Expression expression= (Expression) node;
ITypeBinding expressionTypeBinding= expression.resolveTypeBinding();
res.add(createExpressionTypeBinding(node, expressionTypeBinding));
// expressions:
if (expression instanceof Name) {
IBinding binding= ((Name) expression).resolveBinding();
if (binding != expressionTypeBinding)
res.add(createBinding(expression, binding));
} else if (expression instanceof MethodInvocation) {
MethodInvocation methodInvocation= (MethodInvocation) expression;
IMethodBinding binding= methodInvocation.resolveMethodBinding();
res.add(createBinding(expression, binding));
String inferred= String.valueOf(methodInvocation.isResolvedTypeInferredFromExpectedType());
res.add(new GeneralAttribute(expression, "ResolvedTypeInferredFromExpectedType", inferred)); //$NON-NLS-1$
} else if (expression instanceof SuperMethodInvocation) {
SuperMethodInvocation superMethodInvocation= (SuperMethodInvocation) expression;
IMethodBinding binding= superMethodInvocation.resolveMethodBinding();
res.add(createBinding(expression, binding));
String inferred= String.valueOf(superMethodInvocation.isResolvedTypeInferredFromExpectedType());
res.add(new GeneralAttribute(expression, "ResolvedTypeInferredFromExpectedType", inferred)); //$NON-NLS-1$
} else if (expression instanceof ClassInstanceCreation) {
ClassInstanceCreation classInstanceCreation= (ClassInstanceCreation) expression;
IMethodBinding binding= classInstanceCreation.resolveConstructorBinding();
res.add(createBinding(expression, binding));
String inferred= String.valueOf(classInstanceCreation.isResolvedTypeInferredFromExpectedType());
res.add(new GeneralAttribute(expression, "ResolvedTypeInferredFromExpectedType", inferred)); //$NON-NLS-1$
} else if (expression instanceof FieldAccess) {
IVariableBinding binding= ((FieldAccess) expression).resolveFieldBinding();
res.add(createBinding(expression, binding));
} else if (expression instanceof SuperFieldAccess) {
IVariableBinding binding= ((SuperFieldAccess) expression).resolveFieldBinding();
res.add(createBinding(expression, binding));
} else if (expression instanceof Annotation) {
IAnnotationBinding binding= ((Annotation) expression).resolveAnnotationBinding();
res.add(createBinding(expression, binding));
} else if (expression instanceof LambdaExpression) {
ASTAttribute bindingAttribute;
try {
IMethodBinding binding= ((LambdaExpression) expression).resolveMethodBinding();
bindingAttribute= createBinding(expression, binding);
} catch (RuntimeException e) {
bindingAttribute= new Error(res, ">binding: Error: " + e.getMessage(), e);
ASTViewPlugin.log("Exception thrown in LambdaExpression#resolveMethodBinding() for \"" + expression + "\"", e);
}
res.add(bindingAttribute);
} else if (expression instanceof MethodReference) {
IMethodBinding binding= ((MethodReference) expression).resolveMethodBinding();
res.add(createBinding(expression, binding));
}
// Expression attributes:
res.add(new GeneralAttribute(expression, "Boxing: " + expression.resolveBoxing() + "; Unboxing: " + expression.resolveUnboxing())); //$NON-NLS-1$ //$NON-NLS-2$
res.add(new GeneralAttribute(expression, "ConstantExpressionValue", expression.resolveConstantExpressionValue())); //$NON-NLS-1$
// references:
} else if (node instanceof ConstructorInvocation) {
IMethodBinding binding= ((ConstructorInvocation) node).resolveConstructorBinding();
res.add(createBinding(node, binding));
} else if (node instanceof SuperConstructorInvocation) {
IMethodBinding binding= ((SuperConstructorInvocation) node).resolveConstructorBinding();
res.add(createBinding(node, binding));
} else if (node instanceof MethodRef) {
IBinding binding= ((MethodRef) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof MemberRef) {
IBinding binding= ((MemberRef) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof Type) {
IBinding binding= ((Type) node).resolveBinding();
res.add(createBinding(node, binding));
// declarations:
} else if (node instanceof AbstractTypeDeclaration) {
IBinding binding= ((AbstractTypeDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof AnnotationTypeMemberDeclaration) {
IBinding binding= ((AnnotationTypeMemberDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof EnumConstantDeclaration) {
IBinding binding= ((EnumConstantDeclaration) node).resolveVariable();
res.add(createBinding(node, binding));
IBinding binding2= ((EnumConstantDeclaration) node).resolveConstructorBinding();
res.add(createBinding(node, binding2));
} else if (node instanceof MethodDeclaration) {
IBinding binding= ((MethodDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof VariableDeclaration) {
IBinding binding= ((VariableDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof AnonymousClassDeclaration) {
IBinding binding= ((AnonymousClassDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof ImportDeclaration) {
IBinding binding= ((ImportDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof PackageDeclaration) {
IBinding binding= ((PackageDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof TypeParameter) {
IBinding binding= ((TypeParameter) node).resolveBinding();
res.add(createBinding(node, binding));
} else if (node instanceof MemberValuePair) {
IBinding binding= ((MemberValuePair) node).resolveMemberValuePairBinding();
res.add(createBinding(node, binding));
} else if (node instanceof ModuleDeclaration) {
IBinding binding= ((ModuleDeclaration) node).resolveBinding();
res.add(createBinding(node, binding));
}
List list= node.structuralPropertiesForType();
for (StructuralPropertyDescriptor curr : list) {
res.add(new NodeProperty(node, curr));
}
if (node instanceof CompilationUnit) {
CompilationUnit root= (CompilationUnit) node;
res.add(new JavaElement(root, root.getJavaElement()));
res.add(new CommentsProperty(root));
res.add(new ProblemsProperty(root));
res.add(new SettingsProperty(root));
res.add(new WellKnownTypesProperty(root));
}
return res.toArray();
}
private Binding createBinding(ASTNode parent, IBinding binding) {
String label= Binding.getBindingLabel(binding);
return new Binding(parent, label, binding, true);
}
private Object createExpressionTypeBinding(ASTNode parent, ITypeBinding binding) {
String label= "> (Expression) type binding"; //$NON-NLS-1$
return new Binding(parent, label, binding, true);
}
@Override
public boolean hasChildren(Object parent) {
return getChildren(parent).length > 0;
}
}