[cfe-commits] r49049 - /cfe/trunk/utils/scan-build

Ted Kremenek kremenek at apple.com
Tue Apr 1 13:47:38 PDT 2008


Author: kremenek
Date: Tue Apr  1 15:47:38 2008
New Revision: 49049

URL: http://llvm.org/viewvc/llvm-project?rev=49049&view=rev
Log:
Initial checking of 'scan-build' script, a script used to wrap builds and
interpose calls to gcc with calls to the analyzer.

Added:
    cfe/trunk/utils/scan-build   (with props)

Added: cfe/trunk/utils/scan-build
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/utils/scan-build?rev=49049&view=auto

==============================================================================
--- cfe/trunk/utils/scan-build (added)
+++ cfe/trunk/utils/scan-build Tue Apr  1 15:47:38 2008
@@ -0,0 +1,246 @@
+#!/usr/bin/env perl
+#
+#                     The LLVM Compiler Infrastructure
+#
+# This file is distributed under the University of Illinois Open Source
+# License. See LICENSE.TXT for details.
+#
+##===----------------------------------------------------------------------===##
+#
+# A script designed to wrap a build so that all calls to gcc are intercepted
+# and piped to the static analyzer.
+#
+##===----------------------------------------------------------------------===##
+
+use strict;
+use warnings;
+use File::Temp qw/ :mktemp /;
+
+my $Verbose = 0;       # Verbose output from this script.
+my $Prog = "scan-build";
+
+##----------------------------------------------------------------------------##
+# GetHTMLRunDir - Construct an HTML directory name for the current run.
+##----------------------------------------------------------------------------##
+
+sub GetHTMLRunDir() {  
+
+  die "Not enough arguments." if (@_ == 0);
+  
+  my $Dir = shift @_;
+  
+  # Get current date and time.
+  
+  my @CurrentTime = localtime();
+  
+  my $year  = $CurrentTime[5] + 1900;
+  my $day   = $CurrentTime[3];
+  my $month = $CurrentTime[4] + 1;
+  
+  my $DateString = "$year-$month-$day";
+  
+  # Determine the run number.
+  
+  my $RunNumber;
+  
+  if (-d $Dir) {
+    
+    if (! -r $Dir) {
+      print STDERR "error: '$Dir' exists but is not readable.\n";
+      exit 0;
+    }
+    
+    # Iterate over all files in the specified directory.
+    
+    my $max = 0;
+    
+    opendir(DIR, $Dir);
+    my @FILES= readdir(DIR); 
+    closedir(DIR);
+    
+    foreach my $f (@FILES) {
+
+      my @x = split/-/, $f;
+      
+      next if (scalar(@x) != 4);
+      next if ($x[0] != $year);
+      next if ($x[1] != $month);
+      next if ($x[2] != $day);
+      
+      if ($x[3] > $max) {
+        $max = $x[3];
+      }      
+    }
+    
+    $RunNumber = $max + 1;
+  }
+  else {
+    
+    if (-x $Dir) {
+      print STDERR "error: '$Dir' exists but is not a directory.\n";
+      exit 0;
+    }
+    
+    # $Dir does not exist.  It will be automatically created by the 
+    # clang driver.  Set the run number to 1.  
+    
+    $RunNumber = 1;
+  }
+  
+  die "RunNumber must be defined!" if (!defined($RunNumber));
+  
+  # Append the run number.
+  
+  return "$Dir/$DateString-$RunNumber";  
+}
+
+sub SetHtmlEnv() {
+  
+  die "Wrong number of arguments." if (scalar(@_) != 2);
+  
+  my $Args = shift;
+  my $Dir = shift;
+  
+  die "No build command." if (scalar(@$Args) == 0);
+  
+  my $Cmd = $$Args[0];
+  
+  if ($Cmd =~ /configure/) {
+    return;
+  }
+  
+  if ($Verbose) {
+    print "$Prog: Emitting reports for this run to '$Dir'.\n";  
+  }
+  
+  $ENV{'CCC_ANALYZER_HTML'} = $Dir;
+}
+
+##----------------------------------------------------------------------------##
+# Postprocess - Postprocess the results of an analysis scan.
+##----------------------------------------------------------------------------##
+
+sub Postprocess() {
+  
+  my $Dir = shift;
+  
+  die "No directory specified." if (!defined($Dir));
+  
+  if (! -d $Dir) {
+    return;
+  }
+  
+  opendir(DIR, $Dir);
+  my @files = grep(/^report-.*\.html$/,readdir(DIR));
+  closedir(DIR);
+
+  if (scalar(@files) == 0) {
+    print "$Prog: Remove directory '$Dir' because it contains no reports.\n";
+    `rm -fR $Dir`;
+    return;
+  }
+
+
+}
+
+##----------------------------------------------------------------------------##
+# DisplayHelp - Utility function to display all help options.
+##----------------------------------------------------------------------------##
+
+sub DisplayHelp() {
+  
+  
+  
+}
+
+##----------------------------------------------------------------------------##
+# Process command-line arguments.
+##----------------------------------------------------------------------------##
+
+my $HtmlDir;           # Parent directory to store HTML files.
+my $IgnoreErrors = 0;  # Ignore build errors.
+
+if (!@ARGV) {
+  DisplayHelp();
+  exit 1
+}
+
+while (@ARGV) {
+  
+  # Scan for options we recognize.
+  
+  my $arg = $ARGV[0];
+
+  if ($arg eq "-?") {
+    DisplayHelp();
+    exit 1;
+  }
+  
+  if ($arg eq "-o") {
+    shift @ARGV;
+        
+    if (!@ARGV) {
+      print STDERR "'-o' option requires a target directory name.";
+      exit 0;
+    }
+    
+    $HtmlDir = shift @ARGV;
+    next;
+  }
+  
+  if ($arg eq "-k") {
+    shift @ARGV;
+    $IgnoreErrors = 1;
+    next;
+  }
+  
+  if ($arg eq "-v") {
+    shift @ARGV;
+    $Verbose++;
+    next;
+  }
+  
+  last;
+}
+
+if (!@ARGV) {
+  print STDERR "$Prog: No build command specified.\n\n";
+  DisplayHelp();
+  exit 0;
+}
+
+# Determine the output directory for the HTML reports.
+
+if (!defined($HtmlDir)) {
+  
+  $HtmlDir = mkdtemp("/tmp/scan-build-XXXXXX");
+  
+  if (!defined($HtmlDir)) {
+    print STDERR "error: Cannot create HTML directory in /tmp.\n";
+    exit 0;
+  }
+  
+  if (!$Verbose) {
+    print "$Prog: Using '$HtmlDir' as base HTML report directory.\n";
+  }
+}
+
+$HtmlDir = &GetHTMLRunDir($HtmlDir);
+
+# Set the appropriate environment variables.
+
+&SetHtmlEnv(\@ARGV, $HtmlDir);
+
+$ENV{'CC'} = "ccc-analyzer";
+
+if ($Verbose >= 2) {
+  $ENV{'CCC_ANALYZER_VERBOSE'} = 1;
+}
+
+# Run the build.
+
+system(@ARGV);
+
+# Postprocess the HTML directory.
+
+&Postprocess($HtmlDir);

Propchange: cfe/trunk/utils/scan-build

------------------------------------------------------------------------------
    svn:executable = *





More information about the cfe-commits mailing list