1Module::Build(3)      User Contributed Perl Documentation     Module::Build(3)
2
3
4

NAME

6       Module::Build - Build and install Perl modules
7

SYNOPSIS

9       Standard process for building & installing modules:
10
11         perl Build.PL
12         ./Build
13         ./Build test
14         ./Build install
15
16       Or, if you're on a platform (like DOS or Windows) that doesn't require
17       the "./" notation, you can do this:
18
19         perl Build.PL
20         Build
21         Build test
22         Build install
23

DESCRIPTION

25       "Module::Build" is a system for building, testing, and installing Perl
26       modules.  It is meant to be an alternative to "ExtUtils::MakeMaker".
27       Developers may alter the behavior of the module through subclassing in
28       a much more straightforward way than with "MakeMaker".  It also does
29       not require a "make" on your system - most of the "Module::Build" code
30       is pure-perl and written in a very cross-platform way.
31
32       See "MOTIVATIONS" for more comparisons between "ExtUtils::MakeMaker"
33       and "Module::Build".
34
35       To install "Module::Build", and any other module that uses
36       "Module::Build" for its installation process, do the following:
37
38         perl Build.PL       # 'Build.PL' script creates the 'Build' script
39         ./Build             # Need ./ to ensure we're using this "Build" script
40         ./Build test        # and not another one that happens to be in the PATH
41         ./Build install
42
43       This illustrates initial configuration and the running of three
44       'actions'.  In this case the actions run are 'build' (the default
45       action), 'test', and 'install'.  Other actions defined so far include:
46
47         build                          manifest
48         clean                          manifest_skip
49         code                           manpages
50         config_data                    pardist
51         diff                           ppd
52         dist                           ppmdist
53         distcheck                      prereq_data
54         distclean                      prereq_report
55         distdir                        pure_install
56         distinstall                    realclean
57         distmeta                       retest
58         distsign                       skipcheck
59         disttest                       test
60         docs                           testall
61         fakeinstall                    testcover
62         help                           testdb
63         html                           testpod
64         install                        testpodcoverage
65         installdeps                    versioninstall
66
67       You can run the 'help' action for a complete list of actions.
68

GUIDE TO DOCUMENTATION

70       The documentation for "Module::Build" is broken up into sections:
71
72       General Usage (Module::Build)
73           This is the document you are currently reading. It describes basic
74           usage and background information.  Its main purpose is to assist
75           the user who wants to learn how to invoke and control
76           "Module::Build" scripts at the command line.
77
78       Authoring Reference (Module::Build::Authoring)
79           This document describes the structure and organization of
80           "Module::Build", and the relevant concepts needed by authors who
81           are writing Build.PL scripts for a distribution or controlling
82           "Module::Build" processes programmatically.
83
84       API Reference (Module::Build::API)
85           This is a reference to the "Module::Build" API.
86
87       Cookbook (Module::Build::Cookbook)
88           This document demonstrates how to accomplish many common tasks.  It
89           covers general command line usage and authoring of Build.PL
90           scripts.  Includes working examples.
91

ACTIONS

