diff options
| author | George Karpenkov <ekarpenkov@apple.com> | 2018-12-21 00:26:19 +0000 | 
|---|---|---|
| committer | George Karpenkov <ekarpenkov@apple.com> | 2018-12-21 00:26:19 +0000 | 
| commit | 6d45b1f3b0ff654ac4f5d0dba42ee7286a97e23e (patch) | |
| tree | 6204f5f5b6a7c5c9c698046023559821665904e6 /clang/lib | |
| parent | 212bbfad25e3e13f309e438f4cc7b51ecb9a9643 (diff) | |
| download | bcm5719-llvm-6d45b1f3b0ff654ac4f5d0dba42ee7286a97e23e.tar.gz bcm5719-llvm-6d45b1f3b0ff654ac4f5d0dba42ee7286a97e23e.zip  | |
Revert "Revert "[driver] [analyzer] Fix a backward compatibility issue after r348038.""
This reverts commit 144927939587b790c0536f4ff08245043fc8d733.
Fixes the bug in the original commit.
llvm-svn: 349863
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Driver/ToolChains/Clang.cpp | 10 | 
1 files changed, 7 insertions, 3 deletions
diff --git a/clang/lib/Driver/ToolChains/Clang.cpp b/clang/lib/Driver/ToolChains/Clang.cpp index d377b3c0321..87f9e818cc3 100644 --- a/clang/lib/Driver/ToolChains/Clang.cpp +++ b/clang/lib/Driver/ToolChains/Clang.cpp @@ -2360,9 +2360,6 @@ static void RenderAnalyzerOptions(const ArgList &Args, ArgStringList &CmdArgs,    // Treat blocks as analysis entry points.    CmdArgs.push_back("-analyzer-opt-analyze-nested-blocks"); -  // Enable compatilibily mode to avoid analyzer-config related errors. -  CmdArgs.push_back("-analyzer-config-compatibility-mode=true"); -    // Add default argument set.    if (!Args.hasArg(options::OPT__analyzer_no_default_checks)) {      CmdArgs.push_back("-analyzer-checker=core"); @@ -3738,6 +3735,13 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,    if (isa<AnalyzeJobAction>(JA))      RenderAnalyzerOptions(Args, CmdArgs, Triple, Input); +  // Enable compatilibily mode to avoid analyzer-config related errors. +  // Since we can't access frontend flags through hasArg, let's manually iterate +  // through them. +  for (auto Arg : Args.filtered(options::OPT_Xclang)) +    if (StringRef(Arg->getValue()) == "-analyzer-config") +      CmdArgs.push_back("-analyzer-config-compatibility-mode=true"); +    CheckCodeGenerationOptions(D, Args);    unsigned FunctionAlignment = ParseFunctionAlignment(TC, Args);  | 

