8

WindowsでClangをセットアップしようとしています。これまでのところ、私は Visual Studio と CMake を使用したビルドと、その他のいくつかの驚きに耐えてきました。しかし、Clang には独自の C++ stdlib 実装が付属していないことが判明したため、MinGW 用にビルドされた GCC 4.7.0 の libstdc++ を使用することにしました。

まず、検索パスを HeaderSearchOptions に追加しました。

headeropts->AddPath(path, clang::frontend::IncludeDirGroup::CXXSystem, true, false, false);

パスはまさにヘッダーが存在する場所です。Windows エクスプローラーから文字どおりコピーして貼り付けました (エスケープ用にバックスラッシュを 2 倍にしました)。<iostream>しかし、Clang は、という名前のファイルiostreamが正確に に存在するにもかかわらず、まだ見つからないと主張しますpath

Clang がヘッダーを見つけられないのはなぜですか? libstdc++ を使用するには他に何が必要ですか?

これが私のコードです

llvm::LLVMContext c;
llvm::Module m("", c);

clang::CompilerInstance ci;

clang::FileSystemOptions fso;

clang::FileManager fm(fso);

std::string errors;
llvm::raw_string_ostream error_stream(errors);
clang::DiagnosticOptions diagopts;
clang::TextDiagnosticPrinter printer(error_stream, &diagopts);
llvm::IntrusiveRefCntPtr<clang::DiagnosticIDs> diagids(new clang::DiagnosticIDs);
clang::DiagnosticsEngine engine(diagids, &diagopts, &printer, false);

clang::SourceManager sm(engine, fm);

clang::LangOptions langopts;
langopts.CPlusPlus = true;
langopts.CPlusPlus0x = true;

clang::TargetOptions target;
target.Triple = llvm::sys::getDefaultTargetTriple();
auto targetinfo = clang::TargetInfo::CreateTargetInfo(engine, &target);

auto headeropts = llvm::IntrusiveRefCntPtr<clang::HeaderSearchOptions>(new clang::HeaderSearchOptions());
headeropts->AddPath("D:\\Backups\\unsorted\\x86_64-w64-mingw32-gcc-4.7.0-release-win64_rubenvb\\mingw64\\include\\c++\\4.7.0",clang::frontend::IncludeDirGroup::CXXSystem, true, false, false);
headeropts->UseStandardCXXIncludes = true;
headeropts->UseStandardSystemIncludes = true;
clang::HeaderSearch hs(headeropts, fm, engine, langopts, targetinfo);

auto x = llvm::IntrusiveRefCntPtr<clang::PreprocessorOptions>(new clang::PreprocessorOptions());
clang::Preprocessor p(x, engine, langopts, targetinfo, sm, hs, ci);

clang::ASTContext astcon(langopts, sm, targetinfo, p.getIdentifierTable(), p.getSelectorTable(), p.getBuiltinInfo(), 1000);
CodeGenConsumer consumer;
clang::CodeGen::CodeGenModule codegen(astcon, clang::CodeGenOptions(), m, llvm::DataLayout(&m), engine);
consumer.mod = &codegen;
clang::Sema sema(p, astcon, consumer, clang::TranslationUnitKind::TU_Complete);

sm.createMainFileID(fm.getFile("main.cpp"));
engine.getClient()->BeginSourceFile(langopts, &p);
clang::ParseAST(sema);
4

1 に答える 1

4

clang::InitializePreprocessorフロントエンドを使用しない場合は、手動で呼び出す必要がありclang::BuiltinContext::InitializeBuiltinsます。

さらに、トリプルは「MinGW32」をベンダーとして指定する必要があります。たとえば、「MinGW」と名前を付けると、Clang は、その互換性を望んでいることを黙って認識できず、役に立たないオブジェクト ファイルが生成されます。

于 2012-12-27T17:37:46.557 に答える