Provided by: libextutils-modulemaker-perl_0.63-3_all bug

NAME

       ExtUtils::ModuleMaker - Better than h2xs for creating modules

SYNOPSIS

       At the command prompt:

           %   modulemaker

       Inside a Perl program:

           use ExtUtils::ModuleMaker;

           $mod = ExtUtils::ModuleMaker->new(
               NAME => 'Sample::Module'
           );

           $mod->complete_build();

           $mod->dump_keys(qw|
               ...  # key provided as argument to constructor
               ...  # same
           |);

           $mod->dump_keys_except(qw|
               ...  # key provided as argument to constructor
               ...  # same
           |);

           $license = $mod->get_license();

           $mod->make_selections_defaults();

VERSION

       This document references version 0.63 of ExtUtils::ModuleMaker, released to CPAN on July 31 2018.

DESCRIPTION

       This module is a replacement for the most typical use of the h2xs utility bundled with all Perl
       distributions:  the creation of the directories and files required for a pure-Perl module to be
       installable with make and distributable on the Comprehensive Perl Archive Network (CPAN).

       h2xs has many options which are useful -- indeed, necessary -- for the creation of a properly structured
       distribution that includes C code as well as Perl code.  Most of the time, however, h2xs is used as
       follows

           %   h2xs -AXn My::Module

       to create a distribution containing only Perl code.  ExtUtils::ModuleMaker is intended to be an easy-to-
       use replacement for this use of h2xs.

       While you can call ExtUtils::ModuleMaker from within a Perl script (as in the SYNOPSIS above), it's
       easier to use with a command-prompt invocation of the modulemaker script bundled with this distribution:

           %   modulemaker

       Then respond to the prompts.  For Perl programmers, laziness is a virtue -- and modulemaker is far and
       away the laziest way to create a pure Perl distribution which meets all the requirements for worldwide
       distribution via CPAN.

