diff options
author | Nicholas Clark <nick@ccl4.org> | 2013-07-08 12:11:35 +0200 |
---|---|---|
committer | Nicholas Clark <nick@ccl4.org> | 2013-07-09 07:54:27 +0200 |
commit | 8d68a8a555855e91bb1e6912e9ee30c136295672 (patch) | |
tree | 8b237dda48875ff36d9080b3a0032058e8ed2214 /lib | |
parent | d573a731832b47514921a72ae88e60b18be87e33 (diff) | |
download | perl-8d68a8a555855e91bb1e6912e9ee30c136295672.tar.gz |
Refactor xsinit generation code in ExtUtils::Embed.
Remove tautological comments about loading modules.
Simplify xsi_protos() and static_ext().
canon('/','DynaLoader') is just 'DynaLoader' so inline the constant.
Refactor canon() to consistently use 1 regex pattern delimiter, avoid map
in void context, and teach it that extensions can be in 'dist' and 'cpan' as
well as 'ext'.
Remove obsolete C<require 5.002> statement.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/ExtUtils/Embed.pm | 47 |
1 files changed, 17 insertions, 30 deletions
diff --git a/lib/ExtUtils/Embed.pm b/lib/ExtUtils/Embed.pm index 23ee07a784..71c3876016 100644 --- a/lib/ExtUtils/Embed.pm +++ b/lib/ExtUtils/Embed.pm @@ -1,14 +1,8 @@ -require 5.002; - package ExtUtils::Embed; require Exporter; use Config; require File::Spec; -#Only when we need them -#require ExtUtils::MakeMaker; -#require ExtUtils::Liblist; - use vars qw(@ISA @EXPORT $VERSION @Extensions $Verbose $lib_ext $opt_o $opt_s @@ -88,13 +82,8 @@ EOF sub xsi_protos { my(@exts) = @_; my(@retval,%seen); - my $boot_proto = "pTHX_ CV* cv"; - foreach $_ (@exts){ - my($pname) = canon('/', $_); - my($mname, $cname); - ($mname = $pname) =~ s!/!::!g; - ($cname = $pname) =~ s!/!__!g; - my($ccode) = "EXTERN_C void boot_${cname} ($boot_proto);\n"; + foreach my $cname (canon('__', @exts)) { + my($ccode) = "EXTERN_C void boot_${cname} (pTHX_ CV* cv);\n"; next if $seen{$ccode}++; push(@retval, $ccode); } @@ -103,8 +92,7 @@ sub xsi_protos { sub xsi_body { my(@exts) = @_; - my($pname,@retval,%seen); - my($dl) = canon('/','DynaLoader'); + my(@retval,%seen); push(@retval, " static const char file[] = __FILE__;\n") if @exts; push(@retval, " dXSUB_SYS;\n"); @@ -112,12 +100,11 @@ sub xsi_body { push(@retval, "\n") if @exts; - foreach $_ (@exts){ - my($pname) = canon('/', $_); - my($mname, $cname, $ccode); + foreach my $pname (canon('/', @exts)) { + my($cname, $mname, $ccode); ($mname = $pname) =~ s!/!::!g; ($cname = $pname) =~ s!/!__!g; - if ($pname eq $dl){ + if ($pname eq 'DynaLoader'){ # Must NOT install 'DynaLoader::boot_DynaLoader' as 'bootstrap'! # boot_DynaLoader is called directly in DynaLoader.pm $ccode = " /* DynaLoader is a special case */\n newXS(\"${mname}::boot_${cname}\", boot_${cname}, file);\n"; @@ -131,12 +118,8 @@ sub xsi_body { } sub static_ext { - unless (scalar @Extensions) { - my $static_ext = $Config{static_ext}; - $static_ext =~ s/^\s+//; - @Extensions = sort split /\s+/, $static_ext; - unshift @Extensions, qw(DynaLoader); - } + @Extensions = ('DynaLoader', sort $Config{static_ext} =~ /(\S+)/g) + unless @Extensions; @Extensions; } @@ -275,12 +258,16 @@ sub ccopts { sub canon { my($as, @ext) = @_; foreach(@ext) { - # might be X::Y or lib/auto/X/Y/Y.a - next if s!::!/!g; - s:^(lib|ext)/(auto/)?::; - s:/\w+\.\w+$::; + # might be X::Y or lib/auto/X/Y/Y.a + next + if s!::!/!g; + s!^(?:lib|ext|dist|cpan)/(?:auto/)?!!; + s!/\w+\.\w+$!!; + } + if ($as ne '/') { + s!/!$as! + foreach @ext; } - map(s:/:$as:, @ext) if ($as ne '/'); @ext; } |