Commit 38fe9eec7cdf8409156a060b0963bbcec9b3cb24

Francois Perrad 2015-12-10T07:30:09

sanitize some Perl scripts (Perl4 is gone)

diff --git a/dep.pl b/dep.pl
index 0a5d19a..fe9ab59 100644
--- a/dep.pl
+++ b/dep.pl
@@ -2,122 +2,126 @@
 #
 # Walk through source, add labels and make classes
 #
-#use strict;
+use strict;
+use warnings;
 
 my %deplist;
 
 #open class file and write preamble 
-open(CLASS, ">tommath_class.h") or die "Couldn't open tommath_class.h for writing\n";
-print CLASS "#if !(defined(LTM1) && defined(LTM2) && defined(LTM3))\n#if defined(LTM2)\n#define LTM3\n#endif\n#if defined(LTM1)\n#define LTM2\n#endif\n#define LTM1\n\n#if defined(LTM_ALL)\n";
+open(my $class, '>', 'tommath_class.h') or die "Couldn't open tommath_class.h for writing\n";
+print {$class} "#if !(defined(LTM1) && defined(LTM2) && defined(LTM3))\n#if defined(LTM2)\n#define LTM3\n#endif\n#if defined(LTM1)\n#define LTM2\n#endif\n#define LTM1\n\n#if defined(LTM_ALL)\n";
 
