aboutsummaryrefslogtreecommitdiffstats
path: root/javaparser-symbol-solver-testing/src/test/resources/javasymbolsolver_0_6_0/src/java-symbol-solver-core/com/github/javaparser/symbolsolver/javaparsermodel/declarations/JavaParserTypeAdapter.java
diff options
context:
space:
mode:
Diffstat (limited to 'javaparser-symbol-solver-testing/src/test/resources/javasymbolsolver_0_6_0/src/java-symbol-solver-core/com/github/javaparser/symbolsolver/javaparsermodel/declarations/JavaParserTypeAdapter.java')
-rw-r--r--javaparser-symbol-solver-testing/src/test/resources/javasymbolsolver_0_6_0/src/java-symbol-solver-core/com/github/javaparser/symbolsolver/javaparsermodel/declarations/JavaParserTypeAdapter.java120
1 files changed, 0 insertions, 120 deletions
diff --git a/javaparser-symbol-solver-testing/src/test/resources/javasymbolsolver_0_6_0/src/java-symbol-solver-core/com/github/javaparser/symbolsolver/javaparsermodel/declarations/JavaParserTypeAdapter.java b/javaparser-symbol-solver-testing/src/test/resources/javasymbolsolver_0_6_0/src/java-symbol-solver-core/com/github/javaparser/symbolsolver/javaparsermodel/declarations/JavaParserTypeAdapter.java
deleted file mode 100644
index 97d1ab67c..000000000
--- a/javaparser-symbol-solver-testing/src/test/resources/javasymbolsolver_0_6_0/src/java-symbol-solver-core/com/github/javaparser/symbolsolver/javaparsermodel/declarations/JavaParserTypeAdapter.java
+++ /dev/null
@@ -1,120 +0,0 @@
-package com.github.javaparser.symbolsolver.javaparsermodel.declarations;
-
-import com.github.javaparser.ast.Node;
-import com.github.javaparser.ast.body.BodyDeclaration;
-import com.github.javaparser.ast.body.ClassOrInterfaceDeclaration;
-import com.github.javaparser.ast.body.EnumDeclaration;
-import com.github.javaparser.ast.nodeTypes.NodeWithMembers;
-import com.github.javaparser.ast.nodeTypes.NodeWithSimpleName;
-import com.github.javaparser.ast.nodeTypes.NodeWithTypeParameters;
-import com.github.javaparser.symbolsolver.javaparsermodel.JavaParserFactory;
-import com.github.javaparser.symbolsolver.model.declarations.ReferenceTypeDeclaration;
-import com.github.javaparser.symbolsolver.model.declarations.TypeDeclaration;
-import com.github.javaparser.symbolsolver.model.resolution.SymbolReference;
-import com.github.javaparser.symbolsolver.model.resolution.TypeSolver;
-import com.github.javaparser.symbolsolver.model.typesystem.ReferenceType;
-import com.github.javaparser.symbolsolver.model.typesystem.ReferenceTypeImpl;
-import com.github.javaparser.symbolsolver.model.typesystem.Type;
-import com.github.javaparser.symbolsolver.resolution.SymbolSolver;
-
-import java.util.List;
-import java.util.Optional;
-
-import static com.github.javaparser.symbolsolver.javaparser.Navigator.getParentNode;
-
-/**
- * @author Federico Tomassetti
- */
-public class JavaParserTypeAdapter<T extends Node & NodeWithSimpleName<T> & NodeWithMembers<T> & NodeWithTypeParameters<T>> {
-
- private T wrappedNode;
- private TypeSolver typeSolver;
-
- public JavaParserTypeAdapter(T wrappedNode, TypeSolver typeSolver) {
- this.wrappedNode = wrappedNode;
- this.typeSolver = typeSolver;
- }
-
- public String getPackageName() {
- return Helper.getPackageName(wrappedNode);
- }
-
- public String getClassName() {
- return Helper.getClassName("", wrappedNode);
- }
-
- public String getQualifiedName() {
- String containerName = Helper.containerName(getParentNode(wrappedNode));
- if (containerName.isEmpty()) {
- return wrappedNode.getName().getId();
- } else {
- return containerName + "." + wrappedNode.getName().getId();
- }
- }
-
- public boolean isAssignableBy(ReferenceTypeDeclaration other) {
- List<ReferenceType> ancestorsOfOther = other.getAllAncestors();
- ancestorsOfOther.add(new ReferenceTypeImpl(other, typeSolver));
- for (ReferenceType ancestorOfOther : ancestorsOfOther) {
- if (ancestorOfOther.getQualifiedName().equals(this.getQualifiedName())) {
- return true;
- }
- }
- return false;
- }
-
- public boolean isAssignableBy(Type type) {
- if (type.isNull()) {
- return true;
- }
- if (type.isReferenceType()) {
- ReferenceTypeDeclaration other = typeSolver.solveType(type.describe());
- return isAssignableBy(other);
- } else {
- throw new UnsupportedOperationException();
- }
- }
-
- public SymbolReference<TypeDeclaration> solveType(String name, TypeSolver typeSolver) {
- if (this.wrappedNode.getTypeParameters() != null) {
- for (com.github.javaparser.ast.type.TypeParameter typeParameter : this.wrappedNode.getTypeParameters()) {
- if (typeParameter.getName().getId().equals(name)) {
- return SymbolReference.solved(new JavaParserTypeVariableDeclaration(typeParameter, typeSolver));
- }
- }
- }
-
- // Internal classes
- for (BodyDeclaration<?> member : this.wrappedNode.getMembers()) {
- if (member instanceof com.github.javaparser.ast.body.TypeDeclaration) {
- com.github.javaparser.ast.body.TypeDeclaration<?> internalType = (com.github.javaparser.ast.body.TypeDeclaration<?>) member;
- String prefix = internalType.getName() + ".";
- if (internalType.getName().getId().equals(name)) {
- if (internalType instanceof ClassOrInterfaceDeclaration) {
- return SymbolReference.solved(new JavaParserClassDeclaration((com.github.javaparser.ast.body.ClassOrInterfaceDeclaration) internalType, typeSolver));
- } else if (internalType instanceof EnumDeclaration) {
- return SymbolReference.solved(new JavaParserEnumDeclaration((com.github.javaparser.ast.body.EnumDeclaration) internalType, typeSolver));
- } else {
- throw new UnsupportedOperationException();
- }
- } else if (name.startsWith(prefix) && name.length() > prefix.length()) {
- if (internalType instanceof ClassOrInterfaceDeclaration) {
- return new JavaParserClassDeclaration((com.github.javaparser.ast.body.ClassOrInterfaceDeclaration) internalType, typeSolver).solveType(name.substring(prefix.length()), typeSolver);
- } else if (internalType instanceof EnumDeclaration) {
- return new SymbolSolver(typeSolver).solveTypeInType(new JavaParserEnumDeclaration((com.github.javaparser.ast.body.EnumDeclaration) internalType, typeSolver), name.substring(prefix.length()));
- } else {
- throw new UnsupportedOperationException();
- }
- }
- }
- }
- return SymbolReference.unsolved(TypeDeclaration.class);
- }
-
- public Optional<ReferenceTypeDeclaration> containerType() {
- Optional<Node> parent = wrappedNode.getParentNode();
- return parent.isPresent() ?
- Optional.of(JavaParserFactory.toTypeDeclaration(parent.get(), typeSolver)) :
- Optional.empty();
- }
-}