2 # Copyright (C) 2013-2018 all contributors <meta@public-inbox.org>
3 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
5 use ExtUtils::MakeMaker;
6 open my $m, '<', 'MANIFEST' or die "open(MANIFEST): $!\n";
7 chomp(my @manifest = (<$m>));
8 my @EXE_FILES = grep(m!^script/!, @manifest);
9 my $PM_FILES = join(' ', grep(m!^lib/.*\.pm$!, @manifest));
11 # Don't waste user's disk space by installing some pods from
12 # imported code or internal use only
13 my %man3 = map {; # semi-colon tells Perl this is a BLOCK (and not EXPR)
17 "lib/PublicInbox/$_" => "blib/man3/PublicInbox::$mod.3"
18 } qw(Git.pm Import.pm WWW.pod);
21 NAME => 'PublicInbox',
22 VERSION => '1.1.0-pre1',
23 AUTHOR => 'Eric Wong <e@80x24.org>',
24 ABSTRACT => 'public-inbox server infrastructure',
25 EXE_FILES => \@EXE_FILES,
27 # note: we use spamc(1), NOT the Perl modules
28 # We also depend on git.
29 # Keep this sorted and synced to the INSTALL document
32 'Email::MIME::ContentType' => 0,
34 'Encode::MIME::Header' => 0,
36 # TODO: these should really be made optional...
40 # We have more test dependencies, but do not force
41 # users to install them. See INSTALL
48 # support using eatmydata to speed up tests (apt-get install eatmydata):
49 # https://www.flamingspork.com/projects/libeatmydata/
52 -include Documentation/include.mk
53 N ?= \$(shell echo \$\$(( \$\$(nproc 2>/dev/null || echo 2) + 1)))
54 SCRIPTS := scripts/ssoma-replay
55 my_syntax := \$(addsuffix .syntax, $PM_FILES \$(EXE_FILES) \$(SCRIPTS))
59 @\$(PERL) -I lib -c \$(subst .syntax,,\$@)
61 syntax:: \$(my_syntax)
63 check-manifest :: MANIFEST
64 if git ls-files >\$<.gen 2>&1; then diff -u \$< \$<.gen; fi
66 check:: pure_all check-manifest
67 \$(EATMYDATA) prove -lv -j\$(N)
69 lib/PublicInbox/UserContent.pm :: contrib/css/216dark.css
70 @\$(PERL) -I lib \$@ \$<