2012-12-24 22 views
8

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

まず、HeaderSearchOptionsに検索パスを追加しました。ヘッダは私は文字通りコピーして貼り付け、それをエクスプローラから(そしてエスケープ用のバックスラッシュを倍増)reside-場所を正確

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

パスです。しかし、iostreamという名前のファイルが正確にpathに存在するにもかかわらず、Clangは依然として<iostream>を見つけることができないと主張している。

なぜ私のヘッダーを見つけることができないのですか?また、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); 
+0

単純な '-I'オプションで十分です。 'gcc -v'と' gcc -E'(サンプル入力上)を実行して、使用しているすべてのパスを探します。 –

答えて

4

フロントエンドを使用しない場合、手動でclang::InitializePreprocessorclang::BuiltinContext::InitializeBuiltinsを呼び出す必要がある私のコードです。

さらに、トリプルはベンダーとして "MinGW32"の名前を付ける必要があります。あなたが「MinGW」と名前をつけた場合、Clangはあなたがその互換性を望み、役に立たないオブジェクトファイルを生成していることを気づかずに黙ってしまいます。

関連する問題