scripts: improve checkstack

Cleanup checkstack script:
  * Turn on strict checking
  * Fix resulting error message because the declaration syntax
    was incorrect.
  * Remove incorrect and misleading use of prototype
     - prototype not required for this type of sort function
       because $a and $b are being used in this contex
     - if prototype was being used it should be for both arguments
  * Use closure for sort function

Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Arjan van de Ven <arjan@infradead.org>
Cc: Cong Wang <amwang@redhat.com>
Cc: Michal Marek <mmarek@suse.cz>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Michal Marek <mmarek@suse.cz>
This commit is contained in:
Stephen Hemminger 2010-02-22 15:17:09 -08:00 committed by Michal Marek
parent b59a122584
commit 1f2a144f5a

View file

@ -21,6 +21,8 @@
# #
# TODO : Port to all architectures (one regex per arch) # TODO : Port to all architectures (one regex per arch)
use strict;
# check for arch # check for arch
# #
# $re is used for two matches: # $re is used for two matches:
@ -104,19 +106,11 @@ my (@stack, $re, $dre, $x, $xs);
} }
} }
sub bysize($) {
my ($asize, $bsize);
($asize = $a) =~ s/.*: *(.*)$/$1/;
($bsize = $b) =~ s/.*: *(.*)$/$1/;
$bsize <=> $asize
}
# #
# main() # main()
# #
my $funcre = qr/^$x* <(.*)>:$/; my $funcre = qr/^$x* <(.*)>:$/;
my $func; my ($func, $file, $lastslash);
my $file, $lastslash;
while (my $line = <STDIN>) { while (my $line = <STDIN>) {
if ($line =~ m/$funcre/) { if ($line =~ m/$funcre/) {
@ -173,4 +167,6 @@ while (my $line = <STDIN>) {
} }
} }
print sort bysize @stack; # Sort output by size (last field)
print sort { ($b =~ /:\t*(\d+)$/)[0] <=> ($a =~ /:\t*(\d+)$/)[0] } @stack;