diff options
Diffstat (limited to 'scripts')
| -rwxr-xr-x | scripts/checkincludes.pl | 66 |
1 files changed, 59 insertions, 7 deletions
diff --git a/scripts/checkincludes.pl b/scripts/checkincludes.pl index 4bff13985ebd..676ddc07d6fa 100755 --- a/scripts/checkincludes.pl +++ b/scripts/checkincludes.pl | |||
| @@ -1,33 +1,85 @@ | |||
| 1 | #!/usr/bin/perl | 1 | #!/usr/bin/perl |
| 2 | # | 2 | # |
| 3 | # checkincludes: Find files included more than once in (other) files. | 3 | # checkincludes: find/remove files included more than once |
| 4 | # | ||
| 4 | # Copyright abandoned, 2000, Niels Kristian Bech Jensen <nkbj@image.dk>. | 5 | # Copyright abandoned, 2000, Niels Kristian Bech Jensen <nkbj@image.dk>. |
| 6 | # Copyright 2009 Luis R. Rodriguez <mcgrof@gmail.com> | ||
| 7 | # | ||
| 8 | # This script checks for duplicate includes. It also has support | ||
| 9 | # to remove them in place. Note that this will not take into | ||
| 10 | # consideration macros so you should run this only if you know | ||
| 11 | # you do have real dups and do not have them under #ifdef's. You | ||
| 12 | # could also just review the results. | ||
| 5 | 13 | ||
| 6 | sub usage { | 14 | sub usage { |
| 7 | print "Usage: checkincludes.pl <file list>\n"; | 15 | print "Usage: checkincludes.pl [-r]\n"; |
| 16 | print "By default we just warn of duplicates\n"; | ||
| 17 | print "To remove duplicated includes in place use -r\n"; | ||
| 8 | exit 1; | 18 | exit 1; |
| 9 | } | 19 | } |
| 10 | 20 | ||
| 21 | my $remove = 0; | ||
| 22 | |||
| 11 | if ($#ARGV < 0) { | 23 | if ($#ARGV < 0) { |
| 12 | usage(); | 24 | usage(); |
| 25 | } | ||
| 26 | |||
| 27 | if ($#ARGV >= 1) { | ||
| 28 | if ($ARGV[0] =~ /^-/) { | ||
| 29 | if ($ARGV[0] eq "-r") { | ||
| 30 | $remove = 1; | ||
| 31 | shift; | ||
| 32 | } else { | ||
| 33 | usage(); | ||
| 34 | } | ||
| 35 | } | ||
| 13 | } | 36 | } |
| 14 | 37 | ||
| 15 | foreach $file (@ARGV) { | 38 | foreach $file (@ARGV) { |
| 16 | open(FILE, $file) or die "Cannot open $file: $!.\n"; | 39 | open(FILE, $file) or die "Cannot open $file: $!.\n"; |
| 17 | 40 | ||
| 18 | my %includedfiles = (); | 41 | my %includedfiles = (); |
| 42 | my @file_lines = (); | ||
| 19 | 43 | ||
| 20 | while (<FILE>) { | 44 | while (<FILE>) { |
| 21 | if (m/^\s*#\s*include\s*[<"](\S*)[>"]/o) { | 45 | if (m/^\s*#\s*include\s*[<"](\S*)[>"]/o) { |
| 22 | ++$includedfiles{$1}; | 46 | ++$includedfiles{$1}; |
| 23 | } | 47 | } |
| 48 | push(@file_lines, $_); | ||
| 24 | } | 49 | } |
| 25 | 50 | ||
| 26 | close(FILE); | 51 | close(FILE); |
| 27 | 52 | ||
| 28 | foreach $filename (keys %includedfiles) { | 53 | if (!$remove) { |
| 29 | if ($includedfiles{$filename} > 1) { | 54 | foreach $filename (keys %includedfiles) { |
| 30 | print "$file: $filename is included more than once.\n"; | 55 | if ($includedfiles{$filename} > 1) { |
| 56 | print "$file: $filename is included more than once.\n"; | ||
| 57 | } | ||
| 31 | } | 58 | } |
| 59 | next; | ||
| 32 | } | 60 | } |
| 61 | |||
| 62 | open(FILE,">$file") || die("Cannot write to $file: $!"); | ||
| 63 | |||
| 64 | my $dups = 0; | ||
| 65 | foreach (@file_lines) { | ||
| 66 | if (m/^\s*#\s*include\s*[<"](\S*)[>"]/o) { | ||
| 67 | foreach $filename (keys %includedfiles) { | ||
| 68 | if ($1 eq $filename) { | ||
| 69 | if ($includedfiles{$filename} > 1) { | ||
| 70 | $includedfiles{$filename}--; | ||
| 71 | $dups++; | ||
| 72 | } else { | ||
| 73 | print FILE $_; | ||
| 74 | } | ||
| 75 | } | ||
| 76 | } | ||
| 77 | } else { | ||
| 78 | print FILE $_; | ||
| 79 | } | ||
| 80 | } | ||
| 81 | if ($dups > 0) { | ||
| 82 | print "$file: removed $dups duplicate includes\n"; | ||
| 83 | } | ||
| 84 | close(FILE); | ||
| 33 | } | 85 | } |
