jjzjj

LibTooling

全部标签

c++ - 铛 libTooling : How to find which header an AST item came out of?

在网上找到的clang工具示例总是在玩具示例上运行,这些示例通常都是非常简单的C程序。我正在构建一个对C++代码执行源到源转换的工具,这显然是一项非常非常具有挑战性的任务,但clang可以胜任这项任务。我现在面临的问题是,clang为任何使用STL的C++代码生成的AST非常庞大。例如,我有一些C++代码,clang++-ast-dump...|wc-l是67,018行可怕的AST官话!其中99%是标准库的东西,我打算在我的源到源元编程任务中忽略它们。所以,为了实现这一点,我想简单地过滤掉文件。假设我只想查看正在分析的项目header中的类定义(并忽略所有标准库header的内容),我

c++ - 使用 libtooling 获取完全限定的模板模板参数名称

我正在尝试使用libtooling打印CXXRecordDecl具有模板模板参数的模板类的实例化。不幸的是,模板模板参数的字符串表示不完全限定(例如,它缺少namespace)。我正在打印CXXRecordDecl使用此代码:clang::PrintingPolicypolicy=compiler_instance->getLangOpts();std::stringname=decl->getTypeForDecl()->getCanonicalTypeInternal().getAsString(policy);这是一个我希望输出为ns::A的示例,但我得到ns::A:namesp

c++ - 即时编译 C++ : clang/libtooling fails to set Triple for LLVM IR

假设我想即时编译一个C++字符串:llvm::LLVMContextcontext;std::unique_ptraction=std::make_unique(&context);clang::tooling::runToolOnCode/*WithArgs*/(action.get(),"intfoo(intx){return++x;}");std::unique_ptrmodule=action->takeModule();不幸的是,当LLVM尝试转换IR时,似乎有一个异常表明Triple未设置(https://clang.llvm.org/docs/CrossCompilati

c++ - 从 clang 中的 FunctionDecl 类获取参数信息

如何从clang中的FunctionDecl类获取参数信息作为字符串。我正在尝试,但对这么多的继承感到困惑。他们的编译器还说getReturnType()不是FunctionDecl的成员,但doxygen文档另有说明。请帮忙。http://clang.llvm.org/doxygen/classclang_1_1FunctionDecl.htmlusingnamespacestd;usingnamespaceclang;usingnamespaceclang::driver;usingnamespaceclang::tooling;usingnamespacellvm;.......

c++ - clang:自定义属性在 AST 中不可见

我按照官方手册中的描述在clang中实现了一个自定义属性:http://clang.llvm.org/docs/InternalsManual.html#how-to-add-an-attribute所以我在Attr.td中添加了以下代码:defMyAttr:InheritableAttr{letSpellings=[GNU,CXX11,GCC,Declspec];letSubjects=SubjectList;letDocumentation=[MyAttrDocs];}以及AttrDocs.td的文档。重建clang后,它显然知道该属性,因为我在使用它时没有收到未知属性警告。我什至

c++ - 使用 Clang 的 libtooling 匹配#includes(或#defines)的正确方法是什么?

我正在编写一个libtooling重构工具。我有一个类,比方说Foo,定义在名为foo.h的header中。我想看看foo.h是否包含在文件中。目前,为了检查bar.cc是否包含foo.h,我只是使用recordDecl(hasName("Foo"))进行匹配。这是有效的,因为classFoo{...};将在预处理后存在于bar.cc的AST中,如果bar.cc包含foo.h.但是,如果bar.cc包含cat.h,而cat.h包含foo.h,则此方法无效。我希望bar.cc明确包含foo.h。此外,我希望能够匹配#define宏。我编写工具的方式使这两个目标变得不可能,因为我匹配的AS

c++ - 如何通过 Clang 和 LibTooling 使用标准库

我想使用Clang和LibTooling来创建一些C++源代码分析和转换工具。我在this之后构建了Clang和LibTooling教程,我已经能够运行和创建一些分析工具,并使用我构建的Clang二进制文件编译C++程序。但是,如果我包含标准库中的头文件(在源文件或我的工具中),我会在编译或运行源文件/工具时遇到问题。例如,如果我对以下C++源文件运行clang-check:#includeintmain(){std::cout我收到“fatalerror:找不到‘iostream’文件”。(注意:我可以编译C++程序,例如带有用户定义类的程序,但不能编译使用标准库的C++程序。)为了