######################################################################
    Perl::Configure 0.08
######################################################################

NAME
    Perl::Configure - Answer perl's ./Configure questions reproducibly

SYNOPSIS
          # Command line:
      $ perl-configure threads=y

          # Perl
      use Perl::Configure;

      my $configurator = Perl::Configure->new();

          # Override certain default settings
      $configurator->define( "threads"     => 'y', 
                             "perlio"      => 'n',
                           );

      $configurator->run();

DESCRIPTION
    Compling perl requires a number of configuration steps. Running
    "./Configure" in a perl source distribution configures it for
    compilation on a given platform. It asks about a hundred questions and
    then creates a "config.sh" file, which will later be used to create a
    makefile.

    However, some answers cause several entries in "config.sh" to be
    modified. For example, if you say you want a threaded perl, "Configure"
    will modify 94 different values in "config.sh".

    Perl::Configure to the rescue: It runs Configure, recognizes its
    questions, fills in preprogrammed answers and gives default answers
    otherwise. Perl::Configure is most useful for automatically reproducing
    perl builds with slight modifications.

    For example, to create a threaded perl with ithreads, use this:

        my $cfg = Perl::Configure->new();
        $cfg->define( "threads"  => 'y', 
                      "ithreads" => 'y',
                    );
        $cfg->run();

    This will go quickly through all the questions Configure throws at the
    user, press 'Enter' on pretty much all of them to accept the defaults,
    and will only answer 'y' to the questions

        Build a threading Perl?

    and

        Use the newer interpreter-based ithreads?

    which will then cause 94 variables to be set by Configure in
    "config.sh". Modifying "config.sh" in this case would be a hopeless
    undertaking. While "./Configure" will (almost) always generate a
    "config.sh" file that can be used later to build perl successfully, a
    hand-edited "config.sh" file is not guaranteed to work.

    Note that in most cases you can use "Configure"'s command line options
    to accomplish the same thing:

        ./Configure -Dthreads=y -d

    However, this means you have to look at the "Configure" code and figure
    out which setting corresponds to the question.

    The mapping between a Perl::Configure token (like "threads") and the
    corresponding question (like "Build a threading Perl?") is defined in
    "Perl::Configure::Questions". If "Perl::Configure::Questions" doesn't
    define a pattern to recognize a question Configure asks, the run()
    method will hang and time out after 60 seconds. If you see this, please
    send the question to the module maintainer (see below) to have it added
    to the existing collection and the next release of "Perl::Configure".

    Here's the list of the mappings defined in this release:

        .-----------------------------------------------------------.
        | Token                     | Question                      |
        +---------------------------+-------------------------------+
        | 64-bit-integers           | Try to use 64-bit integers,   |
        |                           | if available?                 |
        | 64-bit-support            | Try to use maximal 64-bit     |
        |                           | support, if available?        |
        | arch                      | What is your architecture     |
        |                           | name                          |
        | build-with-mad            | Build Perl with MAD?          |
        | carriage-return           | Type carriage return to       |
        |                           | continue                      |
        | ccflags                   | Any additional cc flags?      |
        | char-size                 | What is the size of a         |
        |                           | character (in bytes)?         |
        | compiler                  | Use which C compiler?         |
        | compiler-compiler         | Which compiler compiler       |
        |                           | ANY{(byacc or yacc or bison   |
        |                           | -y)} shall I use?             |
        | compiler-flags-special    | Any special flags to pass to  |
        |                           | ANY{cc -c} to compile shared  |
        |                           | library modules?              |
        | config-sh                 | Shall I use it to set the     |
        |                           | defaults?                     |
        | config-sh-reuse           | I see a config.sh file        |
        | devel-release             | Do you really want to         |
        |                           | continue?                     |
        | dir-check                 | Use that name anyway?         |
        | dirs-additional           | Colon-separated list of       |
        |                           | additional directories for    |
        |                           | perl to search?               |
        | domain-name               | What is your domain name?     |
        | double-align              | Doubles must be aligned on a  |
        |                           | how-many-byte boundary?       |
        | dtrace                    | Support DTrace if available?  |
        | dynamic-extensions        | What extensions do you wish   |
        |                           | to load dynamically?          |
        | email                     | What is your e-mail address?  |
        | email-admin               | Perl administrator e-mail     |
        |                           | address                       |
        | extensions                | What extensions do you wish   |
        |                           | to include?                   |
        | fast-stdio                | Use the "fast stdio" if       |
        |                           | available?                    |
        | files-large               | Try to understand large       |
        |                           | files, if available?          |
        | getgroup-pointer          | What type pointer is the      |
        |                           | second argument to            |
        |                           | getgroups() and setgroups()?  |
        | gethostname-ignore        | Shall I ignore gethostname()  |
        |                           | from now on?                  |
        | host-file-yp              | Are you getting the hosts     |
        |                           | file via yellow pages?        |
        | host-name-confirm         | Your host name appears to be  |
        | inc-legacy                | List of earlier versions to   |
        |                           | include in @INC?              |
        | instructions              | Would you like to see the     |
        |                           | instructions                  |
        | ithreads                  | Use the newer                 |
        |                           | interpreter-based ithreads?   |
        | keep-reco                 | Keep the recommended value    |
        | ldflags                   | Any additional ld flags (NOT  |
        |                           | including libraries)?         |
        | lib-dirs                  | Directories to use for        |
        |                           | library searches?             |
        | lib-dynamic-create-cmd    | What command should be used   |
        |                           | to create dynamic libraries?  |
        | lib-dynamic-create-flags  | Any special flags to pass to  |
        |                           | ANY{cc} to create a           |
        |                           | dynamically loaded library?   |
        | lib-dynamic-flags         | Any special flags to pass to  |
        |                           | ANY{cc} to use dynamic        |
        |                           | linking?                      |
        | lib-extension             | What is the file extension    |
        |                           | used for shared libraries?    |
        | lib-extract-with-nm       | Shall I use ANY{/usr/bin/nm}  |
        |                           | to extract C symbols from the |
        |                           | libraries?                    |
        | libperl                   | Build a shared libperl.so     |
        | libperl-name              | What name do you want to give |
        |                           | to the shared libperl         |
        | libs                      | What libraries to use?        |
        | load-dynamic              | Do you wish to use dynamic    |
        |                           | loading?                      |
        | load-dynamic-file         | Source file to use for        |
        |                           | dynamic loading               |
        | long-doubles              | Try to use long doubles if    |
        |                           | available?                    |
        | make-depend               | Run make depend now?          |
        | malloc-perl               | Do you wish to attempt to use |
        |                           | the malloc that comes with    |
        | malloc-wrap               | Do you wish to wrap malloc    |
        |                           | calls to protect against      |
        |                           | potential overflows?          |
        | man-lib-suffix            | What suffix should be used    |
        |                           | for the perl5 library man     |
        |                           | pages?                        |
        | man-suffix                | What suffix should be used    |
        |                           | for the main Perl5 man pages? |
        | mod-dyn-ext               | What is the extension of      |
        |                           | dynamically loaded modules    |
        | modules-extra             | Install any extra modules (y  |
        |                           | or n)?                        |
        | multiplicity              | Build Perl for multiplicity?  |
        | optimizer                 | What optimizer/debugger flag  |
        |                           | should be used?               |
        | os-defaults               | Which of these apply, if any  |
        | os-name                   | Operating system name         |
        | os-version                | Operating system version?     |
        | pager                     | What pager is used on your    |
        |                           | system?                       |
        | path-addon                | Installation prefix to use    |
        |                           | for add-on modules and        |
        |                           | utilities?                    |
        | path-addon-public-exe     | Pathname where the add-on     |
        |                           | public executables should be  |
        |                           | installed?                    |
        | path-addon-public-scripts | Pathname where add-on public  |
        |                           | executable scripts should be  |
        |                           | installed?                    |
        | path-bin                  | Pathname where the public     |
        |                           | executables will reside?      |
        | path-html-lib-site        | Pathname where the            |
        |                           | site-specific library html    |
        |                           | pages should be installed     |
        | path-html-site            | Pathname where the            |
        |                           | site-specific html pages      |
        |                           | should be installed           |
        | path-install              | What installation prefix      |
        |                           | should I use for installing   |
        |                           | files?                        |
        | path-man-lib-site         | Pathname where the            |
        |                           | site-specific library manual  |
        |                           | pages should be installed?    |
        | path-man-lib-src          | Where do the perl5 library    |
        |                           | man pages (source) go?        |
        | path-man-site             | Pathname where the            |
        |                           | site-specific manual pages    |
        |                           | should be installed           |
        | path-man-src              | Where do the main Perl5       |
        |                           | manual pages (source) go?     |
        | path-module-html          | Directory for the Perl5       |
        |                           | module html pages?            |
        | path-perl-html            | Directory for the main Perl5  |
        |                           | html pages?                   |
        | path-private              | Pathname where the private    |
        |                           | library files will reside?    |
        | path-public-arch          | Other username to test        |
        |                           | security of setuid scripts    |
        |                           | with?                         |
        | path-public-exe           | Where do you keep publicly    |
        |                           | executable scripts?           |
        | path-shebang              | What shall I put after the #! |
        |                           | to start up perl              |
        | path-site-specific        | Pathname for the              |
        |                           | site-specific library files?  |
        | path-site-specific-arch   | Pathname for the              |
        |                           | site-specific                 |
        |                           | architecture-dependent        |
        |                           | library files?                |
        | path-vendor-specific      | Pathname for the              |
        |                           | vendor-supplied library       |
        |                           | files?                        |
        | path-vendor-specific-arch | Pathname for vendor-supplied  |
        |                           | architecture-dependent files? |
        | path-vendor-specific-bin  | Pathname for the              |
        |                           | vendor-supplied executables   |
        |                           | directory?                    |
        | path-vendor-specific-html | Pathname for the              |
        |                           | vendor-supplied html pages?   |
        | path-vendor-specific-man1 | Pathname for the              |
        |                           | vendor-supplied manual        |
        |                           | section 1 pages?              |
        | path-vendor-specific-man3 | Pathname for the              |
        |                           | vendor-supplied manual        |
        |                           | section 3 pages?              |
        | path-vendor-specific-scri | Pathname for the              |
        | pts                       | vendor-supplied scripts       |
        |                           | directory?                    |
        | perlio                    | Use the PerlIO abstraction    |
        |                           | layer?                        |
        | prefix                    | Installation prefix to use?   |
        | previous-keep             | Keep the previous value       |
        | random-func               | Use which function to         |
        |                           | generate random numbers?      |
        | relocatable-inc           | Use relocatable @INC?         |
        | setuid-emu                | Do you want to do             |
        |                           | setuid/setgid emulation?      |
        | setuid-secure             | Does your kernel have         |
        |                           | *secure* setuid scripts?      |
        | shell-escape              | Press return or use a shell   |
        |                           | escape to edit config.sh      |
        | socks                     | Build Perl for SOCKS?         |
        | static-extensions         | What extensions do you wish   |
        |                           | to load statically?           |
        | threads                   | Build a threading Perl?       |
        | usrbinperl                | Do you want to install perl   |
        |                           | as /usr/bin/perl              |
        | vendor-specific           | Do you want to configure      |
        |                           | vendor-specific add-on        |
        |                           | directories?                  |
        | vendor-specific-prefix    | Installation prefix to use    |
        |                           | for vendor-supplied add-ons   |
        | version-specific-only     | Do you want to install only   |
        |                           | the version-specific parts of |
        |                           | perl?                         |
        | vfork                     | Do you still want to use      |
        |                           | vfork()                       |
        '---------------------------+-------------------------------'

    Perl::Configure requires an existing perl installation with a number of
    CPAN modules (Expect amongst them), so it can't be used to bootstrap a
    machine without a fully functional perl interpreter.

