From: Ted Kremenek Date: Mon, 27 Jul 2009 22:10:34 +0000 (+0000) Subject: Add scan-build support for 'plist-html', a hybrid mode that supports the X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7753b352366778d01c5cda4117356f181d3dd468;p=clang Add scan-build support for 'plist-html', a hybrid mode that supports the creation of both HTML and plist files. Plist files are currently not generated using the same layout algorithm as just specifying '-plist', so this is mainly intended to help support automated runs of the analyzer. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@77263 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/utils/ccc-analyzer b/utils/ccc-analyzer index e4bf415b16..6355abcd19 100755 --- a/utils/ccc-analyzer +++ b/utils/ccc-analyzer @@ -584,7 +584,7 @@ if ($Action eq 'compile' or $Action eq 'link') { if (defined $OutputFormat) { push @AnalyzeArgs, "-analyzer-output=" . $OutputFormat; - if ($OutputFormat eq "plist") { + if ($OutputFormat =~ /plist/) { # Change "Output" to be a file. my ($h, $f) = tempfile("report-XXXXXX", SUFFIX => ".plist", DIR => $HtmlDir); diff --git a/utils/scan-build b/utils/scan-build index 79421caba9..d7b74e3411 100755 --- a/utils/scan-build +++ b/utils/scan-build @@ -1167,7 +1167,12 @@ while (@ARGV) { $OutputFormat = "plist"; next; } - + if ($arg eq "-plist-html") { + shift @ARGV; + $OutputFormat = "plist-html"; + next; + } + DieDiag("unrecognized option '$arg'\n") if ($arg =~ /^-/); last; @@ -1253,25 +1258,27 @@ if (defined $OutputFormat) { # Run the build. my $ExitStatus = RunBuildCommand(\@ARGV, $IgnoreErrors, $Cmd); -if (defined $OutputFormat and $OutputFormat eq "plist") { - Diag "Analysis run complete.\n"; - Diag "Analysis results (plist files) deposited in '$HtmlDir'\n"; -} -else { - # Postprocess the HTML directory. - my $NumBugs = Postprocess($HtmlDir, $BaseDir); +if (defined $OutputFormat) { + if ($OutputFormat =~ /html/) { + # Postprocess the HTML directory. + my $NumBugs = Postprocess($HtmlDir, $BaseDir); + + if ($ViewResults and -r "$HtmlDir/index.html") { + Diag "Analysis run complete.\n"; + Diag "Viewing analysis results in '$HtmlDir' using scan-view.\n"; + my $ScanView = Cwd::realpath("$RealBin/scan-view"); + if (! -x $ScanView) { $ScanView = "scan-view"; } + exec $ScanView, "$HtmlDir"; + } - if ($ViewResults and -r "$HtmlDir/index.html") { - Diag "Analysis run complete.\n"; - Diag "Viewing analysis results in '$HtmlDir' using scan-view.\n"; - my $ScanView = Cwd::realpath("$RealBin/scan-view"); - if (! -x $ScanView) { $ScanView = "scan-view"; } - exec $ScanView, "$HtmlDir"; + if ($ExitStatusFoundBugs) { + exit 1 if ($NumBugs > 0); + exit 0; + } } - - if ($ExitStatusFoundBugs) { - exit 1 if ($NumBugs > 0); - exit 0; + elsif ($OutputFormat =~ /plist/) { + Diag "Analysis run complete.\n"; + Diag "Analysis results (plist files) deposited in '$HtmlDir'\n"; } }