93       There are some general principles at work here.  First, each task when
94       building a module is called an "action".  These actions are listed
95       above; they correspond to the building, testing, installing, packaging,
96       etc., tasks.
97
98       Second, arguments are processed in a very systematic way.  Arguments
99       are always key=value pairs.  They may be specified at "perl Build.PL"
100       time (i.e. "perl Build.PL destdir=/my/secret/place"), in which case
101       their values last for the lifetime of the "Build" script.  They may
102       also be specified when executing a particular action (i.e.  "Build test
103       verbose=1"), in which case their values last only for the lifetime of
104       that command.  Per-action command line parameters take precedence over
105       parameters specified at "perl Build.PL" time.
106
107       The build process also relies heavily on the "Config.pm" module.  If
108       the user wishes to override any of the values in "Config.pm", she may
109       specify them like so:
110
111         perl Build.PL --config cc=gcc --config ld=gcc
112
113       The following build actions are provided by default.
114
115       build
116           [version 0.01]
117
118           If you run the "Build" script without any arguments, it runs the
119           "build" action, which in turn runs the "code" and "docs" actions.
120
121           This is analogous to the "MakeMaker" make all target.
122
123       clean
124           [version 0.01]
125
126           This action will clean up any files that the build process may have
127           created, including the "blib/" directory (but not including the
128           "_build/" directory and the "Build" script itself).
129
130       code
131           [version 0.20]
132
133           This action builds your code base.
134
135           By default it just creates a "blib/" directory and copies any ".pm"
136           and ".pod" files from your "lib/" directory into the "blib/"
137           directory.  It also compiles any ".xs" files from "lib/" and places
138           them in "blib/".  Of course, you need a working C compiler
139           (probably the same one that built perl itself) for the compilation
140           to work properly.
141
142           The "code" action also runs any ".PL" files in your lib/ directory.
143           Typically these create other files, named the same but without the
144           ".PL" ending.  For example, a file lib/Foo/Bar.pm.PL could create
145           the file lib/Foo/Bar.pm.  The ".PL" files are processed first, so
146           any ".pm" files (or other kinds that we deal with) will get copied
147           correctly.
148
149       config_data
150           [version 0.26]
151
152           ...
153
154       diff
155           [version 0.14]
156
157           This action will compare the files about to be installed with their
158           installed counterparts.  For .pm and .pod files, a diff will be
159           shown (this currently requires a 'diff' program to be in your
160           PATH).  For other files like compiled binary files, we simply
161           report whether they differ.
162
163           A "flags" parameter may be passed to the action, which will be
164           passed to the 'diff' program.  Consult your 'diff' documentation
165           for the parameters it will accept - a good one is "-u":
166
167             ./Build diff flags=-u
168
169       dist
170           [version 0.02]
171
172           This action is helpful for module authors who want to package up
173           their module for source distribution through a medium like CPAN.
174           It will create a tarball of the files listed in MANIFEST and
175           compress the tarball using GZIP compression.
176
177           By default, this action will use the "Archive::Tar" module.
178           However, you can force it to use binary "tar" and "gzip"
179           executables by supplying an explicit "tar" (and optional "gzip")
180           parameter:
181
182             ./Build dist --tar C:\path\to\tar.exe --gzip C:\path\to\zip.exe
183
184       distcheck
185           [version 0.05]
186
187           Reports which files are in the build directory but not in the
188           MANIFEST file, and vice versa.  (See manifest for details.)
189
190       distclean
191           [version 0.05]
192
193           Performs the 'realclean' action and then the 'distcheck' action.
194
195       distdir
196           [version 0.05]
197
198           Creates a "distribution directory" named "$dist_name-$dist_version"
199           (if that directory already exists, it will be removed first), then
200           copies all the files listed in the MANIFEST file to that directory.
201           This directory is what the distribution tarball is created from.
202
203       distinstall
204           [version 0.37]
205
206           Performs the 'distdir' action, then switches into that directory
207           and runs a "perl Build.PL", followed by the 'build' and 'install'
208           actions in that directory.  Use PERL_MB_OPT or .modulebuildrc to
209           set options that should be applied during subprocesses
210
211       distmeta
212           [version 0.21]
213
214           Creates the META.yml file that describes the distribution.
215
216           META.yml is a file containing various bits of metadata about the
217           distribution.  The metadata includes the distribution name,
218           version, abstract, prerequisites, license, and various other data
219           about the distribution.  This file is created as META.yml in a
220           simplified YAML format.
221
222           META.yml file must also be listed in MANIFEST - if it's not, a
223           warning will be issued.
224
225           The current version of the META.yml specification can be found on
226           CPAN as CPAN::Meta::Spec.
227
228       distsign
229           [version 0.16]
230
231           Uses "Module::Signature" to create a SIGNATURE file for your
232           distribution, and adds the SIGNATURE file to the distribution's
233           MANIFEST.
234
235       disttest
236           [version 0.05]
237
238           Performs the 'distdir' action, then switches into that directory
239           and runs a "perl Build.PL", followed by the 'build' and 'test'
240           actions in that directory.  Use PERL_MB_OPT or .modulebuildrc to
241           set options that should be applied during subprocesses
242
243       docs
244           [version 0.20]
245
246           This will generate documentation (e.g. Unix man pages and HTML
247           documents) for any installable items under blib/ that contain POD.
248           If there are no "bindoc" or "libdoc" installation targets defined
249           (as will be the case on systems that don't support Unix manpages)
250           no action is taken for manpages.  If there are no "binhtml" or
251           "libhtml" installation targets defined no action is taken for HTML
252           documents.
253
254       fakeinstall
255           [version 0.02]
256
257           This is just like the "install" action, but it won't actually do
258           anything, it will just report what it would have done if you had
259           actually run the "install" action.
260
261       help
262           [version 0.03]
263
264           This action will simply print out a message that is meant to help
265           you use the build process.  It will show you a list of available
266           build actions too.
267
268           With an optional argument specifying an action name (e.g. "Build
269           help test"), the 'help' action will show you any POD documentation
270           it can find for that action.
271
272       html
273           [version 0.26]
274
275           This will generate HTML documentation for any binary or library
276           files under blib/ that contain POD.  The HTML documentation will
277           only be installed if the install paths can be determined from
278           values in "Config.pm".  You can also supply or override install
279           paths on the command line by specifying "install_path" values for
280           the "binhtml" and/or "libhtml" installation targets.
281
282           With an optional "html_links" argument set to a false value, you
283           can skip the search for other documentation to link to, because
284           that can waste a lot of time if there aren't any links to generate
285           anyway:
286
287             ./Build html --html_links 0
288
289       install
290           [version 0.01]
291
292           This action will use "ExtUtils::Install" to install the files from
293           "blib/" into the system.  See "INSTALL PATHS" for details about how
294           Module::Build determines where to install things, and how to
295           influence this process.
296
297           If you want the installation process to look around in @INC for
298           other versions of the stuff you're installing and try to delete it,
299           you can use the "uninst" parameter, which tells "ExtUtils::Install"
300           to do so:
301
302             ./Build install uninst=1
303
304           This can be a good idea, as it helps prevent multiple versions of a
305           module from being present on your system, which can be a confusing
306           situation indeed.
307
308       installdeps
309           [version 0.36]
310
311           This action will use the "cpan_client" parameter as a command to
312           install missing prerequisites.  You will be prompted whether to
313           install optional dependencies.
314
315           The "cpan_client" option defaults to 'cpan' but can be set as an
316           option or in .modulebuildrc.  It must be a shell command that takes
317           a list of modules to install as arguments (e.g. 'cpanp -i' for
318           CPANPLUS).  If the program part is a relative path (e.g. 'cpan' or
319           'cpanp'), it will be located relative to the perl program that
320           executed Build.PL.
321
322             /opt/perl/5.8.9/bin/perl Build.PL
323             ./Build installdeps --cpan_client 'cpanp -i'
324             # installs to 5.8.9
325
326       manifest
327           [version 0.05]
328
329           This is an action intended for use by module authors, not people
330           installing modules.  It will bring the MANIFEST up to date with the
331           files currently present in the distribution.  You may use a
332           MANIFEST.SKIP file to exclude certain files or directories from
333           inclusion in the MANIFEST.  MANIFEST.SKIP should contain a bunch of
334           regular expressions, one per line.  If a file in the distribution
335           directory matches any of the regular expressions, it won't be
336           included in the MANIFEST.
337
338           The following is a reasonable MANIFEST.SKIP starting point, you can
339           add your own stuff to it:
340
341             ^_build
342             ^Build$
343             ^blib
344             ~$
345             \.bak$
346             ^MANIFEST\.SKIP$
347             CVS
348
349           See the distcheck and skipcheck actions if you want to find out
350           what the "manifest" action would do, without actually doing
351           anything.
352
353       manifest_skip
354           [version 0.3608]
355
356           This is an action intended for use by module authors, not people
357           installing modules.  It will generate a boilerplate MANIFEST.SKIP
358           file if one does not already exist.
359
360       manpages
361           [version 0.28]
362
363           This will generate man pages for any binary or library files under
364           blib/ that contain POD.  The man pages will only be installed if
365           the install paths can be determined from values in "Config.pm".
366           You can also supply or override install paths by specifying there
367           values on the command line with the "bindoc" and "libdoc"
368           installation targets.
369
370       pardist
371           [version 0.2806]
372
373           Generates a PAR binary distribution for use with PAR or PAR::Dist.
374
375           It requires that the PAR::Dist module (version 0.17 and up) is
376           installed on your system.
377
378       ppd [version 0.20]
379
380           Build a PPD file for your distribution.
381
382           This action takes an optional argument "codebase" which is used in
383           the generated PPD file to specify the (usually relative) URL of the
384           distribution.  By default, this value is the distribution name
385           without any path information.
386
387           Example:
388
389             ./Build ppd --codebase "MSWin32-x86-multi-thread/Module-Build-0.21.tar.gz"
390
391       ppmdist
392           [version 0.23]
393
394           Generates a PPM binary distribution and a PPD description file.
395           This action also invokes the "ppd" action, so it can accept the
396           same "codebase" argument described under that action.
397
398           This uses the same mechanism as the "dist" action to tar & zip its
399           output, so you can supply "tar" and/or "gzip" parameters to affect
400           the result.
401
402       prereq_data
403           [version 0.32]
404
405           This action prints out a Perl data structure of all prerequisites
406           and the versions required.  The output can be loaded again using
407           "eval()".  This can be useful for external tools that wish to query
408           a Build script for prerequisites.
409
410       prereq_report
411           [version 0.28]
412
413           This action prints out a list of all prerequisites, the versions
414           required, and the versions actually installed.  This can be useful
415           for reviewing the configuration of your system prior to a build, or
416           when compiling data to send for a bug report.
417
418       pure_install
419           [version 0.28]
420
421           This action is identical to the "install" action.  In the future,
422           though, when "install" starts writing to the file
423           $(INSTALLARCHLIB)/perllocal.pod, "pure_install" won't, and that
424           will be the only difference between them.
425
426       realclean
427           [version 0.01]
428
429           This action is just like the "clean" action, but also removes the
430           "_build" directory and the "Build" script.  If you run the
431           "realclean" action, you are essentially starting over, so you will
432           have to re-create the "Build" script again.
433
434       retest
435           [version 0.2806]
436
437           This is just like the "test" action, but doesn't actually build the
438           distribution first, and doesn't add blib/ to the load path, and
439           therefore will test against a previously installed version of the
440           distribution.  This can be used to verify that a certain installed
441           distribution still works, or to see whether newer versions of a
442           distribution still pass the old regression tests, and so on.
443
444       skipcheck
445           [version 0.05]
446
447           Reports which files are skipped due to the entries in the
448           MANIFEST.SKIP file (See manifest for details)
449
450       test
451           [version 0.01]
452
453           This will use "Test::Harness" or "TAP::Harness" to run any
454           regression tests and report their results. Tests can be defined in
455           the standard places: a file called "test.pl" in the top-level
456           directory, or several files ending with ".t" in a "t/" directory.
457
458           If you want tests to be 'verbose', i.e. show details of test
459           execution rather than just summary information, pass the argument
460           "verbose=1".
461
462           If you want to run tests under the perl debugger, pass the argument
463           "debugger=1".
464
465           If you want to have Module::Build find test files with different
466           file name extensions, pass the "test_file_exts" argument with an
467           array of extensions, such as "[qw( .t .s .z )]".
468
469           If you want test to be run by "TAP::Harness", rather than
470           "Test::Harness", pass the argument "tap_harness_args" as an array
471           reference of arguments to pass to the TAP::Harness constructor.
472
473           In addition, if a file called "visual.pl" exists in the top-level
474           directory, this file will be executed as a Perl script and its
475           output will be shown to the user.  This is a good place to put
476           speed tests or other tests that don't use the "Test::Harness"
477           format for output.
478
479           To override the choice of tests to run, you may pass a "test_files"
480           argument whose value is a whitespace-separated list of test scripts
481           to run.  This is especially useful in development, when you only
482           want to run a single test to see whether you've squashed a certain
483           bug yet:
484
485             ./Build test --test_files t/something_failing.t
486
487           You may also pass several "test_files" arguments separately:
488
489             ./Build test --test_files t/one.t --test_files t/two.t
490
491           or use a "glob()"-style pattern:
492
493             ./Build test --test_files 't/01-*.t'
494
495       testall
496           [version 0.2807]
497
498           [Note: the 'testall' action and the code snippets below are
499           currently in alpha stage, see
500           "/www.nntp.perl.org/group/perl.module.build/2007/03/msg584.html""
501           in "http: ]
502
503           Runs the "test" action plus each of the "test$type" actions defined
504           by the keys of the "test_types" parameter.
505
506           Currently, you need to define the ACTION_test$type method yourself
507           and enumerate them in the test_types parameter.
508
509             my $mb = Module::Build->subclass(
510               code => q(
511                 sub ACTION_testspecial { shift->generic_test(type => 'special'); }
512                 sub ACTION_testauthor  { shift->generic_test(type => 'author'); }
513               )
514             )->new(
515               ...
516               test_types  => {
517                 special => '.st',
518                 author  => ['.at', '.pt' ],
519               },
520               ...
521
522       testcover
523           [version 0.26]
524
525           Runs the "test" action using "Devel::Cover", generating a code-
526           coverage report showing which parts of the code were actually
527           exercised during the tests.
528
529           To pass options to "Devel::Cover", set the $DEVEL_COVER_OPTIONS
530           environment variable:
531
532             DEVEL_COVER_OPTIONS=-ignore,Build ./Build testcover
533
534       testdb
535           [version 0.05]
536
537           This is a synonym for the 'test' action with the "debugger=1"
538           argument.
539
540       testpod
541           [version 0.25]
542
543           This checks all the files described in the "docs" action and
544           produces "Test::Harness"-style output.  If you are a module author,
545           this is useful to run before creating a new release.
546
547       testpodcoverage
548           [version 0.28]
549
550           This checks the pod coverage of the distribution and produces
551           "Test::Harness"-style output. If you are a module author, this is
552           useful to run before creating a new release.
553
554       versioninstall
555           [version 0.16]
556
557           ** Note: since "only.pm" is so new, and since we just recently
558           added support for it here too, this feature is to be considered
559           experimental. **
560
561           If you have the "only.pm" module installed on your system, you can
562           use this action to install a module into the version-specific
563           library trees.  This means that you can have several versions of
564           the same module installed and "use" a specific one like this:
565
566             use only MyModule => 0.55;
567
568           To override the default installation libraries in "only::config",
569           specify the "versionlib" parameter when you run the "Build.PL"
570           script:
571
572             perl Build.PL --versionlib /my/version/place/
573
574           To override which version the module is installed as, specify the
575           "version" parameter when you run the "Build.PL" script:
576
577             perl Build.PL --version 0.50
578
579           See the "only.pm" documentation for more information on version-
580           specific installs.
581

OPTIONS

583   Command Line Options
584       The following options can be used during any invocation of "Build.PL"
585       or the Build script, during any action.  For information on other
586       options specific to an action, see the documentation for the respective
587       action.
588
589       NOTE: There is some preliminary support for options to use the more
590       familiar long option style.  Most options can be preceded with the "--"
591       long option prefix, and the underscores changed to dashes (e.g.
592       "--use-rcfile").  Additionally, the argument to boolean options is
593       optional, and boolean options can be negated by prefixing them with
594       "no" or "no-" (e.g. "--noverbose" or "--no-verbose").
595
596       quiet
597           Suppress informative messages on output.
598
599       verbose
600           Display extra information about the Build on output.  "verbose"
601           will turn off "quiet"
602
603       cpan_client
604           Sets the "cpan_client" command for use with the "installdeps"
605           action.  See "installdeps" for more details.
606
607       use_rcfile
608           Load the ~/.modulebuildrc option file.  This option can be set to
609           false to prevent the custom resource file from being loaded.
610
611       allow_mb_mismatch
612           Suppresses the check upon startup that the version of Module::Build
613           we're now running under is the same version that was initially
614           invoked when building the distribution (i.e. when the "Build.PL"
615           script was first run).  As of 0.3601, a mismatch results in a
616           warning instead of a fatal error, so this option effectively just
617           suppresses the warning.
618
619       debug
620           Prints Module::Build debugging information to STDOUT, such as a
621           trace of executed build actions.
622
623   Default Options File (.modulebuildrc)
624       [version 0.28]
625
626       When Module::Build starts up, it will look first for a file,
627       $ENV{HOME}/.modulebuildrc.  If it's not found there, it will look in
628       the .modulebuildrc file in the directories referred to by the
629       environment variables "HOMEDRIVE" + "HOMEDIR", "USERPROFILE",
630       "APPDATA", "WINDIR", "SYS$LOGIN".  If the file exists, the options
631       specified there will be used as defaults, as if they were typed on the
632       command line.  The defaults can be overridden by specifying new values
633       on the command line.
634
635       The action name must come at the beginning of the line, followed by any
636       amount of whitespace and then the options.  Options are given the same
637       as they would be on the command line.  They can be separated by any
638       amount of whitespace, including newlines, as long there is whitespace
639       at the beginning of each continued line.  Anything following a hash
640       mark ("#") is considered a comment, and is stripped before parsing.  If
641       more than one line begins with the same action name, those lines are
642       merged into one set of options.
643
644       Besides the regular actions, there are two special pseudo-actions: the
645       key "*" (asterisk) denotes any global options that should be applied to
646       all actions, and the key 'Build_PL' specifies options to be applied
647       when you invoke "perl Build.PL".
648
649         *           verbose=1   # global options
650         diff        flags=-u
651         install     --install_base /home/ken
652                     --install_path html=/home/ken/docs/html
653         installdeps --cpan_client 'cpanp -i'
654
655       If you wish to locate your resource file in a different location, you
656       can set the environment variable "MODULEBUILDRC" to the complete
657       absolute path of the file containing your options.
658
659   Environment variables
660       MODULEBUILDRC
661           [version 0.28]
662
663           Specifies an alternate location for a default options file as
664           described above.
665
666       PERL_MB_OPT
667           [version 0.36]
668
669           Command line options that are applied to Build.PL or any Build
670           action.  The string is split as the shell would (e.g. whitespace)
671           and the result is prepended to any actual command-line arguments.
672

INSTALL PATHS

674       [version 0.19]
675
676       When you invoke Module::Build's "build" action, it needs to figure out
677       where to install things.  The nutshell version of how this works is
678       that default installation locations are determined from Config.pm, and
679       they may be overridden by using the "install_path" parameter.  An
680       "install_base" parameter lets you specify an alternative installation
681       root like /home/foo, and a "destdir" lets you specify a temporary
682       installation directory like /tmp/install in case you want to create
683       bundled-up installable packages.
684
685       Natively, Module::Build provides default installation locations for the
686       following types of installable items:
687
688       lib Usually pure-Perl module files ending in .pm.
689
690       arch
691           "Architecture-dependent" module files, usually produced by
692           compiling XS, Inline, or similar code.
693
694       script
695           Programs written in pure Perl.  In order to improve reuse, try to
696           make these as small as possible - put the code into modules
697           whenever possible.
698
699       bin "Architecture-dependent" executable programs, i.e. compiled C code
700           or something.  Pretty rare to see this in a perl distribution, but
701           it happens.
702
703       bindoc
704           Documentation for the stuff in "script" and "bin".  Usually
705           generated from the POD in those files.  Under Unix, these are
706           manual pages belonging to the 'man1' category.
707
708       libdoc
709           Documentation for the stuff in "lib" and "arch".  This is usually
710           generated from the POD in .pm files.  Under Unix, these are manual
711           pages belonging to the 'man3' category.
712
713       binhtml
714           This is the same as "bindoc" above, but applies to HTML documents.
715
716       libhtml
717           This is the same as "libdoc" above, but applies to HTML documents.
718
719       Four other parameters let you control various aspects of how
720       installation paths are determined:
721
722       installdirs
723           The default destinations for these installable things come from
724           entries in your system's "Config.pm".  You can select from three
725           different sets of default locations by setting the "installdirs"
726           parameter as follows:
727
728                                     'installdirs' set to:
729                              core          site                vendor
730
731                         uses the following defaults from Config.pm:
732
733             lib     => installprivlib  installsitelib      installvendorlib
734             arch    => installarchlib  installsitearch     installvendorarch
735             script  => installscript   installsitescript   installvendorscript
736             bin     => installbin      installsitebin      installvendorbin
737             bindoc  => installman1dir  installsiteman1dir  installvendorman1dir
738             libdoc  => installman3dir  installsiteman3dir  installvendorman3dir
739             binhtml => installhtml1dir installsitehtml1dir installvendorhtml1dir [*]
740             libhtml => installhtml3dir installsitehtml3dir installvendorhtml3dir [*]
741
742             * Under some OS (eg. MSWin32) the destination for HTML documents is
743               determined by the C<Config.pm> entry C<installhtmldir>.
744
745           The default value of "installdirs" is "site".  If you're creating
746           vendor distributions of module packages, you may want to do
747           something like this:
748
749             perl Build.PL --installdirs vendor
750
751           or
752
753             ./Build install --installdirs vendor
754
755           If you're installing an updated version of a module that was
756           included with perl itself (i.e. a "core module"), then you may set
757           "installdirs" to "core" to overwrite the module in its present
758           location.
759
760           (Note that the 'script' line is different from "MakeMaker" -
761           unfortunately there's no such thing as "installsitescript" or
762           "installvendorscript" entry in "Config.pm", so we use the
763           "installsitebin" and "installvendorbin" entries to at least get the
764           general location right.  In the future, if "Config.pm" adds some
765           more appropriate entries, we'll start using those.)
766
767       install_path
768           Once the defaults have been set, you can override them.
769
770           On the command line, that would look like this:
771
772             perl Build.PL --install_path lib=/foo/lib --install_path arch=/foo/lib/arch
773
774           or this:
775
776             ./Build install --install_path lib=/foo/lib --install_path arch=/foo/lib/arch
777
778       install_base
779           You can also set the whole bunch of installation paths by supplying
780           the "install_base" parameter to point to a directory on your
781           system.  For instance, if you set "install_base" to "/home/ken" on
782           a Linux system, you'll install as follows:
783
784             lib     => /home/ken/lib/perl5
785             arch    => /home/ken/lib/perl5/i386-linux
786             script  => /home/ken/bin
787             bin     => /home/ken/bin
788             bindoc  => /home/ken/man/man1
789             libdoc  => /home/ken/man/man3
790             binhtml => /home/ken/html
791             libhtml => /home/ken/html
792
793           Note that this is different from how "MakeMaker"'s "PREFIX"
794           parameter works.  "install_base" just gives you a default layout
795           under the directory you specify, which may have little to do with
796           the "installdirs=site" layout.
797
798           The exact layout under the directory you specify may vary by system
799           - we try to do the "sensible" thing on each platform.
800
801       destdir
802           If you want to install everything into a temporary directory first
803           (for instance, if you want to create a directory tree that a
804           package manager like "rpm" or "dpkg" could create a package from),
805           you can use the "destdir" parameter:
806
807             perl Build.PL --destdir /tmp/foo
808
809           or
810
811             ./Build install --destdir /tmp/foo
812
813           This will effectively install to "/tmp/foo/$sitelib",
814           "/tmp/foo/$sitearch", and the like, except that it will use
815           "File::Spec" to make the pathnames work correctly on whatever
816           platform you're installing on.
817
818       prefix
819           Provided for compatibility with "ExtUtils::MakeMaker"'s PREFIX
820           argument.  "prefix" should be used when you want Module::Build to
821           install your modules, documentation, and scripts in the same place
822           as "ExtUtils::MakeMaker"'s PREFIX mechanism.
823
824           The following are equivalent.
825
826               perl Build.PL --prefix /tmp/foo
827               perl Makefile.PL PREFIX=/tmp/foo
828
829           Because of the complex nature of the prefixification logic, the
830           behavior of PREFIX in "MakeMaker" has changed subtly over time.
831           Module::Build's --prefix logic is equivalent to the PREFIX logic
832           found in "ExtUtils::MakeMaker" 6.30.
833
834           The maintainers of "MakeMaker" do understand the troubles with the
835           PREFIX mechanism, and added INSTALL_BASE support in version 6.31 of
836           "MakeMaker", which was released in 2006.
837
838           If you don't need to retain compatibility with old versions
839           (pre-6.31) of "ExtUtils::MakeMaker" or are starting a fresh Perl
840           installation we recommend you use "install_base" instead (and
841           "INSTALL_BASE" in "ExtUtils::MakeMaker").  See "Installing in the
842           same location as ExtUtils::MakeMaker" in Module::Build::Cookbook
843           for further information.
844

MOTIVATIONS

846       There are several reasons I wanted to start over, and not just fix what
847       I didn't like about "MakeMaker":
848
849       ·   I don't like the core idea of "MakeMaker", namely that "make"
850           should be involved in the build process.  Here are my reasons:
851
852           +   When a person is installing a Perl module, what can you assume
853               about their environment?  Can you assume they have "make"?  No,
854               but you can assume they have some version of Perl.
855
856           +   When a person is writing a Perl module for intended
857               distribution, can you assume that they know how to build a
858               Makefile, so they can customize their build process?  No, but
859               you can assume they know Perl, and could customize that way.
860
861           For years, these things have been a barrier to people getting the
862           build/install process to do what they want.
863
864       ·   There are several architectural decisions in "MakeMaker" that make
865           it very difficult to customize its behavior.  For instance, when
866           using "MakeMaker" you do "use ExtUtils::MakeMaker", but the object
867           created in "WriteMakefile()" is actually blessed into a package
868           name that's created on the fly, so you can't simply subclass
869           "ExtUtils::MakeMaker".  There is a workaround "MY" package that
870           lets you override certain "MakeMaker" methods, but only certain
871           explicitly preselected (by "MakeMaker") methods can be overridden.
872           Also, the method of customization is very crude: you have to modify
873           a string containing the Makefile text for the particular target.
874           Since these strings aren't documented, and can't be documented
875           (they take on different values depending on the platform, version
876           of perl, version of "MakeMaker", etc.), you have no guarantee that
877           your modifications will work on someone else's machine or after an
878           upgrade of "MakeMaker" or perl.
879
880       ·   It is risky to make major changes to "MakeMaker", since it does so
881           many things, is so important, and generally works.  "Module::Build"
882           is an entirely separate package so that I can work on it all I
883           want, without worrying about backward compatibility with
884           "MakeMaker".
885
886       ·   Finally, Perl is said to be a language for system administration.
887           Could it really be the case that Perl isn't up to the task of
888           building and installing software?  Even if that software is a bunch
889           of ".pm" files that just need to be copied from one place to
890           another?  My sense was that we could design a system to accomplish
891           this in a flexible, extensible, and friendly manner.  Or die
892           trying.
893

TO DO

895       The current method of relying on time stamps to determine whether a
896       derived file is out of date isn't likely to scale well, since it
897       requires tracing all dependencies backward, it runs into problems on
898       NFS, and it's just generally flimsy.  It would be better to use an MD5
899       signature or the like, if available.  See "cons" for an example.
900
901        - append to perllocal.pod
902        - add a 'plugin' functionality
903

AUTHOR

905       Ken Williams <kwilliams@cpan.org>
906
907       Development questions, bug reports, and patches should be sent to the
908       Module-Build mailing list at <module-build@perl.org>.
909
910       Bug reports are also welcome at
911       <http://rt.cpan.org/NoAuth/Bugs.html?Dist=Module-Build>.
912
913       The latest development version is available from the Git repository at
914       <https://github.com/Perl-Toolchain-Gang/Module-Build>
915
917       Copyright (c) 2001-2006 Ken Williams.  All rights reserved.
918
919       This library is free software; you can redistribute it and/or modify it
920       under the same terms as Perl itself.
921

SEE ALSO

923       perl(1), Module::Build::Cookbook, Module::Build::Authoring,
924       Module::Build::API, ExtUtils::MakeMaker
925
926       META.yml Specification: CPAN::Meta::Spec
927
928       <http://www.dsmit.com/cons/>
929
930       <http://search.cpan.org/dist/PerlBuildSystem/>
931
932
933
934perl v5.28.1                      2019-02-02                  Module::Build(3)
Impressum