Skip Menu |

This queue is for tickets about the ExtUtils-MakeMaker CPAN distribution.

Report information
The Basics
Id: 28992
Status: resolved
Worked: 30 min
Priority: 0/
Queue: ExtUtils-MakeMaker

People
Owner: BINGOS [...] cpan.org
Requestors: schwern [...] pobox.com
Cc:
AdminCc:

Bug Information
Severity: Wishlist
Broken in: (no value)
Fixed in: 6.82



Subject: [Fwd: How to get rid of empty .bs files]
Date: Sat, 25 Aug 2007 18:24:02 -0700
To: via RT <bug-ExtUtils-MakeMaker [...] rt.cpan.org>
From: Michael G Schwern <schwern [...] pobox.com>
Show quoted text
-------- Original Message -------- Subject: How to get rid of empty .bs files Date: Wed, 15 Aug 2007 19:25:52 +0200 From: Reini Urban <rurban@x-ray.at> To: makemaker@perl.org CC: The Perl5 Porters Mailing List <perl5-porters@perl.org> I noticed that on the windows platforms a lot of unnecessary bootstrap files are created. Dynaloader says that a .bs files is ignored if empty. I also assume that on Windows .bs files for dll's will always be empty, because we (windows) cannot deal with unresolved symbols ("lazy loading"), they are resolved by LoadLibrary and DLL stubs instead. So I assume that we don't need to create 0 byte .bs files for each xs because this will speed up dynaloader saving a stat, and a dir entry for those files. And it will please us aesthetically. Maybe it improves security also, because creating a LD_PRELOAD hack is harder than appending to an already existing file. Correct or am I missing something? So how to get rid of empty .bs files? # --- MakeMaker dynamic_bs section: # As Mkbootstrap might not write a file (if none is required) # we use touch to prevent make continually trying to remake it. # The DynaLoader only reads a non-empty file. $(BOOTSTRAP) : $(FIRST_MAKEFILE) $(BOOTDEP) \ $(INST_ARCHAUTODIR)$(DFSEP).exists $(NOECHO) $(ECHO) "Running Mkbootstrap for \ $(NAME) ($(BSLOADLIBS))" $(NOECHO) $(PERLRUN) \ "-MExtUtils::Mkbootstrap" \ -e "Mkbootstrap('$(BASEEXT)','$(BSLOADLIBS)');" $(NOECHO) $(TOUCH) $@ $(CHMOD) $(PERM_RW) $@ $(INST_BOOT) : $(BOOTSTRAP) $(INST_ARCHAUTODIR)$(DFSEP).exists $(NOECHO) $(RM_RF) $@ - $(CP) $(BOOTSTRAP) $@ $(CHMOD) $(PERM_RW) $@ Ok, let's touch it locally to be able to run $(BOOTSTRAP) which MIGHT actually pull in some code. But get rid of INST_BOOT as dependency of dynamic - INST_DYNAMIC is enough - and skip copying an empty file. Currently I do this in MM_Unix # copy .bs only if non-empty push @m, <<'MAKE'; $(CHMOD) $(PERM_RWX) $@ $(NOECHO) $(RM_RF) $(BOOTSTRAP) - $(TEST_S) $(BOOTSTRAP) && $(CP) $(BOOTSTRAP) $(INST_BOOT) && \ $(CHMOD) $(PERM_RW) $(INST_BOOT) This leaves us with Error 1 (ignored) test -s B.bs && cp B.bs ../../lib/auto/B/B.bs && \ chmod 644 ../../lib/auto/B/B.bs make[1]: [../../lib/auto/B/B.dll] Error 1 (ignored) flagging that .bs was not copied. Hmm. Portability: TEST_S is easy, but the '&&' logic? Shouldn't we use a ABSPERLRUN -MExtUtils::Command -e cp_nonempty (PERM FROM TO) Or maybe only on non-unix platforms?
difforig perl-current/lib/ExtUtils 2007-08-15 Reini Urban <rurban@x-ray.at> diff -ub perl-current/lib/ExtUtils/Command.pm.orig --- perl-current/lib/ExtUtils/Command.pm.orig 2007-02-06 21:44:12.000000000 +0000 +++ perl-current/lib/ExtUtils/Command.pm 2007-08-15 17:00:30.531250000 +0000 @@ -10,9 +10,9 @@ require Exporter; use vars qw(@ISA @EXPORT @EXPORT_OK $VERSION); @ISA = qw(Exporter); -@EXPORT = qw(cp rm_f rm_rf mv cat eqtime mkpath touch test_f test_d chmod +@EXPORT = qw(cp rm_f rm_rf mv cat eqtime mkpath touch test_f test_s test_d chmod dos2unix); -$VERSION = '1.13'; +$VERSION = '1.13_01'; my $Is_VMS = $^O eq 'VMS'; @@ -31,6 +31,7 @@ perl -MExtUtils::Command -e mkpath directories... perl -MExtUtils::Command -e eqtime source destination perl -MExtUtils::Command -e test_f file + perl -MExtUtils::Command -e test_s file perl -MExtUtils::Command -e test_d directory perl -MExtUtils::Command -e chmod mode files... ... @@ -273,6 +274,19 @@ exit(-f $ARGV[0] ? 0 : 1); } +=item test_s + + test_s file + +Tests if a file exists and is not empty (size > 0). I<Exits> with 0 if it does, 1 if it does not. + +=cut + +sub test_s +{ + exit(-s $ARGV[0] ? 0 : 1); +} + =item test_d test_d directory diff -ub perl-current/lib/ExtUtils/MM_Any.pm.orig --- perl-current/lib/ExtUtils/MM_Any.pm.orig 2007-02-22 14:39:26.000000000 +0000 +++ perl-current/lib/ExtUtils/MM_Any.pm 2007-08-15 17:18:25.921875000 +0000 @@ -2,7 +2,7 @@ use strict; use vars qw($VERSION @ISA); -$VERSION = '0.15'; +$VERSION = '0.15_01'; use Carp; use File::Spec; @@ -441,7 +441,7 @@ # $(INST_BIN) $(INST_SCRIPT) # $(INST_MAN1DIR) $(INST_MAN3DIR) # $(INST_LIBDIR) $(INST_ARCHLIBDIR) $(INST_AUTODIR) -# $(INST_STATIC) $(INST_DYNAMIC) $(INST_BOOT) +# $(INST_STATIC) $(INST_DYNAMIC) # ); @@ -626,10 +626,11 @@ sub dynamic { # --- Dynamic Loading Sections --- +# Note: $(INST_BOOT) moved to dynamic_lib to get rid of empty .bs my($self) = shift; ' -dynamic :: $(FIRST_MAKEFILE) $(INST_DYNAMIC) $(INST_BOOT) +dynamic :: $(FIRST_MAKEFILE) $(BOOTSTRAP) $(INST_DYNAMIC) $(NOECHO) $(NOOP) '; } diff -ub perl-current/lib/ExtUtils/MM_Unix.pm.orig --- perl-current/lib/ExtUtils/MM_Unix.pm.orig 2007-07-03 16:15:39.000000000 +0000 +++ perl-current/lib/ExtUtils/MM_Unix.pm 2007-08-15 17:23:31.546875000 +0000 @@ -859,7 +859,7 @@ # As Mkbootstrap might not write a file (if none is required) # we use touch to prevent make continually trying to remake it. -# The DynaLoader only reads a non-empty file. +# BOOTSTRAP only gets installed if non-empty. $(BOOTSTRAP) : $(FIRST_MAKEFILE) $(BOOTDEP) $(INST_ARCHAUTODIR)$(DFSEP).exists $(NOECHO) $(ECHO) "Running Mkbootstrap for $(NAME) ($(BSLOADLIBS))" $(NOECHO) $(PERLRUN) \ @@ -867,11 +867,6 @@ -e "Mkbootstrap('$(BASEEXT)','$(BSLOADLIBS)');" $(NOECHO) $(TOUCH) %s $(CHMOD) $(PERM_RW) %s - -$(INST_BOOT) : $(BOOTSTRAP) $(INST_ARCHAUTODIR)$(DFSEP).exists - $(NOECHO) $(RM_RF) %s - - $(CP) $(BOOTSTRAP) %s - $(CHMOD) $(PERM_RW) %s MAKE_FRAG } @@ -903,7 +898,7 @@ INST_DYNAMIC_DEP = '.$inst_dynamic_dep.' INST_DYNAMIC_FIX = '.$ld_fix.' -$(INST_DYNAMIC): $(OBJECT) $(MYEXTLIB) $(BOOTSTRAP) $(INST_ARCHAUTODIR)$(DFSEP).exists $(EXPORT_LIST) $(PERL_ARCHIVE) $(PERL_ARCHIVE_AFTER) $(INST_DYNAMIC_DEP) +$(INST_DYNAMIC): $(OBJECT) $(MYEXTLIB) $(INST_ARCHAUTODIR)$(DFSEP).exists $(EXPORT_LIST) $(PERL_ARCHIVE) $(PERL_ARCHIVE_AFTER) $(INST_DYNAMIC_DEP) '); if ($armaybe ne ':'){ $ldfrom = 'tmp$(LIB_EXT)'; @@ -949,8 +944,12 @@ $(INST_DYNAMIC_FIX) MAKE + # copy .bs only if non-empty push @m, <<'MAKE'; $(CHMOD) $(PERM_RWX) $@ + $(NOECHO) $(RM_RF) $(BOOTSTRAP) + - $(TEST_S) $(BOOTSTRAP) && $(CP) $(BOOTSTRAP) $(INST_BOOT) && \ + $(CHMOD) $(PERM_RW) $(INST_BOOT) MAKE return join('',@m); @@ -1728,7 +1727,7 @@ Initializes EXTRALIBS, BSLOADLIBS, LDLOADLIBS, LIBS, LD_RUN_PATH, LD, OBJECT, BOOTDEP, PERLMAINCC, LDFROM, LINKTYPE, SHELL, NOOP, -FIRST_MAKEFILE, MAKEFILE_OLD, NOECHO, RM_F, RM_RF, TEST_F, +FIRST_MAKEFILE, MAKEFILE_OLD, NOECHO, RM_F, RM_RF, TEST_F, TEST_S, TOUCH, CP, MV, CHMOD, UMASK_NULL, ECHO, ECHO_N =cut @@ -1805,6 +1804,7 @@ $self->{RM_RF} ||= "rm -rf"; $self->{TOUCH} ||= "touch"; $self->{TEST_F} ||= "test -f"; + $self->{TEST_S} ||= "test -s"; $self->{CP} ||= "cp"; $self->{MV} ||= "mv"; $self->{CHMOD} ||= "chmod"; @@ -3528,7 +3528,7 @@ # We set PM_FILTER as late as possible so it can see all the earlier # on macro-order sensitive makes such as nmake. - for my $tool (qw{ SHELL CHMOD CP MV NOOP NOECHO RM_F RM_RF TEST_F TOUCH + for my $tool (qw{ SHELL CHMOD CP MV NOOP NOECHO RM_F RM_RF TEST_F TEST_S TOUCH UMASK_NULL DEV_NULL MKPATH EQUALIZE_TIMESTAMP ECHO ECHO_N UNINST VERBINST diff -ub perl-current/lib/ExtUtils/MM_VMS.pm.orig --- perl-current/lib/ExtUtils/MM_VMS.pm.orig 2007-07-02 15:44:47.000000000 +0000 +++ perl-current/lib/ExtUtils/MM_VMS.pm 2007-08-15 17:02:38.140625000 +0000 @@ -473,6 +473,7 @@ $self->{RM_F} ||= '$(ABSPERLRUN) "-MExtUtils::Command" -e rm_f'; $self->{RM_RF} ||= '$(ABSPERLRUN) "-MExtUtils::Command" -e rm_rf'; $self->{TEST_F} ||= '$(ABSPERLRUN) "-MExtUtils::Command" -e test_f'; + $self->{TEST_S} ||= '$(ABSPERLRUN) "-MExtUtils::Command" -e test_s'; $self->{EQUALIZE_TIMESTAMP} ||= '$(ABSPERLRUN) -we "open F,qq{>>$ARGV[1]};close F;utime(0,(stat($ARGV[0]))[9]+1,$ARGV[1])"'; $self->{MOD_INSTALL} ||= diff -ub perl-current/lib/ExtUtils/MM_Win32.pm.orig --- perl-current/lib/ExtUtils/MM_Win32.pm.orig 2007-07-02 15:44:47.000000000 +0000 +++ perl-current/lib/ExtUtils/MM_Win32.pm 2007-08-15 17:01:38.750000000 +0000 @@ -165,6 +165,7 @@ $self->{MV} ||= '$(ABSPERLRUN) -MExtUtils::Command -e mv'; $self->{NOOP} ||= 'rem'; $self->{TEST_F} ||= '$(ABSPERLRUN) -MExtUtils::Command -e test_f'; + $self->{TEST_S} ||= '$(ABSPERLRUN) -MExtUtils::Command -e test_s'; $self->{DEV_NULL} ||= '> NUL'; $self->{FIXIN} ||= $self->{PERL_CORE} ? diff -ub perl-current/lib/ExtUtils/Mkbootstrap.pm.orig --- perl-current/lib/ExtUtils/Mkbootstrap.pm.orig 2007-02-22 14:39:26.000000000 +0000 +++ perl-current/lib/ExtUtils/Mkbootstrap.pm 2007-08-15 15:44:30.593750000 +0000 @@ -4,7 +4,7 @@ use strict 'refs'; use vars qw($VERSION @ISA @EXPORT); -$VERSION = '1.17'; +$VERSION = '1.17_01'; require Exporter; @ISA = ('Exporter');
This has been patched in the EUMM source repository.
Many thanks, this has now been resolved.