NAME

Tk::Getopt - User configuration window for Tk with interface to Getopt::Long

SYNOPSIS

    use Tk::Getopt;
    @opttable = (['opt1', '=s', 'default'], ['opt2', '!', 1], ...);
    $opt = new Tk::Getopt(-opttable => \@opttable,
                          -options => \%options,
			  -filename => "$ENV{HOME}/.options");
    $opt->load_options;
    $opt->get_options;
    $opt->process_options;
    print $options->{'opt1'}, $options->{'opt2'} ...;
    ...
    $top = new MainWindow;
    $opt->option_editor($top);

or using a Getopt::Long-like interface

    $opt = new Tk::Getopt(-getopt => ['help'   => \$HELP,
				      'file:s' => \$FILE,
				      'foo!'   => \$FOO,
				      'num:i'  => \$NO,
				     ]);

or an alternative Getopt::Long interface

    %optctl = ('foo' => \$foo,
	       'bar' => \$bar);
    $opt = new Tk::Getopt(-getopt => [\%optctl, "foo!", "bar=s"]);

DESCRIPTION

Tk::Getopt provides an interface to access command line options via Getopt::Long and editing with a graphical user interface via a Tk window.

Unlike Getopt::Long, this package uses a object oriented interface, so you have to create a new Tk::Getopt object with new. Unlike other packages in the Tk hierarchy, this package does not define a Tk widget. The graphical interface is calles by the method option_editor.

After creating an object with new, you can parse command line options by calling get_options. This method calls itself Getopt::Long::GetOptions.

METHODS

new Tk::Getopt(arg_hash)

Constructs a new object of the class Tk::Getopt. Arguments are passed in a hash (just like Tk widgets and methods). There are many variants to specify the option description. You can use an interface similar to Getopt::Long::GetOptions by using -getopt or a more powerful interface by using -opttable. Internally, the option description will be converted to the -opttable interface. One of the arguments -getopt or -opttable are mandatory.

The arguments for new are:

-getopt

-getopt should be a reference to a hash or an array. This hash has the same format as the argument to the Getopt::Long::GetOptions function. Look at Getopt::Long for a detailed description. Note also that not all of GetOptions is implemented, see BUGS for further information.

Example:

new Tk::Options(-getopt => [\%options,
                            "opt1=i", "opt2=s" ...]);
-opttable

-opttable provides a more powerful interface. The options are stored in variables named $opt_XXX or in a hash when -options is given (see below). -opttable should be a reference to an array containing all options. Elements of this array may be strings, which indicate the beginning of a new group, or array references describing the options. The first element of this array is the name of the option, the second is the type (=s for string, =i for integer, ! for boolean, =f for float etc., see Getopt::Long) for a detailed list. The third element is optional and contains the default value (otherwise the default is undefined). The fourth element is optional too and describes further attributes. It have to be a reference to a hash with following keys:

alias

An array of aliases also accepted by Getopt::Long.

label

A label to be displayed in the GUI instead of the option name.

help

A short help string used by usage and the Balloon help facility in option_editor.

longhelp

A long help string used by option_editor.

choices

An array of additional choices for the options editor.

range

An array with the beginning and end of a range for an integer or float value.

strict

Must be used with choices or range. When set to true, options have to match either the choices or the range.

var

Use variable instead of $options-{optname}> or $opt_optname to store the value.

nogui

This option will not have an entry in the GUI.

widget

This should be a reference to a subroutine for creating an own widget. Folowing arguments will be passed to this subroutine: a reference to the Tk::Getopt object, Frame object, options entry. The subroutine should create a widget in the frame (packing is not necessary!) and should return a reference to the created widget.

nosafe

