]> Sergey Matveev's repositories - public-inbox.git/blobdiff - Makefile.PL
add xt/mem-nntpd-tls maintainer test
[public-inbox.git] / Makefile.PL
index ca8e45cfb650c05599ddcce263107a6842fcbf8e..848eb70299d8ed88464857de79085a0d90cd5b63 100644 (file)
@@ -1,16 +1,18 @@
 #!/usr/bin/perl -w
-# Copyright (C) 2013-2021 all contributors <meta@public-inbox.org>
+# Copyright (C) all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 use strict;
 use ExtUtils::MakeMaker;
 open my $m, '<', 'MANIFEST' or die "open(MANIFEST): $!\n";
 chomp(my @manifest = (<$m>));
+push @manifest, 'lib/PublicInbox.pm'; # generated
 my @EXE_FILES = grep(m!^script/!, @manifest);
 my $v = {};
 my $t = {};
 
 # do not sort
-my @RELEASES = qw(v1.6.1 v1.6.0 v1.5.0 v1.4.0 v1.3.0 v1.2.0 v1.1.0-pre1 v1.0.0);
+my @RELEASES = qw(v1.8.0 v1.7.0 v1.6.1 v1.6.0 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) ];
@@ -21,7 +23,7 @@ push @dtxt, @{$v->{txt}};
 for my $txt (@dtxt) {
        my $html = $txt;
        $html =~ s/\.txt\z/.html/ or $html .= '.html';
-       $t->{"$html : $txt"} = [ "\$(txt2pre) <$txt" ];
+       $t->{"$html : $txt"} = [ "\$(txt2pre) <$txt", "touch -r $txt \$@" ];
 }
 $v->{t_slash_star_dot_t} = [ grep(m!\At/.*\.t\z!, @manifest) ];
 my @scripts = qw(scripts/ssoma-replay); # legacy
@@ -44,12 +46,22 @@ $v->{-m1} = [ map {
                }
        } @EXE_FILES,
        qw(
-       lei-add-external lei-config lei-daemon-kill lei-daemon-pid
-       lei-forget-external lei-init lei-ls-external lei-q)];
+       lei-add-external lei-add-watch lei-blob lei-config lei-convert
+       lei-daemon-kill lei-daemon-pid lei-edit-search lei-export-kw
+       lei-forget-external lei-forget-mail-sync lei-forget-search
+       lei-import lei-index lei-init lei-inspect lei-lcat
+       lei-ls-external lei-ls-label lei-ls-mail-source lei-ls-mail-sync
+       lei-ls-search lei-ls-watch lei-mail-diff lei-p2q lei-q
+       lei-rediff lei-refresh-mail-sync lei-rm lei-rm-watch lei-tag
+       lei-up)];
 $v->{-m5} = [ qw(public-inbox-config public-inbox-v1-format
-               public-inbox-v2-format public-inbox-extindex-format) ];
-$v->{-m7} = [ qw(lei-overview public-inbox-overview public-inbox-tuning) ];
-$v->{-m8} = [ qw(public-inbox-daemon) ];
+               public-inbox-v2-format public-inbox-extindex-format
+               lei-mail-formats lei-store-format
+               ) ];
+$v->{-m7} = [ qw(lei-mail-sync-overview lei-overview lei-security
+               public-inbox-overview public-inbox-tuning
+               public-inbox-glossary) ];
+$v->{-m8} = [ qw(public-inbox-daemon lei-daemon) ];
 my @sections = (1, 5, 7, 8);
 $v->{check_80} = [];
 $v->{manuals} = [];
@@ -61,13 +73,15 @@ for my $i (@sections) {
                my $pod = "Documentation/$m.pod";
                my $txt = "Documentation/$m.txt";
                $t->{"$m.$i : $pod"} = [ "\$(podman) -s$i $pod \$@" ];
-               $t->{"$txt : $pod"} = [ "\$(podtext) $pod \$\@+",
-                                       "touch -r $pod \$\@+",
+               $t->{"$txt : $m.$i"} = [ "\$(man2text) ./$m.$i >\$\@+",
+                                       "touch -r $pod \$\@+ ./$m.$i",
                                        "mv \$\@+ \$@" ];
-               $t->{"Documentation/$m.html : $txt"} = [ "\$(txt2pre) <$txt" ];
+               $t->{"Documentation/$m.html : $txt"} = [ "\$(txt2pre) <$txt",
+                                                       "touch -r $txt \$@" ];
                $t->{".$m.cols : $m.$i"} = [
                        "\@echo CHECK80 $m.$i;".
-                       "COLUMNS=80 \$(MAN) ./$m.$i | \$(check_man)" ];
+                       "COLUMNS=80 \$(MAN) ./$m.$i | \$(check_man)",
+                       '>$@' ];
                $t->{".$m.lexgrog: $m.$i"} = [
                        "\@echo LEXGROG $m.$i;" .
                        "\$(LEXGROG) ./$m.$i >\$\@+ && mv \$\@+ \$@" ];
@@ -78,34 +92,16 @@ for my $i (@sections) {
        push @{$v->{manuals}}, @$manuals;
        push @{$v->{mantxt}}, map { "Documentation/$_.txt" } @$ary;
 }
-push @dtxt, @{$v->{mantxt}};
 $v->{docs} = [ @dtxt, 'NEWS' ];
 $v->{docs_html} = [ map {;
                my $x = $_;
                $x =~ s/\.txt\z//;
                "$x.html"
-       } @{$v->{docs}} ];
+       } (@{$v->{docs}}, @{$v->{mantxt}}) ];
 $v->{gz_docs} = [ map { "$_.gz" } (@{$v->{docs}},@{$v->{docs_html}}) ];
 $v->{rsync_docs} = [ @{$v->{gz_docs}}, @{$v->{docs}},
        @{$v->{docs_html}}, qw(NEWS.atom NEWS.atom.gz)];
 