EXAMPLES
    If you want to make sure that a previously generated "config.sh" file's
    content is used as a default and that any discrepancies are kept, use
    "config-sh" and "previous-keep".

        my $cfg = Perl::Configure->new();
        $cfg->define( "config-sh"     => 'y', 
                      "previous-keep" => 'y',
                    );
        $cfg->run();

    If you specify a prefix path that doesn't exist (yet), make sure to set
    "dir-check" to 'y' to answer Configure's question appropriately:

        $cfg->define( "prefix"    => '/quack', 
                      "dir-check" => 'y',
                    );

ADDING QUESTIONS
    The questions that "Perl::Configure" recognizes are stored in the
    __DATA__ section of "Perl::Configure::Questions" in YAML format. New
    releases of "Perl::Configure" might add to this section (or change its
    format, so don't rely on it, use the API instead).

    If you encounter a "Configure" question that "Perl::Configure" doesn't
    recognize (and therefore first hangs and then aborts), the best way to
    fix this is submit the question, a proposed token name and a sample
    answer to the maintainer of this module (see below). This way,
    "Perl::Configure" can be improved and other people can benefit from your
    update.

    If you want a quick fix (or need to fix something very specific to your
    platform that no one else will find useful), you can add questions to
    "Perl::Configure::Questions":

        my $questions = Perl::Configure::Questions->new();

        $questions->add( "path-frobnicate",                 # token
                         "What's your frobnication path?",  # question
                         "/frob",                           # sample answer
                       );

        my $cfg = Perl::Configure->new(questions => $questions);

        $cfg->define( "prefix"          => '/somewhere', 
                      "path-frobnicate" => '/frob',
                    );
        $cfg->run();

    If you forget to "add()" the question and the token beforehand,
    "Perl::Configure"'s "define" method would complain about an unknown
    token and die.

    There is also an optional forth parameter to override Configure's
    defaults, please check the Perl::Configure::Questions documentation for
    details.

SEE ALSO
    Perl::Configure::Questions

AUTHOR
    Mike Schilli, m@perlmeister.com, 2006

COPYRIGHT AND LICENSE
    Copyright (C) 2006 by Mike Schilli

    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself, either Perl version 5.8.5 or, at
    your option, any later version of Perl 5 you may have available.