gpt4 book ai didi

c++ - Clang AST - 是否可以只匹配子树?

转载 作者:行者123 更新时间:2023-11-28 01:48:14 26 4
gpt4 key购买 nike

我想找到一个名为“x”的变量,所以我定义了一个 DeclarationMatcher

DeclarationMatcher decmatch = varDecl().bind("id");

我还使用匹配器和 MatchCallBack 设置了 MatchFinder

 matcher.addMatcher(decmatch, &callback);

我用它来匹配给定的 AST

 matcher.matchAST(astcontext);

我想知道是否可以使用此匹配器仅在子树内部进行匹配,而不是在整个 AST 上进行匹配。例如,如果 a 有一个给定的 FunctionDecl 节点,我想使用匹配器只匹配这个节点下面的节点。我搜索了整个文档,找不到任何可以帮助我解决这个问题的东西。

最佳答案

我通过在 CompoundStmt 上使用 MatchFinder::match(node, astContext) 尝试了类似的事情。我的记忆是只检查了特定的节点,并且我添加了 forEachDescendant 来处理后代。我不记得它是否在整个子树中递归。

如果这对您不起作用,ASTMatchFinder.cpp 中的源代码应该会有帮助。 matchAST() 的源代码只有大约五行。我希望如果你写了一个重载,matchAST(ASTContext &Context, Decl * myNode),并替换了

Visitor.TraverseDecl(Context.getTranslationUnitDecl());

Visitor.TraverseDecl(myNode);

那会做你想做的事。

关于c++ - Clang AST - 是否可以只匹配子树?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44006739/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com