-# 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/.$_.txt" } @xman ];
-$v->{xdocs_html} = [ map { "Documentation/.$_.html" } @xman ];
-for (@{$v->{xdocs}}) {
-       $t->{"$_:"} = [
-               '$(PERL) -w Documentation/extman.perl $@ >$@+',
-               'mv $@+ $@'
-       ];
-       my $html = $_;
-       $html =~ s/\.txt\z/.html/;
-       $t->{"$html : $_"} = [ "\$(txt2pre) <$_" ];
-}
-$v->{gz_xdocs} = [ map { "$_.gz" } (@{$v->{xdocs_html}}, @{$v->{xdocs}}) ];
-$v->{rsync_xdocs} = [ @{$v->{gz_xdocs}}, @{$v->{xdocs_html}}, @{$v->{xdocs}} ];
-
 my $TGTS = join("\n", map {;
        my $tgt_prereq = $_;
        my $cmds = $t->{$_};
@@ -135,11 +131,16 @@ WriteMakefile(
        NAME => 'PublicInbox', # n.b. camel-case is not our choice
 
        # XXX drop "PENDING" in .pod before updating this!
-       VERSION => '1.6.1',
+       VERSION => '1.9.0.PENDING',
 
-       AUTHOR => 'Eric Wong <e@80x24.org>',
-       ABSTRACT => 'public-inbox server infrastructure',
+       AUTHOR => 'public-inbox hackers <meta@public-inbox.org>',
+       ABSTRACT => 'an "archives first" approach to mailing lists',
        EXE_FILES => \@EXE_FILES,
+
+       # DO NOT blindly put "use v5.12" in *.pm files, unicode_strings
+       # causes known breakages.  "use v5.10.1" is safe, though
+       MIN_PERL_VERSION => '5.12.0',
+       LICENSE => 'agpl_3', # AGPL-3.0+, CPAN::Meta::Spec doesn't have '+'
        PREREQ_PM => {
                # note: we use spamc(1), NOT the Perl modules
                # We also depend on git.
@@ -155,11 +156,12 @@ WriteMakefile(
                'IO::Compress::Gzip' => 0,
                'IO::Uncompress::Gunzip' => 0,
                'Storable' => 0, # rpm: perl-Storable
+               'Text::ParseWords' => 0, # rpm: perl-Text-ParseWords
 
                # Plack is needed for public-inbox-httpd and PublicInbox::WWW
                # 'Plack' => 0,
 
-               'URI::Escape' => 0,
+               'URI' => 0,
 
                # We have more test dependencies, but do not force
                # users to install them.  See INSTALL
@@ -174,7 +176,18 @@ WriteMakefile(
        },
        MAN3PODS => \%man3,
        clean => {
-               FILES => 't/home1/setup* t/home1/t* t/home1/.public-inbox'
+               FILES => 't/home*/setup* t/home*/t* t/home*/.public-inbox '.
+                       't/data-gen/*'
+       },
+       PM => {
+               map {
+                       s[^lib/][]s;
+                       +('lib/' . $_ => '$(INST_LIB)/' . $_);
+               } grep {
+                       # Will include *.pod and an *.h file, but so
+                       # would ExtUtils::MakeMaker.
+                       m[^lib/];
+               } @manifest
        },
 );
 
@@ -236,13 +249,17 @@ Makefile.PL : MANIFEST
 # prefix + bindir matches git.git Makefile:
 prefix = \$(HOME)
 bindir = \$(prefix)/bin
-symlink-install :
+symlink-install : lib/PublicInbox.pm
        mkdir -p \$(bindir)
        lei=\$\$(realpath lei.sh) && cd \$(bindir) && \\
        for x in \$(EXE_FILES); do \\
                ln -sf "\$\$lei" \$\$(basename "\$\$x"); \\
        done
 
+pure_all :: lib/PublicInbox.pm
+lib/PublicInbox.pm : FORCE
+       VERSION=\$(VERSION) \$(PERL) -w ./version-gen.perl
+
 update-copyrights :
        \@case '\$(GNULIB_PATH)' in '') echo >&2 GNULIB_PATH unset; false;; esac
        git ls-files | UPDATE_COPYRIGHT_HOLDER='all contributors' \\