Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 165573
b: refs/heads/master
c: 92f3f19
h: refs/heads/master
i:
  165571: 8c7004a
v: v3
  • Loading branch information
Luis R. Rodriguez authored and Sam Ravnborg committed Sep 20, 2009
1 parent affe8e4 commit bc20b7f
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 8 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 82fa39552fd858468a5647fa58d14955ecd50eb4
refs/heads/master: 92f3f19c519d2eb18812a38312b05075cf0407db
66 changes: 59 additions & 7 deletions trunk/scripts/checkincludes.pl
Original file line number Diff line number Diff line change
@@ -1,33 +1,85 @@
#!/usr/bin/perl
#
# checkincludes: Find files included more than once in (other) files.
# checkincludes: find/remove files included more than once
#
# Copyright abandoned, 2000, Niels Kristian Bech Jensen <nkbj@image.dk>.
# Copyright 2009 Luis R. Rodriguez <mcgrof@gmail.com>
#
# This script checks for duplicate includes. It also has support
# to remove them in place. Note that this will not take into
# consideration macros so you should run this only if you know
# you do have real dups and do not have them under #ifdef's. You
# could also just review the results.

sub usage {
print "Usage: checkincludes.pl <file list>\n";
print "Usage: checkincludes.pl [-r]\n";
print "By default we just warn of duplicates\n";
print "To remove duplicated includes in place use -r\n";
exit 1;
}

my $remove = 0;

if ($#ARGV < 0) {
usage();
usage();
}

if ($#ARGV >= 1) {
if ($ARGV[0] =~ /^-/) {
if ($ARGV[0] eq "-r") {
$remove = 1;
shift;
} else {
usage();
}
}
}

foreach $file (@ARGV) {
open(FILE, $file) or die "Cannot open $file: $!.\n";

my %includedfiles = ();
my @file_lines = ();

while (<FILE>) {
if (m/^\s*#\s*include\s*[<"](\S*)[>"]/o) {
++$includedfiles{$1};
}
push(@file_lines, $_);
}

close(FILE);

foreach $filename (keys %includedfiles) {
if ($includedfiles{$filename} > 1) {
print "$file: $filename is included more than once.\n";

if (!$remove) {
foreach $filename (keys %includedfiles) {
if ($includedfiles{$filename} > 1) {
print "$file: $filename is included more than once.\n";
}
}
next;
}

open(FILE,">$file") || die("Cannot write to $file: $!");

my $dups = 0;
foreach (@file_lines) {
if (m/^\s*#\s*include\s*[<"](\S*)[>"]/o) {
foreach $filename (keys %includedfiles) {
if ($1 eq $filename) {
if ($includedfiles{$filename} > 1) {
$includedfiles{$filename}--;
$dups++;
} else {
print FILE $_;
}
}
}
} else {
print FILE $_;
}
}
if ($dups > 0) {
print "$file: removed $dups duplicate includes\n";
}
close(FILE);
}

0 comments on commit bc20b7f

Please sign in to comment.