From 27871ea66fa9b1f5622bef542c422d2ab5969e13 Mon Sep 17 00:00:00 2001 From: Ted Kremenek Date: Thu, 10 Mar 2011 21:10:08 +0000 Subject: [PATCH] Tweak ccc-analyzer's 'Analyze' function to not mutate the original arguments list. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@127428 91177308-0d34-0410-b5e6-96231b3b80d8 --- tools/scan-build/ccc-analyzer | 42 +++++++++++++++++------------------ 1 file changed, 21 insertions(+), 21 deletions(-) diff --git a/tools/scan-build/ccc-analyzer b/tools/scan-build/ccc-analyzer index 5601387d79..35d62aeb24 100755 --- a/tools/scan-build/ccc-analyzer +++ b/tools/scan-build/ccc-analyzer @@ -147,9 +147,10 @@ sub GetCCArgs { } sub Analyze { - my ($Clang, $Args, $AnalyzeArgs, $Lang, $Output, $Verbose, $HtmlDir, + my ($Clang, $OriginalArgs, $AnalyzeArgs, $Lang, $Output, $Verbose, $HtmlDir, $file) = @_; + my @Args = @$OriginalArgs; my $Cmd; my @CmdArgs; my @CmdArgsSansAnalyses; @@ -166,41 +167,40 @@ sub Analyze { else { $Cmd = $Clang; if ($Lang eq "objective-c" || $Lang eq "objective-c++") { - push @$Args,'-DIBOutlet=__attribute__((iboutlet))'; - push @$Args,'-DIBOutletCollection(ClassName)=__attribute__((iboutletcollection)))'; - push @$Args,'-DIBAction=void)__attribute__((ibaction)'; + push @Args,'-DIBOutlet=__attribute__((iboutlet))'; + push @Args,'-DIBOutletCollection(ClassName)=__attribute__((iboutletcollection)))'; + push @Args,'-DIBAction=void)__attribute__((ibaction)'; } # Create arguments for doing regular parsing. - my $SyntaxArgs = GetCCArgs("-fsyntax-only", $Args); - @CmdArgsSansAnalyses = @CmdArgs; - push @CmdArgsSansAnalyses, @$SyntaxArgs; - + my $SyntaxArgs = GetCCArgs("-fsyntax-only", \@Args); + @CmdArgsSansAnalyses = @$SyntaxArgs; + # Create arguments for doing static analysis. if (defined $ResultFile) { - push @$Args,'-o'; - push @$Args, $ResultFile; + push @Args,'-o'; + push @Args, $ResultFile; } elsif (defined $HtmlDir) { - push @$Args,'-o'; - push @$Args, $HtmlDir; + push @Args,'-o'; + push @Args, $HtmlDir; } - push @$Args,"-Xclang"; - push @$Args,"-analyzer-display-progress"; + push @Args,"-Xclang"; + push @Args,"-analyzer-display-progress"; foreach my $arg (@$AnalyzeArgs) { - push @$Args, "-Xclang"; - push @$Args, $arg; + push @Args, "-Xclang"; + push @Args, $arg; } # Display Ubiviz graph? if (defined $ENV{'CCC_UBI'}) { - push @$Args, "-Xclang"; - push @$Args,"-analyzer-viz-egraph-ubigraph"; + push @Args, "-Xclang"; + push @Args,"-analyzer-viz-egraph-ubigraph"; } - my $AnalysisArgs = GetCCArgs("--analyze", $Args); - push @CmdArgs, @$AnalysisArgs; + my $AnalysisArgs = GetCCArgs("--analyze", \@Args); + @CmdArgs = @$AnalysisArgs; } my @PrintArgs; @@ -217,7 +217,7 @@ sub Analyze { if ($Verbose == 1) { # We MUST print to stderr. Some clients use the stdout output of # gcc for various purposes. - print STDERR join(' ',@PrintArgs); + print STDERR join(' ', @PrintArgs); print STDERR "\n"; } elsif ($Verbose == 2) { -- 2.40.0