USAGE

   Usage from the command-line with modulemaker
       The easiest way to use ExtUtils::ModuleMaker is to invoke the modulemaker script from the command-line.
       You can control the content of the files built by modulemaker either by supplying command-line options or
       -- easier still -- replying to the screen prompts in modulemaker's interactive mode.

       If you are encountering ExtUtils::ModuleMaker for the first time, you should turn now to the
       documentation for modulemaker which is bundled this distribution.  Return to this document once you have
       become familiar with modulemaker.

   Use of Public Methods within a Perl Program
       You can use ExtUtils::ModuleMaker within a Perl script to generate the directories and files needed to
       begin work on a CPAN-ready Perl distribution.  You will need to call "new()" and "complete_build()", both
       of which are described in the next section.  These two methods control the building of the file and
       directory structure for a new Perl distribution.

       There are four other publicly available methods in this version of ExtUtils::ModuleMaker.  "dump_keys",
       "dump_keys_except" and "get_license" are intended primarily as shortcuts for trouble-shooting problems
       with an ExtUtils::ModuleMaker object.  "make_selections_defaults" enables you to be even lazier in your
       use of ExtUtils::ModuleMaker by saving keystrokes entered for attributes.

       "new"

       Creates and returns an ExtUtils::ModuleMaker object.  Takes a list containing key-value pairs with
       information specifying the structure and content of the new module(s).  (In this documentation, we will
       sometimes refer to these key-value pairs as the attributes of the ExtUtils::ModuleMaker object.)  With
       the exception of key "EXTRA_MODULES" (see below), the values in these pairs are all strings.  Like most
       such lists of key-value pairs, this list is probably best held in a hash.   Keys which may be specified
       are:

       •   Required Argument

           •   NAME

               The  only  required  feature.   This is the name of the primary module (with '"::"' separators if
               needed).  Will no longer support the older, Perl 4-style separator ""'"" like  the  module  D'Oh.
               There is no current default for NAME; you must supply a name explicitly.

       •   Other Important Arguments

           •   ABSTRACT

               A  short  description  of the module.  CPAN likes to use this feature to describe the module.  If
               the abstract contains an apostrophe ("'"), then the value corresponding to key "ABSTRACT" in  the
               list  passed  to  the  constructor  must  be double-quoted; otherwise Makefile.PL gets messed up.
               Certain CPAN indexing features still work better if the abstract is 44  or  fewer  characters  in
               length, but this does not appear to be as mandatory as in the past.  (Defaults to dummy copy.)

           •   VERSION

               A  string  holding the version number.  For alpha releases, include an underscore to the right of
               the dot like "0.31_21". (Default is 0.01.)

           •   LICENSE

               Which license to include in the Copyright section.  You can choose one of the  standard  licenses
               by including 'perl', 'gpl', 'artistic', and 18 others approved by opensource.org.  The default is
               to choose the 'perl' flavor which is to share it "under the same terms as Perl itself."

               Other      licenses      can     be     added     by     individual     module     authors     to
               ExtUtils::ModuleMaker::Licenses::Local to keep your company lawyers happy.

               Some licenses include placeholders that will be replaced with AUTHOR information.

           •   BUILD_SYSTEM

               This can take one of three values:

               •   'ExtUtils::MakeMaker'

                   The first generates a basic Makefile.PL file for your module.

               •   'Module::Build'

                   The second creates a Build.PL file.

               •   'Module::Build and Proxy'

                   The third creates a Build.PL along with a proxy Makefile.PL script that attempts  to  install
                   Module::Build if necessary, and then runs the Build.PL script.  This option is recommended if
                   you  want  to  use  Module::Build  as  your build system.  See Module::Build::Compat for more
                   details.

                   Note:  To correct a discrepancy between the documentation and code  in  earlier  versions  of
                   ExtUtils::ModuleMaker, we now explicitly provide this synonym for the third option:

                       'Module::Build and proxy Makefile.PL'

                   (Thanks to David A Golden for spotting this bug.)

           •   COMPACT

               For  a  module  named  "Foo::Bar::Baz"  creates  a  base directory named "Foo-Bar-Baz" instead of
               Foo/Bar/Baz.  (Default is off.)

           •   VERBOSE

               Prints messages to STDOUT as it creates directories, writes files, etc. (Default is off.)

           •   PERMISSIONS

               Used to create new directories.  (Default is 0755:  group and world can not write.)

           •   USAGE_MESSAGE

               Message given when the module "die"s.  Scripts should set this to the same string it would  print
               if the user asked for help.  (A reasonable default is provided.)

           •   NEED_POD

               Include POD section in *.pm files created.  (Default is on.)

           •   NEED_NEW_METHOD

               Include a simple "new()" method in the *.pm files created.  (Default is on.)

           •   CHANGES_IN_POD

               Omit a Changes file, but instead add a HISTORY section to the POD.  (Default is off).

           •   INCLUDE_MANIFEST_SKIP

               Boolean  value  which, if true, includes a MANIFEST.SKIP file in the distribution with reasonable
               default values facilitating use of the make manifest command during module development.   (Thanks
               to David A Golden for this feature.  Default is off.)

           •   INCLUDE_TODO

               Boolean  value  which,  if  true,  includes a Todo file in the distribution in which the module's
               author or maintainer can discuss future lines of development.  (Default is on.)

           •   INCLUDE_LICENSE

               Boolean value which, if true, includes a LICENSE file in the distribution.  (Which  LICENSE  file
               is determined in the LICENSE option.)  (Default is on.)

           •   INCLUDE_SCRIPTS_DIRECTORY

               Boolean  value  which,  if true, includes a scripts/ directory (at the same level as lib/ or t/).
               (Default is on.)

           •   INCLUDE_WARNINGS

               Boolean value which, if true, inserts "use warnings;" in all Perl modules created by use of  this
               module.  (Default is off.)

           •   INCLUDE_ID_LINE

               Boolean  value  which, if true, inserts "#$Id$" in all Perl modules created by use of this module
               for the purpose of inserting a Subversion file 'Id' string.  (Default is off.)

       •   Arguments Related to the Module's Author

           •   AUTHOR

               Name of the author.  If the author's name contains an apostrophe ("'"),  then  the  corresponding
               value  in  the  list  passed to the constructor must be double-quoted; otherwise Makefile.PL gets
               messed up.  (Defaults to dummy copy.)

           •   EMAIL

               Email address of the author.  If the author's e-mail address contains an apostrophe  ("'"),  then
               the  corresponding  value  in the list passed to the constructor must be double-quoted; otherwise
               Makefile.PL gets messed up.  (Defaults to dummy copy.)

           •   CPANID

               The CPANID of the author.  (Defaults to dummy copy. To suppress printing of this  line  entirely,
               set "CPANID" to a Perl-false value such as an empty string.)

           •   WEBSITE

               The  personal  or  organizational  website  of  the author.  (Defaults to dummy copy. To suppress
               printing of this line entirely, set "CPANID" to a Perl-false value such as an empty string.)

           •   ORGANIZATION

               Company or group owning the module.  (Defaults to dummy copy. To suppress printing of  this  line
               entirely, set "CPANID" to a Perl-false value such as an empty string.)

       •   Argument Related to Multiple Modules within a Distribution

           •   EXTRA_MODULES

               A  reference  to  an array of hashes, each of which contains values for additional modules in the
               distribution.

                   $mod = ExtUtils::ModuleMaker->new(
                       NAME           => 'Alpha::Beta',
                       EXTRA_MODULES  => [
                           { NAME => 'Alpha::Beta::Gamma' },
                           { NAME => 'Alpha::Beta::Delta' },
                           { NAME => 'Alpha::Beta::Gamma::Epsilon' },
                       ],
                   );

               As with the primary module, the only attribute required for each extra module is  "NAME".   Other
               attributes  may  be  supplied  but  the primary module's values will be used if no value is given
               here.

               Each extra module will be created in the  correct  relative  place  in  the  lib  directory.   By
               default,  a  test file will also be created in the t directory corresponding to each extra module
               to test that it loads properly.  (See EXTRA_MODULES_SINGLE_TEST_FILE below to learn how to change
               this behavior.)  However, no other supporting documents (e.g., README, Changes) will be created.

               This is one major improvement over the earlier h2xs as you can now build multi-module packages.

       •   Arguments Related to Test Files

           •   FIRST_TEST_NUMBER

               A non-negative natural number from which the count begins in  test  files  that  are  numerically
               ordered.  (Default is 1.)

           •   TEST_NUMBER_FORMAT

               In test files that are numerically ordered, a Perl "sprintf" formatting string that specifies how
               FIRST_TEST_NUMBER is to be formatted.  (Default is "%03d".)

           •   TEST_NAME

               String forming the core of the name of a test file.  (Default is "load").

           •   TEST_NAME_DERIVED_FROM_MODULE_NAME

               Boolean  value  which,  when true, tells ExtUtils::ModuleMaker to create a file in the test suite
               with a name derived from the .pm package it is testing, thereby overriding any value set  in  the
               TEST_NAME  attribute.   For  example,  for a module called 'Alpha::Sigma::Tau', a test file named
               t/Alpha_Sigma_Tau.t will be created.  (Default is off.)

           •   TEST_NAME_SEPARATOR

               String holding the character which joins components of a test file's name,  e.g.,  the  character
               used to join 001 and <load> in a file named 001_load.t.  (Defaults to an underscore "_".)

           •   EXTRA_MODULES_SINGLE_TEST_FILE

               Boolean  value  which,  when true and when extra modules have been specified in the EXTRA_MODULES
               attribute, will put tests for those extra modules in a single test file rather than in individual
               test files corresponding to each module.  (Default is off.)

           •   INCLUDE_POD_COVERAGE_TEST

               Boolean value which, if true, causes a test file called t/pod-coverage.t to be included in the t/
               directory.  This test is advocated by some Perl quality assurance  experts  and  module  authors.
               However,  since the maintainer of ExtUtils::ModuleMaker is not persuaded of its worth, default is
               off.

           •   INCLUDE_POD_TEST

               Boolean value which, if true, causes a test  file  called  t/pod.t  to  be  included  in  the  t/
               directory.   This  test  is  advocated by some Perl quality assurance experts and module authors.
               However, since the maintainer of ExtUtils::ModuleMaker is not persuaded of its worth, default  is
               off.

           •   INCLUDE_FILE_IN_PM

               String  holding a path to a file containing Perl code and/or documentation which will be included
               in each lib/*.pm file created in a particular distribution. By default, such  content  is  placed
               after  any constructor and before the main POD block.  This could, for example, be used to insert
               stub subroutines in each package within a distribution.  Default is off.

       •   Arguments for Advanced Usages

           •   INTERACTIVE

               Activates interactive mode in modulemaker utility.  The interactive mode presents the user with a
               series of menus from which the user selects features by entering  text  at  the  command  prompt.
               This attribute should only be used by interactive scripts like modulemaker.  (Default is off.)

           •   ALT_BUILD

               Name  of  a  Perl package holding methods which override those called withiin "complete_build" to
               shape the content of files created by using ExtUtils::ModuleMaker.  See "An Alternative  Approach
               to Subclassing" below.

       "complete_build"

       Creates    all   directories   and   files   as   configured   by   the   key-value   pairs   passed   to
       "ExtUtils::ModuleMaker::new".  Returns a true value if all specified files are created -- but  this  says
       nothing about whether those files have been created with the correct content.

       "dump_keys"

       When  troubleshooting  problems  with  an  ExtUtils::ModuleMaker  object,  it  is  often  useful  to  use
       Data::Dumper to dump the contents of the object.  Use "dump_keys()" when you only need to examine  a  few
       of the object's attributes.

           $mod->dump_keys( qw| NAME ABSTRACT | );

       "dump_keys_except"

       When  troubleshooting  problems  with  an  ExtUtils::ModuleMaker  object,  it  is  often  useful  to  use
       Data::Dumper to dump the contents of the object.  However, since certain  elements  of  that  object  are
       often  quite  lengthy  (e.g, the values of keys "LicenseParts" and "USAGE_MESSAGE"), it's handy to have a
       dumper function that dumps all keys except certain designated keys.

           $mod->dump_keys_except(qw| LicenseParts USAGE_MESSAGE |);

       "get_license"

       Returns a string which nicely formats a short version of the License and Copyright information.

           $license = $mod->get_license();
           print $license;

       ... will print something like this:

           =====================================================================
           =====================================================================
           [License Information]
           =====================================================================
           =====================================================================
           [Copyright Information]
           =====================================================================
           =====================================================================

       (Earlier versions of ExtUtils::ModuleMaker contained a "Display_License" function in each  of  submodules
       ExtUtils::ModuleMaker::Licenses::Standard  and  ExtUtils::ModuleMaker::Licenses::Local.   These functions
       were never publicly documented or tested.  "get_license()" is intended as a  replacement  for  those  two
       functions.)

       "make_selections_defaults()"

       Saves  the  values  you  entered  as arguments passed to "new()" in a personal defaults file so that they
       supersede the defaults provided by ExtUtils::ModuleMaker itself.

       This is an advanced usage of ExtUtils::ModuleMaker.  If you have  used  ExtUtils::ModuleMaker  more  than
       once,  you  have  probably  typed  in  a  choice  for  "AUTHOR",  "EMAIL", etc., more than once.  To save
       unnecessary typing and reduce typing errors, ExtUtils::ModuleMaker now  offers  you  the  possibility  of
       establishing personal default values which override the default values supplied with the distribution and
       found in lib/ExtUtils/ModuleMaker/Defaults.pm.

       Suppose that you have called "ExtUtils::ModuleMaker::new()" as follows:

           $mod = ExtUtils::ModuleMaker->new(
               NAME            => 'Sample::Module',
               ABSTRACT        => 'Now is the time to join the party',
               AUTHOR          => 'Hilton Stallone',
               CPANID          => 'RAMBO',
               ORGANIZATION    => 'Parliamentary Pictures',
               WEBSITE         => 'http://parliamentarypictures.com',
               EMAIL           => 'hiltons@parliamentarypictures.com',
           );

       While $mod is still in scope, you can call:

           $mod->make_selections_defaults()

       and the values selected  -- with two important exceptions -- will be saved in a Personal/Defaults.pm file
       stored  in  your  home  directory.   The  next time you invoke ExtUtils::ModuleMaker, the new values will
       appear in the appropriate locations in the files created by "complete_build()".  They will also appear in
       the menus provided on screen by the modulemaker utility.

       What are those two important exceptions?

       •   "NAME"

           You  cannot  enter  a  default  value  for  "NAME":   the  name  of  the  module  you  are  creating.
           ExtUtil::ModuleMaker's  own defaults file omits a value for "NAME" to prevent you from overwriting an
           already  existing   module.    (More   precisely,   the   default   value   is   an   empty   string.
           ExtUtil::ModuleMaker  will  throw  an  error  if you attempt to create a module whose name is empty.)
           This precaution applies to your personal defaults file as well.

       •   "ABSTRACT"

           Since every module you create presumably has its own unique purpose, every module must have a  unique
           "ABSTRACT"  to  summarize  that  purpose.   ExtUtil::ModuleMaker supplies the following string as the
           default value for the "ABSTRACT" key:

               Module abstract (<= 44 characters) goes here

           ... a string which, not coincidentally, happens to be exactly 44 characters long -- so you  can  just
           overstrike  it.   This  will be the default value for "ABSTRACT" in any Personal/Defaults.pm file you
           create as well.

CUSTOMIZATION

       ExtUtils::ModuleMaker is designed to be customizable to your needs and to offer you more  flexibility  as
       you become more experienced with it.

   Via modulemaker Utility Interactive Mode
       As  with  everything else about ExtUtils::ModuleMaker, the easiest, laziest way to get started is via the
       modulemaker utility; see its documentation.  Suppose that you  have  entered  your  correct  name,  email
       address and website at the prompts in modulemaker's Author Menu.

         ------------------------

         modulemaker: Author Menu

             Feature       Current Value
         N - Author        'John Q Public'
         C - CPAN ID       'MODAUTHOR'
         O - Organization  'XYZ Corp.'
         W - Website       'http://public.net/~jqpublic'
         E - Email         'jqpublic@public.net'

         R - Return to main menu
         X - Exit immediately

         Please choose which feature you would like to edit:

       Why should you ever have to enter this information again?  Return to the modulemaker Main Menu ("R").

         ------------------------

         modulemaker: Main Menu

             Feature                     Current Value
         N - Name of module              ''
         S - Abstract                    'Module abstract (<= 44 characters) goes here'
         A - Author information
         L - License                     'perl'
         D - Directives
         B - Build system                'ExtUtils::MakeMaker'

         G - Generate module
         H - Generate module;
             save selections as defaults

         X - Exit immediately

         Please choose which feature you would like to edit:

       Select "H" instead of "G" to generate the distribution.  An internal call to "make_selections_defaults()"
       will  save  those  selections  in a personal defaults file and present them to you on the Author Menu the
       next time you go to use it.

   Via modulemaker Utility Command-Line Options Mode
       For simplicity, not all of ExtUtils::ModuleMaker's default values are represented on modulemaker's menus.
       Those that are not represented on those menus cannot be changed from there.  They can, however,  in  many
       cases  be  specified  as  options  passed  to  modulemaker on the command-line and automatically saved as
       personal defaults by including the "s" flag as one of those options.  If, for example, your name is 'John
       Q Public' and you want all modules you create to have compact top-level directories, you would call:

           %   modulemaker -Icsn Sample::Module -u 'John Q Public'

       A distribution with a top-level directory Sample-Module would be created.  'John Q Public'  would  appear
       in  appropriate  places  in  Sample-Module/Makefile.PL and Sample-Module/lib/Sample/Module.pm.  You could
       then throw away the entire Sample-Module directory tree.  The next time you call "modulemaker", the call

           %   modulemaker -In Second::Module

       would suffice to generate a compact top-level directory and 'John Q Public' would appear  in  appropriate
       locations instead of the dreaded 'A. U. Thor'.

   Via "ExtUtils::ModuleMaker::new()"
       In  all  cases, ExtUtils::ModuleMaker's default values can be overridden with arguments passed to "new()"
       inside   a   Perl   program.    The   overriding   can   then    be    made    permanent    by    calling
       "make_selections_defaults()".

       Suppose, for example,

       1.  that you want the files in your test suite to appear in a numerical order starting from 0 rather than
           ExtUtils::ModuleMaker's own default starting point of 1;

       2.  that  you  want  the number in the test file's name to be formatted as a two-digit string padded with
           zeroes rather than ExtUtils::ModuleMaker's own default format of a three-digit, zero-padded string;

       3.  that you want the numerical part of the test filename to be joined to the lexical  part  with  a  dot
           (".") rather than ExtUtils::ModuleMaker's own default linkage character of an underscore ("_"); and

       4.  that  you  want  the  lexical  part  of  the  test  filename to reflect the module's name rather than
           ExtUtils::ModuleMaker's default of "load".

       Your Perl program would look like this:

           #!/usr/local/bin/perl
           use strict;
           use warnings;
           use ExtUtils::ModuleMaker;

           my $mod = ExtUtils::ModuleMaker->new(
               NAME        => 'Sample::Module',
               AUTHOR      => 'John Q Public',
               COMPACT     => 1,
               FIRST_TEST_NUMBER    => 0,
               TEST_NUMBER_FORMAT   => "%02d",
               TEST_NAME_SEPARATOR  => q{.},
               TEST_NAME_DERIVED_FROM_MODULE_NAME => 1,
           );

           $mod->make_selections_defaults();

       A subsequent call to the modulemaker utility,

           %    modulemaker -In Second::Balcony::Jump

       would generate a directory tree with a compact top-level, 'John Q Public'  in  appropriate  locations  in
       Second-Balcony-Jump/Makefile.PL and Second-Balcony-Jump/lib/Second/Balcony/Jump.pm and a test file called
       Second-Balcony-Jump/t/00.Second.Balcony.Jump.t.

   Via Subclassing ExtUtils::ModuleMaker
       If  you're  a  power-user,  once you start playing with ExtUtils::ModuleMaker, you won't be able to stop.
       You'll ask yourself, "Self, if I can change the default values, why can't I change the 'boilerplate' copy
       that appears inside the files which ExtUtils::ModuleMaker creates?"

       Now, you can.  You can hack on the methods which  "ExtUtils::ModuleMaker::new()"  and  "complete_build()"
       call  internally to customize their results to your heart's desire.  The key:  build an entirely new Perl
       extension whose lib/*.pm file has methods that override the methods you need overridden -- and only those
       methods.  Follow these steps:

       1. Study ExtUtils::ModuleMaker::Defaults, ::Initializers and ::StandardText

       ExtUtils::ModuleMaker's default values are stored in lib/ExtUtils/ModuleMaker/Defaults.pm,  specifically,
       in its "default_values()" method.  Identify those values which you wish to change.

       ExtUtils::ModuleMaker's     other     internal    methods    are    found    in    two    other    files:
       /lib/ExtUtils/ModuleMaker/Initializers.pm and lib/ExtUtils/ModuleMaker/StandardText.pm.  Rule  of  thumb:
       If  an  internal method is called within "new()", it is found in ExtUtils::ModuleMaker::Initializers.  If
       it is called within "complete_build()", it is found in ExtUtils::ModuleMaker::StandardText.  Study  these
       two packages to identify the methods you wish to override.

       Hint:   If  changing a default value in ExtUtils::ModuleMaker::Defaults will achieve your objective, make
       that  change  rather  than  trying  to  override  methods   in   ExtUtils::ModuleMaker::Initializers   or
       ExtUtils::ModuleMaker::StandardText.

       Hint:   You  should probably think about overriding methods in ExtUtils::ModuleMaker::StandardText before
       overriding those in ExtUtils::ModuleMaker::Initializers.

       2. Use modulemaker to Create the Framework for a New Distribution

       You're creating a new Perl extension.  Who ya gonna call?  modulemaker, natch!  (If you have not read the
       documentation for modulemaker by this point, do so now.)

       Suppose that you've gotten on the 'Perl Best Practices' bandwagon  and  want  to  create  all  your  Perl
       extensions  in  the  style recommended by Damian Conway in the book of the same name.  Use modulemaker to
       create the framework:

           %    modulemaker -Icqn ExtUtils::ModuleMaker::PBP \
                -u 'James E Keenan' \
                -p JKEENAN \
                -o 'Perl Seminar NY' \
                -w http://search.cpan.org/~jkeenan/

       You used the "-q" option above because you do not want or need a constructor in the new package  you  are
       creating.  That package will inherit its constructor from ExtUtils::ModuleMaker.

       3. Edit the lib/*.pm File

       Open up the best text-editor at your disposal and proceed to hack:

           %    vi ExtUtils-ModuleMaker-PBP/lib/ExtUtils/ModuleMaker/PBP.pm

       Add this line near the top of the file:

           use base qw{ ExtUtils::ModuleMaker };

       so  that  ExtUtils::ModuleMaker::PBP  inherits  from ExtUtils::ModuleMaker (which, in turn, inherits from
       ExtUtils::ModuleMaker::Defaults,                 ExtUtils::ModuleMaker::Initializers                  and
       ExtUtils::ModuleMaker::StandardText).

       If  you  have  carefully studied ExtUtils::ModuleMaker::Defaults, ExtUtils::ModuleMaker::StandardText and
       Perl Best Practices, you will write methods including the following:

           sub default_values {
               my $self = shift;
               my $defaults_ref = $self->SUPER::default_values();
               $defaults_ref->{COMPACT}                        = 1;
               $defaults_ref->{FIRST_TEST_NUMBER}              = 0;
               $defaults_ref->{TEST_NUMBER_FORMAT}             = "%02d";
               $defaults_ref->{EXTRA_MODULES_SINGLE_TEST_FILE} = 1;
               $defaults_ref->{TEST_NAME_SEPARATOR}            = q{.};
               $defaults_ref->{INCLUDE_TODO}                   = 0;
               $defaults_ref->{INCLUDE_POD_COVERAGE_TEST}      = 1;
               $defaults_ref->{INCLUDE_POD_TEST}               = 1;
               return $defaults_ref;;
           }

           sub text_Makefile {
               my $self = shift;
               my $Makefile_format = q~
           use strict;
           use warnings;
           use ExtUtils::MakeMaker;

           WriteMakefile(
               NAME            => '%s',
               AUTHOR          => '%s <%s>',
               VERSION_FROM    => '%s',
               ABSTRACT_FROM   => '%s',
               PL_FILES        => {},
               PREREQ_PM    => {
                   'Test::More'    => 0,
                   'version'       => 0,
               },
               dist            => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', },
               clean           => { FILES => '%s-*' },
           );
           ~;
               my $text_of_Makefile = sprintf $Makefile_format,
                   map { my $s = $_; $s =~ s{'}{\\'}g; $s; }
                       $self->{NAME},
                       $self->{AUTHOR},
                       $self->{EMAIL},
                       $self->{FILE},
                       $self->{FILE},
                       $self->{FILE};
               return $text_of_Makefile;
           }

       Of course, for true Perl laziness, you'll use CPAN distribution  ExtUtils::ModuleMaker::PBP,  written  by
       the  author  of  ExtUtils::ModuleMaker as an exemplar of subclassing ExtUtils::ModuleMaker and generating
       the same output as Damian Conway's Module::Starter::PBP.

       4. Test

       How do you know you have correctly subclassed ExtUtils::ModuleMaker?  With a test suite, of course.  With
       careful editing, you can use many of ExtUtils::ModuleMaker's own tests in  your  new  distribution.   You
       will,  of  course,  have  to  change  a  number  of tests, because the default values implied by Conway's
       recommendations are different from ExtUtils::ModuleMaker's own defaults.  Among other  things,  you  will
       have to do a search-and-replace on all constructor calls.

           %    perl -pi'*.bak' -e 's{ExtUtils::ModuleMaker->new}{ExtUtils::ModuleMaker::PBP->new}g;'

       Of course, you should have written your tests first, right?

       5. Install and Use

       You  would  install  your  new  distribution  as you would any other Perl distribution, i.e., with either
       ExtUtils::MakeMaker or Module::Build, depending on which you chose in creating your subclass.

           #!/usr/local/bin/perl
           use strict;
           use warnings;
           use ExtUtils::ModuleMaker::PBP;

           my $mod = ExtUtils::ModuleMaker::PBP->new(
               NAME        => 'Sample::Module',
           );

           $mod->complete_build();

       For an adaptation of the modulemaker utility to work with ExtUtils::ModuleMaker::PBP, see  mmkrpbp  which
       is bundled with the latter package.

       An Alternative Approach to Subclassing

       There  is  one  other  way  to subclass to ExtUtils::ModuleMaker which bears mentioning, more because the
       author used it  in  the  development  of  this  version  of  ExtUtils::ModuleMaker  than  because  it  is
       recommended.   If  for  some  reason  you do not wish to create a full-fledged Perl distribution for your
       subclass, you can simply write the subclassing package and store it in the same  directory  hierarchy  on
       your system in which your personal defaults file is stored.

       For   example,   suppose   you   are   experimenting   and   only   wish   to   override  one  method  in
       ExtUtils::ModuleMaker::StandardText.        You       can       create       a       package       called
       ExtUtils::ModuleMaker::AlternativeText.   If  you  are working on a Unix-like system, you would move that
       file such that its path would be:

           "$ENV{HOME}/.modulemaker/ExtUtils/ModuleMaker/AlternativeText.pm"

       You would then add one argument to your call to "ExtUtils::ModuleMaker::new()":

           my $mod = ExtUtils::ModuleMaker->new(
               NAME        => 'Sample::Module',
               ALT_BUILD   => 'ExtUtils::ModuleMaker::AlternativeText',
           );

CAVEATS

       •   Require Perl 5.6.1

           Support for versions of Perl earlier than 5.6.1 was dropped in version 0.57 released in May 2018.

       •   Testing of modulemaker's Interactive Mode

           The easiest, laziest and recommended way of using  this  distribution  is  the  command-line  utility
           modulemaker,  especially its interactive mode.  However, this is necessarily the most difficult test,
           as its testing would require capturing the STDIN, STDOUT and  STDERR  for  a  process  spawned  by  a
           "system('modulemaker')" call from within a test file.  For now, the maintainer has relied on repeated
           visual inspection of the screen prompts generated by modulemaker.  With luck, Expect-based tests will
           be available in a future version.

       •   Testing modulemaker on Non-*nix-Like Operating Systems

           Since  testing the modulemaker utility from within the test suite requires a "system()" call, a clean
           test run depends in part on the way a given operating  system  parses  command-line  arguments.   The
           maintainer  has tested this on Darwin and Win32 and, thanks to a suggestion by A.  Sinan Unur, solved
           a problem on Win32.  Results on other operating systems may differ; feedback is welcome.

TO DO

       •   Tests for modulemaker's interactive mode.

       •   Possible new "USE_AS_BASE" attribute which would insert modules from which  user's  new  module  will
           inherit.

               USE_AS_BASE => [ qw|
                   Template::Toolkit
                   Module::Build
                   Lingua::Romana::Perligata
                   Acme::Buffy
               | ],

           Such        an        attribute        would        require        replacement        copy        for
           "ExtUtils::ModuleMaker::StandardText::block_begin()".

AUTHOR/MAINTAINER

       ExtUtils::ModuleMaker  was  originally  written  in  2001-02  by  R.  Geoffrey  Avery  (modulemaker  [at]
       PlatypiVentures  [dot]  com).   Since  version 0.33 (July 2005) it has been maintained by James E. Keenan
       (jkeenan [at] cpan [dot] org).

SUPPORT

       Send email to jkeenan [at] cpan [dot] org.  Please include 'modulemaker' in  the  subject  line.   Please
       report  any  bugs  or  feature  requests  to  "bug-ExtUtils-ModuleMaker@rt.cpan.org",  or through the web
       interface at <http://rt.cpan.org>.

       Development repository: <https://github.com/jkeenan/extutils-modulemaker>

ACKNOWLEDGMENTS

       Thanks first and foremost to Geoff Avery for  creating  ExtUtils::ModuleMaker  and  popularizing  it  via
       presentations I attended at YAPC::NA::2003 (Boca Raton) and YAPC::EU::2003 (Paris).

       Soon after I took over maintenance of ExtUtils::ModuleMaker, David A Golden became a driving force in its
       ongoing development, providing suggestions for additional functionality as well as bug reports.  David is
       the  author  of  ExtUtils::ModuleMaker::TT  which,  while  not  a pure subclass of ExtUtils::ModuleMaker,
       extends its functionality for users of Template::Toolkit.

       Thanks for suggestions about testing the modulemaker utility to Michael G Schwern on perl.qa and A  Sinan
       Unur  and  Paul Lalli on comp.lang.perl.misc.  Thanks for help in dealing with a nasty bug in the testing
       to Perlmonks davidrw and tlm.  That well known Perl hacker,  Anonymous  Guest,  contributed  another  bug
       report  on rt.cpan.org.

       As  development  proceeded,  several  issues were clarified by members of Perlmonks.org.  CountZero, xdg,
       Tanktalus, holli, TheDamian and nothingmuch made particularly useful suggestions, as did Brian Clarkson.

       Thanks also go to the following beta testers:  Alex Gill, Marc Prewitt, Scott Godin, Reinhard  Urban  and
       imacat.

       Version 0.39 of ExtUtils::ModuleMaker encountered spurious testing failure reports from testers.cpan.org.
       These  were  eventually  diagnosed  as  being  due to bugs in the automated testing programs and/or their
       operating environments on different systems -- i.e., to problems  outside  ExtUtils::ModuleMaker  itself.
       Several Perlmonks helped investigate this problem:  chromatic, dave_the_m, randyk, and njh.

       Thanks to Paul M Sirianni for reporting bugs that led to versions 0.48 and 0.51.

       Thanks  to Chris Kirke for pointing to reports at http://cpants.cpanauthors.org/dist/ExtUtils-ModuleMaker
       of inconsistent $VERSION numbers across the component files.

COPYRIGHT

       Copyright (c) 2001-2002 R. Geoffrey Avery.  Revisions from v0.33 forward (c) 2005-2015 James  E.  Keenan.
       All  rights  reserved.  This program is free software; you can redistribute it and/or modify it under the
       same terms as Perl itself.

       The full text of the license can be found in the LICENSE file included with this module.

DISCLAIMER OF WARRANTY

       BECAUSE THIS SOFTWARE IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE SOFTWARE,  TO  THE  EXTENT
       PERMITTED  BY  APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER
       PARTIES PROVIDE THE SOFTWARE "AS  IS"  WITHOUT  WARRANTY  OF  ANY  KIND,  EITHER  EXPRESSED  OR  IMPLIED,
       INCLUDING,  BUT  NOT  LIMITED  TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
       PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF  THE  SOFTWARE  IS  WITH  YOU.  SHOULD  THE
       SOFTWARE PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR, OR CORRECTION.

       IN  NO  EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY
       OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE SOFTWARE AS PERMITTED BY THE ABOVE LICENCE, BE  LIABLE
       TO  YOU  FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF
       THE USE OR INABILITY TO USE THE SOFTWARE (INCLUDING BUT NOT  LIMITED  TO  LOSS  OF  DATA  OR  DATA  BEING
       RENDERED  INACCURATE  OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE SOFTWARE TO OPERATE
       WITH ANY OTHER SOFTWARE), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF  SUCH
       DAMAGES.

SEE ALSO

       modulemaker,    perlnewmod,   h2xs,   ExtUtils::MakeMaker,   Module::Build,   ExtUtils::ModuleMaker::PBP,
       ExtUtils::ModuleMaker::TT, mmkrpbp.

perl v5.36.0                                       2023-01-27                         ExtUtils::ModuleMaker(3pm)