]> Sergey Matveev's repositories - public-inbox.git/blobdiff - Makefile.PL
public-inbox 1.5.0
[public-inbox.git] / Makefile.PL
index 96c5903bcfc479e2d767d12d21fe9a0196c09b91..30b8adda2f0166126a543ba0b9cd42367a155e49 100644 (file)
@@ -1,5 +1,5 @@
 #!/usr/bin/perl -w
-# Copyright (C) 2013-2019 all contributors <meta@public-inbox.org>
+# Copyright (C) 2013-2020 all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 use strict;
 use ExtUtils::MakeMaker;
@@ -8,12 +8,19 @@ chomp(my @manifest = (<$m>));
 my @EXE_FILES = grep(m!^script/!, @manifest);
 my $v = {};
 my $t = {};
+
+# do not sort
+my @RELEASES = qw(v1.5.0 v1.4.0 v1.3.0 v1.2.0 v1.1.0-pre1 v1.0.0);
+
+$v->{news_deps} = [ map { "Documentation/RelNotes/$_.eml" } @RELEASES ];
 $v->{txt} = [ qw(INSTALL README COPYING TODO HACKING) ];
-my @dtxt = grep(m!\ADocumentation/.*\.txt\z!, @manifest);
+my @dtxt = grep(m!\ADocumentation/[^/]+\.txt\z!, @manifest);
 push @dtxt, 'Documentation/standards.txt';
+push @dtxt, 'Documentation/flow.txt';
+push @dtxt, @{$v->{txt}};
 for my $txt (@dtxt) {
        my $html = $txt;
-       $html =~ s/\.txt\z/.html/;
+       $html =~ s/\.txt\z/.html/ or $html .= '.html';
        $t->{"$html : $txt"} = [ "\$(txt2pre) <$txt" ];
 }
 $v->{t_slash_star_dot_t} = [ grep(m!\At/.*\.t\z!, @manifest) ];
@@ -67,11 +74,12 @@ $v->{rsync_docs} = [ @{$v->{gz_docs}}, @{$v->{docs}},
 # external manpages which we host ourselves, since some packages
 # (currently just Xapian) doesn't host manpages themselves.
 my @xman = qw(copydatabase.1 xapian-compact.1);
-$v->{xdocs} = [ map { "Documentation/.x/.$_.txt" } @xman ];
-$v->{xdocs_html} = [ map { "Documentation/.x/.$_.html" } @xman ];
+$v->{xdocs} = [ map { "Documentation/.$_.txt" } @xman ];
+$v->{xdocs_html} = [ map { "Documentation/.$_.html" } @xman ];
 for (@{$v->{xdocs}}) {
-       $t->{"$_ : | Documentation/.x"} = [
-               '$(PERL) -w Documentation/extman.perl >$@',
+       $t->{"$_:"} = [
+               '$(PERL) -w Documentation/extman.perl $@ >$@+',
+               'mv $@+ $@'
        ];
        my $html = $_;
        $html =~ s/\.txt\z/.html/;
@@ -90,6 +98,7 @@ my $VARS = join("\n", map {;
        my $varname = $_;
        join('', map { "$varname += $_\n" } sort @{$v->{$varname}});
 } grep(!/^-/, sort keys %$v));
+$VARS .= "\nRELEASES = ".join(' ', @RELEASES)."\n";
 
 # Don't waste user's disk space by installing some pods from
 # imported code or internal use only
@@ -103,8 +112,8 @@ my %man3 = map {; # semi-colon tells Perl this is a BLOCK (and not EXPR)
 
 WriteMakefile(
        NAME => 'PublicInbox',
-       VERSION => '1.2.0',
-       AUTHOR => 'Eric Wong <e@80x24.org>',
+       VERSION => '1.5.0',
+       AUTHOR => 'Eric Wong <e@yhbt.net>',
        ABSTRACT => 'public-inbox server infrastructure',
        EXE_FILES => \@EXE_FILES,
        PREREQ_PM => {
@@ -116,18 +125,24 @@ WriteMakefile(
                # `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,
 
                # libperl$PERL_VERSION or libencode-perl on Debian,
                # `perl5' on FreeBSD
-               'Encode' => 0,
+               'Encode' => 2.35, # 2.35 shipped with 5.10.1
+
+               # libperl$PERL_VERSION + perl-modules-$PERL_VERSION
+               'Compress::Raw::Zlib' => 0,
+               'Compress::Zlib' => 0,
+               'IO::Compress::Gzip' => 0,
 
-               # TODO: these should really be made optional...
-               'Plack' => 0,
+               # Plack is needed for public-inbox-httpd and PublicInbox::WWW
+               # 'Plack' => 0,
+
+               # Filesys::Notify::Simple is pulled in by Plack, but also
+               # needed by public-inbox-watch (for now)
+               # 'Filesys::Notify::Simple' => 0,
+
+               # TODO: this should really be made optional...
                'URI::Escape' => 0,
 
                # We have more test dependencies, but do not force
@@ -136,7 +151,7 @@ WriteMakefile(
                # 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.19',
+               'File::Temp' => '0.19', # for ->tmpdir support
                'Getopt::Long' => 0,
                'Exporter' => 0,
                # ExtUtils::MakeMaker # this file won't run w/o it...
@@ -166,10 +181,19 @@ changed = \$(shell git ls-files -m)
 dsyn :: \$(addsuffix .syntax, \$(filter \$(changed), \$(syn_files)))
 
 check-manifest :: MANIFEST
-       if git ls-files >\$?.gen 2>&1; then diff -u \$? \$?.gen; fi
+       if test -e .git && git ls-files >\$?.gen 2>&1; then \\
+               diff -u \$? \$?.gen; fi
+
+# the traditional way running per-*.t processes:
+check-each :: pure_all check-manifest
+       \$(EATMYDATA) \$(PROVE) --state=save -bvw -j\$(N)
+
+# lightly-tested way to run tests, relies "--state=save" in check-each
+# for best performance
+check-run :: pure_all check-manifest
+       \$(EATMYDATA) \$(PROVE) -bvw t/run.perl :: -j\$(N)
 
-check:: pure_all check-manifest
-       \$(EATMYDATA) \$(PROVE) -bvw -j\$(N)
+check :: check-each
 
 lib/PublicInbox/UserContent.pm :: contrib/css/216dark.css
        \$(PERL) -I lib \$@ \$?