-foreach my $filename (glob "bn*.c") {
+foreach my $filename (glob 'bn*.c') {
    my $define = $filename;
 
-print "Processing $filename\n";
+   print "Processing $filename\n";
 
-   # convert filename to upper case so we can use it as a define 
+   # convert filename to upper case so we can use it as a define
    $define =~ tr/[a-z]/[A-Z]/;
    $define =~ tr/\./_/;
-   print CLASS "#define $define\n";
+   print {$class} "#define $define\n";
 
    # now copy text and apply #ifdef as required 
    my $apply = 0;
-   open(SRC, "<$filename");
-   open(OUT, ">tmp");
+   open(my $src, '<', $filename);
+   open(my $out, '>', 'tmp');
 
    # first line will be the #ifdef
-   my $line = <SRC>;
+   my $line = <$src>;
    if ($line =~ /include/) {
-      print OUT $line;
+      print {$out} $line;
    } else {
-      print OUT "#include <tommath.h>\n#ifdef $define\n$line";
+      print {$out} "#include <tommath.h>\n#ifdef $define\n$line";
       $apply = 1;
    }
-   while (<SRC>) {
+   while (<$src>) {
       if (!($_ =~ /tommath\.h/)) {
-         print OUT $_;
+         print {$out} $_;
       }
    }
    if ($apply == 1) {
-      print OUT "#endif\n";
+      print {$out} "#endif\n";
    }
-   close SRC;
-   close OUT;
+   close $src;
+   close $out;
 
-   unlink($filename);
-   rename("tmp", $filename);
+   unlink $filename;
+   rename 'tmp', $filename;
 }
-print CLASS "#endif\n\n";
+print {$class} "#endif\n\n";
 
 # now do classes 
 
-foreach my $filename (glob "bn*.c") {
-   open(SRC, "<$filename") or die "Can't open source file!\n"; 
+foreach my $filename (glob 'bn*.c') {
+   open(my $src, '<', $filename) or die "Can't open source file!\n";
 
    # convert filename to upper case so we can use it as a define 
    $filename =~ tr/[a-z]/[A-Z]/;
    $filename =~ tr/\./_/;
 
-   print CLASS "#if defined($filename)\n";
+   print {$class} "#if defined($filename)\n";
    my $list = $filename;
 
    # scan for mp_* and make classes
-   while (<SRC>) {
+   while (<$src>) {
       my $line = $_;
       while ($line =~ m/(fast_)*(s_)*mp\_[a-z_0-9]*/) {
           $line = $';
           # now $& is the match, we want to skip over LTM keywords like
           # mp_int, mp_word, mp_digit
-          if (!($& eq "mp_digit") && !($& eq "mp_word") && !($& eq "mp_int") && !($& eq "mp_min_u32")) {
+          if (!($& eq 'mp_digit') && !($& eq 'mp_word') && !($& eq 'mp_int') && !($& eq 'mp_min_u32')) {
              my $a = $&;
              $a =~ tr/[a-z]/[A-Z]/;
-             $a = "BN_" . $a . "_C";
+             $a = 'BN_' . $a . '_C';
              if (!($list =~ /$a/)) {
-                print CLASS "   #define $a\n";
+                print {$class} "   #define $a\n";
              }
-             $list = $list . "," . $a;
+             $list = $list . ',' . $a;
           }
       }
    }
-   @deplist{$filename} = $list;
+   $deplist{$filename} = $list;
 
-   print CLASS "#endif\n\n";
-   close SRC;
+   print {$class} "#endif\n\n";
+   close $src;
 }
 
-print CLASS "#ifdef LTM3\n#define LTM_LAST\n#endif\n#include <tommath_superclass.h>\n#include <tommath_class.h>\n#else\n#define LTM_LAST\n#endif\n";
-close CLASS;
+print {$class} "#ifdef LTM3\n#define LTM_LAST\n#endif\n#include <tommath_superclass.h>\n#include <tommath_class.h>\n#else\n#define LTM_LAST\n#endif\n";
+close $class;
 
 #now let's make a cool call graph... 
 
-open(OUT,">callgraph.txt");
-$indent = 0;
-foreach (keys %deplist) {
-   $list = "";
-   draw_func(@deplist{$_});
-   print OUT "\n\n";
+open(my $out, '>', 'callgraph.txt');
+my $indent = 0;
+my $list;
+foreach (sort keys %deplist) {
+   $list = '';
+   draw_func($deplist{$_});
+   print {$out} "\n\n";
 }
-close(OUT);
+close $out;
 
-sub draw_func()
+sub draw_func
 {
-   my @funcs = split(",", $_[0]);
-   if ($list =~ /@funcs[0]/) {
+   my @funcs = split ',', $_[0];
+   if ($list =~ /$funcs[0]/) {
       return;
    } else {
-      $list = $list . @funcs[0];
+      $list = $list . $funcs[0];
+   }
+   if ($indent == 0) {
+   } elsif ($indent >= 1) {
+      print {$out} '|   ' x ($indent - 1) . '+--->';
    }
-   if ($indent == 0) { }
-   elsif ($indent >= 1) { print OUT "|   " x ($indent - 1) . "+--->"; }
-   print OUT @funcs[0] . "\n";   
+   print {$out} $funcs[0] . "\n";
    shift @funcs;
-      my $temp = $list;
+   my $temp = $list;
    foreach my $i (@funcs) {
       ++$indent;
-      draw_func(@deplist{$i});
+      draw_func($deplist{$i}) if exists $deplist{$i};
       --$indent;
    }
-      $list = $temp;
+   $list = $temp;
+   return;
 }
 
-
diff --git a/filter.pl b/filter.pl
index a8a50c7..49f050e 100755
--- a/filter.pl
+++ b/filter.pl
@@ -2,32 +2,32 @@
 
 # we want to filter every between START_INS and END_INS out and then insert crap from another file (this is fun)
 
-$dst = shift;
-$ins = shift;
+use strict;
+use warnings;
 
-open(SRC,"<$dst");
-open(INS,"<$ins");
-open(TMP,">tmp.delme");
+open(my $src, '<', shift);
+open(my $ins, '<', shift);
+open(my $tmp, '>', 'tmp.delme');
 
-$l = 0;
-while (<SRC>) {
+my $l = 0;
+while (<$src>) {
    if ($_ =~ /START_INS/) {
-      print TMP $_;
+      print {$tmp} $_;
       $l = 1;
-      while (<INS>) {
-         print TMP $_;
+      while (<$ins>) {
+         print {$tmp} $_;
       }
-      close INS;
+      close $ins;
    } elsif ($_ =~ /END_INS/) {
-      print TMP $_;
+      print {$tmp} $_;
       $l = 0;
    } elsif ($l == 0) {
-      print TMP $_;
+      print {$tmp} $_;
    }
 }
 
-close TMP;
-close SRC;
+close $tmp;
+close $src;
 
 # $Source$
 # $Revision$
diff --git a/gen.pl b/gen.pl
index 57f65ac..332994d 100644
--- a/gen.pl
+++ b/gen.pl
@@ -4,16 +4,17 @@
 # add the whole source without any makefile troubles
 #
 use strict;
+use warnings;
 
-open( OUT, ">mpi.c" ) or die "Couldn't open mpi.c for writing: $!";
-foreach my $filename (glob "bn*.c") {
-   open( SRC, "<$filename" ) or die "Couldn't open $filename for reading: $!";
-   print OUT "/* Start: $filename */\n";
-   print OUT while <SRC>;
-   print OUT "\n/* End: $filename */\n\n";
-   close SRC or die "Error closing $filename after reading: $!";
+open(my $out, '>', 'mpi.c') or die "Couldn't open mpi.c for writing: $!";
+foreach my $filename (glob 'bn*.c') {
+   open(my $src, '<', $filename) or die "Couldn't open $filename for reading: $!";
+   print {$out} "/* Start: $filename */\n";
+   print {$out} $_ while <$src>;
+   print {$out} "\n/* End: $filename */\n\n";
+   close $src or die "Error closing $filename after reading: $!";
 }
-print OUT "\n/* EOF */\n";
-close OUT or die "Error closing mpi.c after writing: $!";
+print {$out} "\n/* EOF */\n";
+close $out or die "Error closing mpi.c after writing: $!";
 
 system('perl -pli -e "s/\s*$//" mpi.c');
diff --git a/makefile b/makefile
index 1a1664e..96578ee 100644
--- a/makefile
+++ b/makefile
@@ -193,3 +193,6 @@ zipup:
 new_file:
 	bash updatemakes.sh
 	perl dep.pl
+
+perlcritic:
+	perlcritic *.pl
diff --git a/parsenames.pl b/parsenames.pl
index cc57673..fd21b10 100755
--- a/parsenames.pl
+++ b/parsenames.pl
@@ -4,18 +4,21 @@
 # wrapped at 80 chars
 #
 # Tom St Denis
-@a = split(" ", $ARGV[1]);
-$b = "$ARGV[0]=";
-$len = length($b);
+use strict;
+use warnings;
+
+my @a = split ' ', $ARGV[1];
+my $b = $ARGV[0] . '=';
+my $len = length $b;
 print $b;
 foreach my $obj (@a) {
-   $len = $len + length($obj);
+   $len = $len + length $obj;
    $obj =~ s/\*/\$/;
    if ($len > 100) {
       printf "\\\n";
-      $len = length($obj);
+      $len = length $obj;
    }
-   print "$obj ";
+   print $obj . ' ';
 }
 
 print "\n\n";