Do not use a safe compartment when loading options (see load_options.

Here is an example for this rather complicated argument:

@opttable = (['debug', # name of the option (--debug)
              '!',     # type boolean, accept --nodebug
              0,       # default is 0 (false)
              {'callback' => sub { $^W = 1 
                                     if $options->{'debug'}; }
              # additional attribute: callback to be called if
              # you set or change the value
              }],
             ['age',
              '=i',    # option accepts integer value
              18,
              {'strict' => 1, # value must be in range
               'range' => [0, 100], # allowed range
               'alias' => ['year', 'years'] # possible aliases
              }],
             ['browser',
              '=s',    # option accepts string value
              'tkweb',
              {'choices' => ['mosaic', 'netscape',
                             'lynx', 'chimera'],
               # choices for the list widget in the GUI
               'label' => 'WWW browser program'
               # label for the GUI instead of 'browser'
              }],
             ['foo',
              '=f',    # option accepts float value
              undef,   # no default value
              {'help' => 'This is a short help',
               # help string for usage() and the help balloon
               'longhelp' => 'And this is a slightly longer help'
               # longer help displayed in the GUI's help window
              }]);
new Tk::Options(-opttable => \@opttable,
                -options => \%options);
-options

This argument should be a reference to an (empty) hash. Options are set into this hash. If this argument is missing, options will be stored in variables named $opt_XXX.

-filename

This argument is optional and specified the filename for loading and saving options.

set_defaults

Set default values. This only applies if the -opttable variant is used.

load_options(filename)

Loads options from file filename, or, if not specified, from object's filename as specified in new. The loading is done in a safe compartment ensure security.The loaded file should have a reference to a hash named $loadoptions.

save_options(filename)

Writes options to file filename, or, if not specified, from object's filename as specified in new. The saving is done with Data::Dumper. Since saving may fail, you should call this method inside of eval {} and check $@. Possible exceptions are No Data::Dumper (cannot find the Data::Dumper module) and Writing failed (cannot write to file).

get_options

Gets options via GetOptions. Returns the same value as GetOptions, i.e. 0 indicates that the function detected one or more errors.

If you want to process options which does not appear in the GUI, you have two alternatives:

  • Use the -opttable variant of new and mark all non-GUI options with nogui, e.g.

    new Tk::Getopt(-opttable => ['not-in-gui', '!', undef,
                                 {'nogui' => 1}], ...)
  • Use Getopt::Long::passthrough and process non-GUI options directly with Getopt::Long::GetOptions. The remaining args can be passed to get_options.

    Example:

    use Tk::Getopt;
    use Getopt::Long;
    
    $Getopt::Long::passthrough = 1;
    GetOptions('options!' => \$preloadopt);
    $Getopt::Long::passthrough = 0;
    
    $opt = new Tk::Getopt( ... );
    $opt->get_options;
usage

Generates an usage string from object's opttable. The usage string is constructed from the option name, default value and help entries.

process_options([undo_hash])

Checks wheather given values are valid (if strict is set) and calls any callbacks specified by the sub option. If undo_hash is given and the new value of an option did not change, no sub is called.

option_editor(widget, [arguments ...])

Pops the option editor up. The editor provides facilitied for editing options, undoing, restoring to their default valued and saving to the default options file.

The first argument is the parent widget. Further optional arguments are passed as a hash:

-callback

Execute additional callback after creating the option editor. Arguments passed to this callback are: reference to the Tk::Getopt object and a reference to the option editor window.

-nosave

Disable saving of options.

-toplevel

Use another widget instead of Toplevel for embedding the option editor, e.g. Frame to embed the editor into another toplevel widget (do not forget to pack the frame!).

-statusbar

Use an additional status bar for help messages.

-string

Change button labels and title. This argument should be a hash reference with following keys: optedit, undo, lastsaved, save, defaults, ok, cancel.

Since the option editor uses the NoteBook widget, options may be grouped in several pages. Grouping is only possible if using the -opttable variant of new. Help messages are shown in balloons and, if specified, in a statusbar.

option_editor returns a reference to the created window.

Note: this method returns immediately to the calling program.

Buttons in the option editor window:

OK

Accept options and close option editor window.

Cancel

Set old values and close option editor window.

Undo

Set old values.

Last saved

Set last saved options. This button is not displayed if no filename was given in new.

Save

Save options to file. This button is not displayed if no filename was given in new.

The option types are translated to following widgets:

Boolean

Checkbutton (_boolean_widget)

Integer and Float

Scale, if range is set, otherwise either BrowseEntry or Entry (_integer_widget, _float_widget).

String

BrowseEntry if choices is set, otherwise entry (_string_widget).

REQUIREMENTS

Tk::Getopt needs Data::Dumper (Version 2.07) for saving options and, of course, the Tk (Version 400.202) package, if you want to use the graphical interface. You can found these packages at CPAN.

BUGS

Not all of Getopt::Long is supported (array and hash options, <>, alias names, abbrevs).

The Options editor probably should be a real widget.

You should use Tk400.203, since Tk::Balloon has a bug when its parent window is destroyed.

The API will not be stable until version 1.00.

This manual is confusing. In fact, the whole module is confusing.

AUTHOR

Slaven Rezic <eserte@cs.tu-berlin.de>

This package is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

SEE ALSO

perl, Getopt::Long, Data::Dumper, Tk, Tk::NoteBook, Safe