| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 | #!/usr/bin/perl -wif ($ARGV[0] =~ /^-/) {    $lang = shift @ARGV;    $C = ($lang eq '-C');#    $TXT = ($lang eq '-txt');}for $fn (@ARGV) {    open(F, "$fn");    $lastnil = 0;    $incomment = 0;    while (<F>) {        ## Warn about windows-style newlines.        if (/\r/) {            print "       CR:$fn:$.\n";        }        ## Warn about tabs.        if (/\t/) {            print "      TAB:$fn:$.\n";        }        ## Warn about trailing whitespace.        if (/ +$/) {            print "Space\@EOL:$fn:$.\n";        }        ## Warn about control keywords without following space.        if ($C && /\s(?:if|while|for|switch)\(/) {            print "      KW(:$fn:$.\n";        }        ## Warn about multiple empty lines.        if ($lastnil && /^$/) {            print " DoubleNL:$fn:$.\n";        } elsif (/^$/) {            $lastnil = 1;        } else {            $lastnil = 0;        }        ## Terminals are still 80 columns wide in my world.  I refuse to        ## accept double-line lines.  Except, of course, svn Id tags        ## can make us go long.        if (/^.{80}/ && !/\$Id: /) {            print "     Wide:$fn:$.\n";        }        ### Juju to skip over comments and strings, since the tests        ### we're about to do are okay there.        if ($C) {            if ($incomment) {                if (m!\*/!) {                    s!.*?\*/!!;                    $incomment = 0;                } else {                    next;                }            }            if (m!/\*.*?\*/!) {                s!\s*/\*.*?\*/!!;            } elsif (m!/\*!) {                s!\s*/\*!!;                $incomment = 1;                next;            }            s!"(?:[^\"]+|\\.)*"!"X"!g;            next if /^\#/;            ## Warn about C++-style comments.            if (m!//!) {                #    print "       //:$fn:$.\n";                s!//.*!!;            }            ## Warn about braces preceded by non-space.            if (/([^\s])\{/) {                print "       $1\{:$fn:$.\n";            }            ## Warn about multiple internal spaces.            #if (/[^\s,:]\s{2,}[^\s\\=]/) {            #    print "     X  X:$fn:$.\n";            #}            ## Warn about { with stuff after.            #s/\s+$//;            #if (/\{[^\}\\]+$/) {            #    print "     {X:$fn:$.\n";            #}            ## Warn about function calls with space before parens.            if (/(\w+)\s\(([A-Z]*)/) {                if ($1 ne "if" and $1 ne "while" and $1 ne "for" and                    $1 ne "switch" and $1 ne "return" and $1 ne "int" and                    $1 ne "elsif" and $1 ne "WINAPI" and $2 ne "WINAPI" and                    $1 ne "void" and $1 ne "__attribute__") {                    print "     fn ():$fn:$.\n";                }            }            ## Warn about functions not declared at start of line.            if ($in_func_head ||                ($fn !~ /\.h$/ && /^[a-zA-Z0-9_]/ &&                 ! /^(?:const |static )*(?:typedef|struct|union)[^\(]*$/ &&                 ! /= *\{$/ && ! /;$/)) {                if (/.\{$/){                    print "fn() {:$fn:$.\n";                    $in_func_head = 0;                } elsif (/^\S[^\(]* +\**[a-zA-Z0-9_]+\(/) {                    $in_func_head = -1; # started with tp fn                } elsif (/;$/) {                    $in_func_head = 0;                } elsif (/\{/) {                    if ($in_func_head == -1) {                        print "tp fn():$fn:$.\n";                    }                    $in_func_head = 0;                }            }        }    }    if (! $lastnil) {        print "  EOL\@EOF:$fn:$.\n";    }    close(F);}
 |