diff options
-rw-r--r-- | utils/pl2pm.PL | 87 |
1 files changed, 30 insertions, 57 deletions
diff --git a/utils/pl2pm.PL b/utils/pl2pm.PL index 4f50f17cbb..48e281d1a5 100644 --- a/utils/pl2pm.PL +++ b/utils/pl2pm.PL @@ -61,50 +61,43 @@ Larry Wall <larry@wall.org> =cut -use strict; -use warnings; - -my %keyword = (); - while (<DATA>) { - chomp; + chop; $keyword{$_} = 1; } -local $/; - +undef $/; +$* = 1; while (<>) { - my $newname = $ARGV; + $newname = $ARGV; $newname =~ s/\.pl$/.pm/ || next; $newname =~ s#(.*/)?(\w+)#$1\u$2#; if (-f $newname) { warn "Won't overwrite existing $newname\n"; next; } - my $oldpack = $2; - my $newpack = "\u$2"; - my @export = (); + $oldpack = $2; + $newpack = "\u$2"; + @export = (); + print "$oldpack => $newpack\n" if $verbose; s/\bstd(in|out|err)\b/\U$&/g; s/(sub\s+)(\w+)(\s*\{[ \t]*\n)\s*package\s+$oldpack\s*;[ \t]*\n+/${1}main'$2$3/ig; - if (/sub\s+\w+'/) { - @export = m/sub\s+\w+'(\w+)/g; + if (/sub\s+main'/) { + @export = m/sub\s+main'(\w+)/g; s/(sub\s+)main'(\w+)/$1$2/g; } else { @export = m/sub\s+([A-Za-z]\w*)/g; } - my @export_ok = grep($keyword{$_}, @export); + @export_ok = grep($keyword{$_}, @export); @export = grep(!$keyword{$_}, @export); - - my %export = (); @export{@export} = (1) x @export; - s/(^\s*);#/$1#/g; s/(#.*)require ['"]$oldpack\.pl['"]/$1use $newpack/; s/(package\s*)($oldpack)\s*;[ \t]*\n+//ig; - s/([\$\@%&*])'(\w+)/&xlate($1,"",$2,$newpack,$oldpack,\%export)/eg; - s/([\$\@%&*]?)(\w+)'(\w+)/&xlate($1,$2,$3,$newpack,$oldpack,\%export)/eg; + s/([\$\@%&*])'(\w+)/&xlate($1,"",$2)/eg; + s/([\$\@%&*]?)(\w+)'(\w+)/&xlate($1,$2,$3)/eg; if (!/\$\[\s*\)?\s*=\s*[^0\s]/) { s/^\s*(local\s*\()?\s*\$\[\s*\)?\s*=\s*0\s*;[ \t]*\n//g; s/\$\[\s*\+\s*//g; @@ -113,22 +106,24 @@ while (<>) { } s/open\s+(\w+)/open($1)/g; - my $export_ok = ''; - my $carp =''; - if (s/\bdie\b/croak/g) { $carp = "use Carp;\n"; s/croak "([^"]*)\\n"/croak "$1"/g; } - + else { + $carp = ""; + } if (@export_ok) { $export_ok = "\@EXPORT_OK = qw(@export_ok);\n"; } + else { + $export_ok = ""; + } - if ( open(PM, ">$newname") ) { - print PM <<"END"; + open(PM, ">$newname") || warn "Can't create $newname: $!\n"; + print PM <<"END"; package $newpack; -require 5.6.0; +require 5.000; require Exporter; $carp \@ISA = qw(Exporter); @@ -136,35 +131,27 @@ $carp $export_ok $_ END - } - else { - warn "Can't create $newname: $!\n"; - } } sub xlate { - my ($prefix, $pack, $ident,$newpack,$oldpack,$export) = @_; - - my $xlated ; + local($prefix, $pack, $ident) = @_; if ($prefix eq '' && $ident =~ /^(t|s|m|d|ing|ll|ed|ve|re)$/) { - $xlated = "${pack}'$ident"; + "${pack}'$ident"; } - elsif ($pack eq '' || $pack eq 'main') { - if ($export->{$ident}) { - $xlated = "$prefix$ident"; + elsif ($pack eq "" || $pack eq "main") { + if ($export{$ident}) { + "$prefix$ident"; } else { - $xlated = "$prefix${pack}::$ident"; + "$prefix${pack}::$ident"; } } elsif ($pack eq $oldpack) { - $xlated = "$prefix${newpack}::$ident"; + "$prefix${newpack}::$ident"; } else { - $xlated = "$prefix${pack}::$ident"; + "$prefix${pack}::$ident"; } - - return $xlated; } __END__ AUTOLOAD @@ -172,8 +159,6 @@ BEGIN CORE DESTROY END -INIT -CHECK abs accept alarm @@ -185,7 +170,6 @@ bless caller chdir chmod -chomp chop chown chr @@ -217,7 +201,6 @@ eof eq eval exec -exists exit exp fcntl @@ -277,12 +260,10 @@ link listen local localtime -lock log lstat lt m -map mkdir msgctl msgget @@ -298,21 +279,16 @@ open opendir or ord -our pack package pipe pop -pos print printf -prototype push q qq -qr quotemeta -qu qw qx rand @@ -372,15 +348,12 @@ sub substr symlink syscall -sysopen sysread -sysseek system syswrite tell telldir tie -tied time times tr |