NAME

App::Options - combine command line options, environment vars, and option file values

SYNOPSIS

  #!/usr/local/bin/perl

  BEGIN {
      use App::Options;
      App::Options->init();  # reads into %App::options by default
  }

  print "Options:\n";
  foreach $var (sort keys %App::options) {
      printf "    %-20s => [%s]\n", $var, $App::options{$var};
  }

or a more full-featured example...

  #!/usr/local/bin/perl

  BEGIN {
      use App::Options;
      App::Options->init(
          values => \%MyPackage::some_hash,
          options => [ "option_file", "prefix", "app", "app_path_info",
                      "perlinc", "debug_options", "import", ],
          option => {
              option_file   => "~/.app/app.conf",         # set default
              app           => "default=app;type=string", # default & type
              app_path_info => {default=>"",type=>"string"}, # as a hashref
              prefix        => "type=string;required;env=PREFIX",
              perlinc       => undef,         # no default
              debug_options => "type=integer",
              import        => "type=string",
              flush_imports => 1,
          },
          no_cmd_args => 1,
          no_env_vars => 1,
          no_option_file => 1,
          print_usage => sub { my ($values, $init_options) = @_; print "Use it right!\n"; },
      );
  }

  print "Options:\n";
  foreach $var (sort keys %MyPackage::some_hash) {
      printf "    %-20s => [%s]\n", $var, $MyPkg::my_hash{$var};
  }

DESCRIPTION

App::Options combines command-line arguments, environment variables, option files, and program defaults to produce a hash of option values.

All of this may be done within the BEGIN block so that the @INC variable can be modified in time to affect "use" statements within the regular code. This is particularly important to support the installation of multiple versions of a Perl application on the same physical computer.

App::Options supports the P5EE/App-Context variant of the Perl 5 Enterprise Environment. See the P5EE web sites for more information.

http://www.officevision.com/pub/p5ee
http://p5ee.perl.org

App::Options is in its own distribution because it will be very stable and can be installed in the default perl places on the system. This is different than the App-Context, App-Repository, and App-Widget distributions which are expected to evolve significantly.

A developer writing an application based on the P5EE/App-Context framework will want to install App-Options in the default perl places. The other distributions will be installed in release-specific locations.

Methods

init()

* Signature: App::Options->init();
* Signature: App::Options->init(%named);
* Signature: App::Options->init($myvalues);
* Signature: App::Options->init($myvalues, %named);
* Param:  $myvalues     HASH
* Param:  values        HASH
* Return: void
* Throws: <none>
* Since:  0.01

Sample Usage: 

BEGIN {
    use App::Options;
    App::Options->init();
}

... or, to use every option available ...

BEGIN {
    use App::Options;
    App::Options->init(
        values => \%MyPackage::options,
        options => [ "option_file", "prefix", "app", "app_path_info",
                     "perlinc", "debug_options", "import", ],
        option => {
            option_file   => "~/.app/app.conf",         # set default
            app           => "default=app;type=string", # default & type
            app_path_info => {default=>"",type=>"string"}, # as a hashref
            prefix        => "type=string;required;env=PREFIX",
            perlinc       => undef,         # no default
            debug_options => "type=int",
            import        => "type=string",
            flush_imports => 1,
        },
        no_cmd_args => 1,
        no_env_vars => 1,
        no_option_file => 1,
        print_usage => sub { my ($values, $init_options) = @_; print "Use it right!\n"; },
    );
}

The init() method reads the command line args (@ARGV), finds an options file, and loads it, all in a way which can be done in a BEGIN block. This is important to be able to modify the @INC array so that normal "use" and "require" statements will work with the configured @INC path.

The various named parameters of the init() method are as follows.

values - specify a hash reference other than %App::options to
    put configuration values in.
options - specify a limited, ordered list of options to be
    displayed when the "--help" or "-?" options are invoked
option - specify optional additional information about any of
    the various options to the program (see below)
no_cmd_args - do not process command line arguments
no_env_vars - do not read environment variables
no_option_file - do not read in the option file
print_usage - provide an alternate print_usage() function

The additional information that can be specified about any individual option variable is as follows.

default - the default variable if none supplied on the command
    line, in an environment variable, or in an option file
required - the program will not run unless a value is provided
    for this option
type - if a value is provided, the program will not run unless
    the value matches the type ("string", "integer", "float",
    "boolean", "date", "time", "datetime", /regexp/).
description - printed next to the option in the "usage" page

The init() method stores command line options and option file values all in the global %App::options hash (unless the "values" argument specifies another reference to a hash to use). The special keys to this resulting hash are as follows.

option_file - specifies the exact file name of the option file useful
   for command line usage (i.e. "app --option_file=/path/to/app.conf")
   "option_file" is automatically set with the option file that it found
   if it is not supplied at the outset as an argument.

app - specifies the tag that will be used when searching for
   a option file. (i.e. "app --app=myapp" will search for "myapp.conf"
   before it searches for "app.conf")
   "app" is automatically set with the stem of the program file that 
   was run (or the first part of PATH_INFO) if it is not supplied at
   the outset as an argument.

app_path_info - this is the remainder of PATH_INFO after the first
   part is taken off to make the app.

prefix - This represents the base directory of the software
   installation (i.e. "/usr/myproduct/1.3.12").  If it is not
   set explicitly, it is detected from the following places:
      1. PREFIX environment variable
      2. the real path of the program with /bin or /cgi-bin stripped
      3. the current directory
   If it is autodetected from one of those three places, that is
   only provisional, in order to find the "option_file".  The "prefix"
   variable should be set authoritatively in the "option_file" if it
   is desired to be in the $values structure.

perlinc - a path of directories to prepend to the @INC search path.
   This list of directories is separated by any combination of
   [,; ] characters.

debug_options - if this is set, a variety of debug information is
   printed out during the option processing.  This helps in debugging
   which option files are being used and what the resulting variable
   values are.

import - a list of additional option files to be processed

ACKNOWLEDGEMENTS

* Author:  Stephen Adkins <stephen.adkins@officevision.com>
* License: This is free software. It is licensed under the same terms as Perl itself.

SEE ALSO