diff options
author | Artyom Skrobov <Artyom.Skrobov@arm.com> | 2013-12-13 13:43:48 +0000 |
---|---|---|
committer | Artyom Skrobov <Artyom.Skrobov@arm.com> | 2013-12-13 13:43:48 +0000 |
commit | 3a4fe369165a554e7376832ea1bf505567a086d7 (patch) | |
tree | 28d273188c640186b6fac7b9dadd3d85e7b7d027 | |
parent | e723bb10b02c59ab3162e9725fd0131b4337b943 (diff) | |
download | bcm5719-llvm-3a4fe369165a554e7376832ea1bf505567a086d7.tar.gz bcm5719-llvm-3a4fe369165a554e7376832ea1bf505567a086d7.zip |
clang-check to ignore -no-integrated-as because certain drivers can't handle it
llvm-svn: 197229
-rw-r--r-- | clang/lib/Tooling/CompilationDatabase.cpp | 8 | ||||
-rw-r--r-- | clang/test/Tooling/multi-jobs.cpp | 3 |
2 files changed, 6 insertions, 5 deletions
diff --git a/clang/lib/Tooling/CompilationDatabase.cpp b/clang/lib/Tooling/CompilationDatabase.cpp index 286beb7ae26..7bbae12dbf5 100644 --- a/clang/lib/Tooling/CompilationDatabase.cpp +++ b/clang/lib/Tooling/CompilationDatabase.cpp @@ -204,8 +204,8 @@ private: /// \li true if successful. /// \li false if \c Args cannot be used for compilation jobs (e.g. /// contains an option like -E or -version). -bool stripPositionalArgs(std::vector<const char *> Args, - std::vector<std::string> &Result) { +static bool stripPositionalArgs(std::vector<const char *> Args, + std::vector<std::string> &Result) { IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts = new DiagnosticOptions(); UnusedInputDiagConsumer DiagClient; DiagnosticsEngine Diagnostics( @@ -237,6 +237,10 @@ bool stripPositionalArgs(std::vector<const char *> Args, // up with no jobs but then this is the user's fault. Args.push_back("placeholder.cpp"); + // Remove -no-integrated-as; it's not used for syntax checking, + // and it confuses targets which don't support this option. + std::remove_if(Args.begin(), Args.end(), MatchesAny(std::string("no-integrated-as"))); + const OwningPtr<driver::Compilation> Compilation( NewDriver->BuildCompilation(Args)); diff --git a/clang/test/Tooling/multi-jobs.cpp b/clang/test/Tooling/multi-jobs.cpp index cef84439f0d..db8e9494083 100644 --- a/clang/test/Tooling/multi-jobs.cpp +++ b/clang/test/Tooling/multi-jobs.cpp @@ -2,6 +2,3 @@ // CHECK: C++ requires invalid; - -// MSVC targeted drivers (*-win32) are incapable of invoking external assembler. -// XFAIL: win32 |