我从Eclipse wiki(http://wiki.eclipse.org/JDT/FAQ#From_an_IJavaElement_to_its_declaring_ASTNode)中读到了这篇文章,但我仍然无法从IMethod转换为相应的MethodDeclaration。
我有一个扩展点,可以为IMethod对象添加一个弹出菜单。拥有这个IMethod对象,我想用ASTVisitor访问它。
以下是我尝试从IMethod转换为MethodDeclaration
的方式public static MethodDeclaration convertToAstNode(final IMethod method) throws JavaModelException
{
final ICompilationUnit compilationUnit = method.getCompilationUnit();
final ASTParser astParser = ASTParser.newParser( AST.JLS4 );
astParser.setSource( compilationUnit );
astParser.setKind( ASTParser.K_COMPILATION_UNIT );
astParser.setResolveBindings( true );
astParser.setBindingsRecovery( true );
final ASTNode rootNode = astParser.createAST( null );
final CompilationUnit compilationUnitNode = (CompilationUnit) rootNode;
final String key = method.getKey();
final ASTNode javaElement = compilationUnitNode.findDeclaringNode( key );
final MethodDeclaration methodDeclarationNode = (MethodDeclaration) javaElement;
return methodDeclarationNode;
}
我错过了什么?
答案 0 :(得分:1)
我意识到这个问题现在已经很老了,但我想发布这个解决方案,以防未来的Google员工偶然发现它:)
workaround EijiAdachi在评论中发布工作,但我在搜索解决方案时发现了一种更“正确”的方法。
为了让ASTNode正确解析绑定,页面内容需要先完全解析。这是通过(有点奇怪的名称恕我直言)ASTNode.accept(ASTVisitor)
方法完成的。因此,如果您继承ASTVisitor,则可以覆盖所关注的所有ASTNode类型的访问方法,并将它们添加到AST完全解析后可获得的数据结构中。
此示例将使您可以访问CompilationUnit根节点中的所有MethodDeclaration节点(有关如何通过ASTParser类获取该节点,请参阅OP):
public class MethodVisitor extends ASTVisitor {
private final List <MethodDeclaration> methods = new ArrayList <> ();
@Override
public boolean visit (final MethodDeclaration method) {
methods.add (method);
return super.visit (method);
}
/**
* @return an immutable list view of the methods discovered by this visitor
*/
public List <MethodDeclaration> getMethods () {
return Collections.unmodifiableList (methods);
}
}
任何其他ASTNode子类型都可以使用完全相同的过程进行舍入(您可以创建单独的访问者类型或将其全部放在一起)。
如果有人有兴趣,您可以在this tutorial article中查找更完整的示例。