X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=Makefile.PL;h=113f8c776cd2ad7248753724db89bba247fc301d;hb=d9aad3a7988262b31ab2171f2c982daf04ac822c;hp=c134ff92893db27a83d7b6e637f5272f0e369adc;hpb=b60a4c5e4839bd358f285683b3e388d40e595cb8;p=public-inbox.git diff --git a/Makefile.PL b/Makefile.PL index c134ff92..113f8c77 100644 --- a/Makefile.PL +++ b/Makefile.PL @@ -8,6 +8,15 @@ chomp(my @manifest = (<$m>)); my @EXE_FILES = grep(m!^script/!, @manifest); my $PM_FILES = join(' ', grep(m!^lib/.*\.pm$!, @manifest)); +# Don't waste user's disk space by installing some pods from +# imported code or internal use only +my %man3 = map {; # semi-colon tells Perl this is a BLOCK (and not EXPR) + my $base = $_; + my $mod = $base; + $mod =~ s/\.\w+\z//; + "lib/PublicInbox/$_" => "blib/man3/PublicInbox::$mod.3" +} qw(Git.pm Import.pm WWW.pod); + WriteMakefile( NAME => 'PublicInbox', VERSION => '1.1.0-pre1', @@ -19,10 +28,20 @@ WriteMakefile( # We also depend on git. # Keep this sorted and synced to the INSTALL document 'Date::Parse' => 0, + + # libperl$PERL_VERSION, + # `perl5' on FreeBSD + # perl-Digest-SHA on RH-based + 'Digest::SHA' => 0, 'Email::MIME' => 0, + + # the following should be pulled in by Email::MIME: 'Email::MIME::ContentType' => 0, 'Email::Simple' => 0, - 'Encode::MIME::Header' => 0, + + # libperl$PERL_VERSION or libencode-perl on Debian, + # `perl5' on FreeBSD + 'Encode' => 0, # TODO: these should really be made optional... 'Plack' => 0, @@ -30,7 +49,16 @@ WriteMakefile( # We have more test dependencies, but do not force # users to install them. See INSTALL + + # All Perl installs I know about have these, but RH-based + # distros make them separate even though 'perl' pulls them in + 'File::Path' => 0, + 'File::Temp' => 0, + 'Getopt::Long' => 0, + 'Exporter' => 0, + # ExtUtils::MakeMaker # this file won't run w/o it... }, + MAN3PODS => \%man3, ); sub MY::postamble { @@ -38,23 +66,29 @@ sub MY::postamble { # support using eatmydata to speed up tests (apt-get install eatmydata): # https://www.flamingspork.com/projects/libeatmydata/ EATMYDATA = +N = \$\$(( \$\$(nproc 2>/dev/null || gnproc 2>/dev/null || echo 2) + 1 )) -include config.mak -include Documentation/include.mk -N ?= \$(shell echo \$\$(( \$\$(nproc 2>/dev/null || echo 2) + 1))) SCRIPTS := scripts/ssoma-replay -my_syntax := \$(addsuffix .syntax, $PM_FILES \$(EXE_FILES) \$(SCRIPTS)) - +syn_files := $PM_FILES \$(EXE_FILES) \$(SCRIPTS) +my_syntax := \$(addsuffix .syntax, \$(syn_files)) +changed = \$(shell git ls-files -m) %.syntax :: - @\$(PERL) -I lib -c \$(subst .syntax,,\$@) + @\$(PERL) -w -I lib -c \$(subst .syntax,,\$@) syntax:: \$(my_syntax) +dsyn :: \$(addsuffix .syntax, \$(filter \$(changed), \$(syn_files))) + check-manifest :: MANIFEST - if git ls-files >\$<.gen 2>&1; then diff -u \$< \$<.gen; fi + if git ls-files >\$?.gen 2>&1; then diff -u \$? \$?.gen; fi check:: pure_all check-manifest - \$(EATMYDATA) prove -lv -j\$(N) + \$(EATMYDATA) prove -lvw -j\$(N) + +lib/PublicInbox/UserContent.pm :: contrib/css/216dark.css + \$(PERL) -I lib \$@ \$? EOF }