ObjectCreationContext.java
/*
* Copyright (C) 2015-2016 Federico Tomassetti
* Copyright (C) 2017-2024 The JavaParser Team.
*
* This file is part of JavaParser.
*
* JavaParser can be used either under the terms of
* a) the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
* b) the terms of the Apache License
*
* You should have received a copy of both licenses in LICENCE.LGPL and
* LICENCE.APACHE. Please refer to those files for details.
*
* JavaParser is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*/
package com.github.javaparser.symbolsolver.javaparsermodel.contexts;
import static com.github.javaparser.resolution.Navigator.demandParentNode;
import com.github.javaparser.ast.Node;
import com.github.javaparser.ast.expr.Expression;
import com.github.javaparser.ast.expr.ObjectCreationExpr;
import com.github.javaparser.resolution.TypeSolver;
import com.github.javaparser.resolution.declarations.ResolvedMethodDeclaration;
import com.github.javaparser.resolution.declarations.ResolvedReferenceTypeDeclaration;
import com.github.javaparser.resolution.declarations.ResolvedTypeDeclaration;
import com.github.javaparser.resolution.model.SymbolReference;
import com.github.javaparser.resolution.types.ResolvedType;
import com.github.javaparser.symbolsolver.javaparsermodel.JavaParserFacade;
import com.github.javaparser.symbolsolver.javaparsermodel.JavaParserFactory;
import java.util.List;
/**
* @author Federico Tomassetti
*/
public class ObjectCreationContext extends ExpressionContext<ObjectCreationExpr> {
public ObjectCreationContext(ObjectCreationExpr wrappedNode, TypeSolver typeSolver) {
super(wrappedNode, typeSolver);
}
@Override
public SymbolReference<ResolvedTypeDeclaration> solveType(String name, List<ResolvedType> typeArguments) {
if (wrappedNode.hasScope()) {
Expression scope = wrappedNode.getScope().get();
ResolvedType scopeType = JavaParserFacade.get(typeSolver).getType(scope);
// Be careful, the scope can be an object creation expression like <code>new inner().new Other()</code>
if (scopeType.isReferenceType()
&& scopeType.asReferenceType().getTypeDeclaration().isPresent()) {
ResolvedReferenceTypeDeclaration scopeTypeDeclaration =
scopeType.asReferenceType().getTypeDeclaration().get();
for (ResolvedTypeDeclaration it : scopeTypeDeclaration.internalTypes()) {
if (it.getName().equals(name)) {
return SymbolReference.solved(it);
}
}
}
}
// find first parent node that is not an object creation expression to avoid stack overflow errors, see #1711
Node parentNode = demandParentNode(wrappedNode);
while (parentNode instanceof ObjectCreationExpr) {
parentNode = demandParentNode(parentNode);
}
return JavaParserFactory.getContext(parentNode, typeSolver).solveType(name, typeArguments);
}
@Override
public SymbolReference<ResolvedMethodDeclaration> solveMethod(
String name, List<ResolvedType> argumentsTypes, boolean staticOnly) {
return JavaParserFactory.getContext(demandParentNode(wrappedNode), typeSolver)
.solveMethod(name, argumentsTypes, false);
}
}