我有一个基于 clang 的小工具,它创建一个编译器实例,并且能够解析 C 头文件。该工具在 clang 3.4 和 3.5 上运行良好。
我首先创建了一个编译器实例,并将其与从 ASTConsumer 创建的新类一起使用:
ci = new clang::CompilerInstance()
ci.createDiagnostics();
ci.createFileManager();
ci.createSourceManager(ci.getFileManager());
std::shared_ptr<clang::TargetOptions> pto = std::make_shared<clang::TargetOptions>();
pto->Triple = llvm::sys::getDefaultTargetTriple();
clang::TargetInfo *pti = clang::TargetInfo::CreateTargetInfo(m_ci.getDiagnostics(), pto);
ci.setTarget(pti);
ci.createPreprocessor(clang::TU_Complete);
...
//add source file and the headers paths
...
MyASTConsumer * myASTConsumerClassInstance = new MyASTConsumer;
ci.setASTConsumer(myASTConsumerClassInstance);
...
//parse the header file
其中 myASTConsumerClassInstance 是我像这样创建的类的实例(简化形式):
class MyASTConsumer : public clang::ASTConsumer
{
MyASTConsumer()
~MyASTConsumer() {};
virtual bool HandleTopLevelDecl( clang::DeclGroupRef d);
virtual void HandleTagDeclDefinition( clang::TagDecl * d);
private:
std::vector<clang::TagDecl *> m_my_tags;
}
在 HandleTagDeclDefinition
方法,所有在 vector m_my_tags
中注册的标签声明。因此,在解析过程之后,我能够从 myASTConsumerInstance 访问所有标记声明。
现在在 clang 3.6 api 中,方法 clang::CompilerInstance::setASTConsumer
需要 std::unique_ptr<ASTConsumer>
。如何调整我的代码?
最佳答案
事实上替换它很容易
MyASTConsumer * myASTConsumerClassInstance = new MyASTConsumer;
ci.setASTConsumer(myASTConsumerClassInstance);
与:
ci.setASTConsumer(llvm::make_unique<MyASTConsumer>());
或:
MyASTConsumer * myASTConsumerClassInstance = new MyASTConsumer;
ci.setASTConsumer(llvm::make_unique<clang::ASTConsumer>(*myASTConsumerClassInstance));
关于c++ - 如何将 Compiler 实例和 ASTConsumer 与 clang 3.6 一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29411052/