Tk::CmdLine - Process standard X11 command line options and set initial resources
Tk::CmdLine::SetArguments([@argument]); my $value = Tk::CmdLine::cget([$option]); Tk::CmdLine::SetResources((\@resource | $resource) [, $priority]); Tk::CmdLine::LoadResources( [ -symbol => $symbol ] [ -file => $fileSpec ] [ -priority => $priority ] [ -echo => $fileHandle ] );
Process standard X11 command line options and set initial resources.
The X11R5 man page for X11 says: Most X programs attempt to use the
same names for command line options and arguments. All applications
written with the X Toolkit Intrinsics automatically accept the following
options: .... This module processes these command line options for
perl/Tk applications using the SetArguments
() function.
This module can optionally be used to load initial resources
explicitly via function SetResources
(), or from specified
files (default: the standard X11 application-specific resource files)
via function LoadResources
().
Specifies the color to be used for the window background.
Specifies the class under which resources for the application should be found. This option is useful in shell aliases to distinguish between invocations of an application, without resorting to creating links to alter the executable file name.
Specifies the name of the X server to be used.
Specifies the font to be used for displaying text.
Specifies the color to be used for text or graphics.
Specifies the initial size and location of the first MainWindow.
Indicates that the user would prefer that the application's windows initially not be visible as if the windows had been immediately iconified by the user. Window managers may choose not to honor the application's request.
Specifies that the application should adhere as closely as possible to Motif look-and-feel standards. For example, active elements such as buttons and scrollbar sliders will not change color when the pointer passes over them.
Specifies the name under which resources for the application should be found. This option is useful in shell aliases to distinguish between invocations of an application, without resorting to creating links to alter the executable file name.
Indicates that requests to the X server should be sent synchronously, instead of asynchronously. Since Xlib normally buffers requests to the server, errors do do not necessarily get reported immediately after they occur. This option turns off the buffering so that the application can be debugged. It should never be used with a working program.
This option specifies the title to be used for this window. This information is sometimes used by a window manager to provide some sort of header identifying the window.
Specifies a resource pattern and value to override any defaults. It is also very useful for setting resources that do not have explicit command line arguments. The ResourceString is of the form <pattern>:<value>, that is (the first) ':' is used to determine which part is pattern and which part is value. The (<pattern>, <value>) pair is entered into the options database with optionAdd (for each MainWindow configured), with interactive priority.
There are several mechanism for initializing the resource database to
be used by an X11 application. Resources may be defined in a
$HOME
/.Xdefaults file, a system application defaults file
(e.g. /usr/lib/X11/app-defaults/<CLASS>), or a
user application defaults file (e.g.
$HOME
/<CLASS>). The Tk::CmdLine
functionality for setting initial resources concerns itself with the
latter two.
Resource files contain data lines of the form <pattern>:<value>. They may also contain blank lines and comment lines (denoted by a ! character as the first non-blank character). Refer to option for a description of <pattern>:<value>.
System application defaults files may be specified via environment
variable $XFILESEARCHPATH
which, if set, contains a list of
file patterns (joined using the OS-dependent path delimiter, e.g. colon
on UNIX).
User application defaults files may be specified via environment
variables $XUSERFILESEARCHPATH
, $XAPPLRESDIR
or $HOME
.
Extract the X11 options contained in a specified array (@ARGV by
default). Tk::CmdLine::SetArguments([@argument]) The X11 options may be
specified using a single dash - as per the X11 convention, or
using two dashes -- as per the POSIX standard (e.g.
-geometry 100x100, -geometry
100x100 or -geometry=100x100). The
options may be interspersed with other options or arguments. A
-- by itself terminates option processing. By default, command
line options are extracted from @ARGV
the first time a
MainWindow is created. The Tk::MainWindow constructor indirectly invokes
SetArguments
() to do this.
Get a list of the X11 options that have been processed by
SetArguments
(). (GetArguments
() first invokes
SetArguments
() if it has not already been invoked.)
Get the value of a configuration option specified via
SetArguments
(). (cget
() first invokes
SetArguments
() if it has not already been invoked.)
Tk::CmdLine::cget([$option]) The valid options are:
-class, -name,
-screen and -title. If no option is
specified, -class is implied. A typical use of
cget
() might be to obtain the application class in order to
define the name of a resource file to be loaded in via
LoadResources
(). my $class = Tk::CmdLine::cget(); # process
command line and return class
Set the initial resources. Tk::CmdLine::SetResources((\@resource |
$resource) [, $priority]) A single resource may be specified using a
string of the form '<pattern>:<value>'.
Multiple resources may be specified by passing an array reference whose
elements are either strings of the above form, and/or anonymous arrays
of the form [ <pattern>, <value> ]. The
optional second argument specifies the priority, as defined in option,
to be associated with the resources (default: userDefault).
Note that SetResources
() first invokes
SetArguments
() if it has not already been invoked.
Load initial resources from one or more files.
Tk::CmdLine::LoadResources( [ -symbol => $symbol ] [ -file =>
$fileSpec ] [ -priority => $priority ] [ -echo => $fileHandle ] );
[ -symbol => $symbol
] specifies the
name of an environment variable that, if set, defines a list of one or
more directories and/or file patterns (joined using the OS-dependent
path delimiter, e.g. colon on UNIX).
$XUSERFILESEARCHPATH
is a special case. If
$XUSERFILESEARCHPATH
is not set, $XAPPLRESDIR
is checked instead. If $XAPPLRESDIR
is not set,
$HOME
is checked instead. An item is identified as a file
pattern if it contains one or more /%[A-Za-z]/ patterns. Only patterns
%L
, %T
and
%N
are currently recognized. All others
are replaced with the null string. Pattern
%L
is translated into $LANG
.
Pattern %T
is translated into
app-defaults. Pattern %N
is
translated into the application class name. Each file pattern, after
substitutions are applied, is assumed to define a FileSpec to be
examined. When a directory is specified, FileSpecs
<DIRECTORY>/<LANG>/<CLASS>
and <DIRECTORY>/<CLASS>
are defined, in that order. [ -file =>
$fileSpec
] specifies a resource file to be loaded in. The
file is silently skipped if if does not exist, or if it is not readable.
[ -priority => $priority
] specifies
the priority, as defined in option, to be associated with the resources
(default: userDefault). [ -echo =>
$fileHandle
] may be used to specify that a line should be
printed to the corresponding FileHandle (default: \*STDOUT) everytime a
file is examined / loaded. If no -symbol or
-file options are specified,
LoadResources
() processes symbol
$XFILESEARCHPATH
with priority startupFile and
$XUSERFILESEARCHPATH
with priority userDefault.
(Note that $XFILESEARCHPATH
and
$XUSERFILESEARCHPATH
are supposed to contain only patterns.
$XAPPLRESDIR
and $HOME
are supposed to be a
single directory. LoadResources
() does not check/care
whether this is the case.) For each set of FileSpecs,
LoadResources
() examines each FileSpec to determine if the
file exists and is readable. The first file that meets this criteria is
read in and SetResources
() is invoked. Note that
LoadResources
() first invokes SetArguments
()
if it has not already been invoked.
This module is an object-oriented module whose methods can be invoked
as object methods, class methods or regular functions. This is
accomplished via an internally-maintained object reference which is
created as necessary, and which always points to the last object used.
SetArguments
(), SetResources
() and
LoadResources
() return the object reference.
@ARGV
is processed by Tk::CmdLine at MainWindow
creation. use Tk; # <Process @ARGV - ignoring all X11-specific
options> my $mw = MainWindow->new(); MainLoop();
@ARGV
is processed by Tk::CmdLine before MainWindow
creation. An @ARGV
of (--geometry=100x100 -opt1 a b c -bg
red) is equal to (-opt1 a b c) after SetArguments
() is
invoked. use Tk; Tk::CmdLine::SetArguments(); #
Tk::CmdLine->SetArguments() works too # <Process @ARGV - not
worrying about X11-specific options> my $mw = MainWindow->new();
MainLoop();
Just like 2) except that default arguments are loaded first. use Tk; Tk::CmdLine::SetArguments(qw(-name test -iconic)); Tk::CmdLine::SetArguments(); # <Process @ARGV - not worrying about X11-specific options> my $mw = MainWindow->new(); MainLoop();
@ARGV
is processed by Tk::CmdLine before MainWindow
creation. Standard resource files are loaded in before MainWindow
creation. use Tk; Tk::CmdLine::SetArguments(); # <Process @ARGV - not
worrying about X11-specific options> Tk::CmdLine::LoadResources(); my
$mw = MainWindow->new(); MainLoop();
@ARGV
is processed by Tk::CmdLine before MainWindow
creation. Standard resource files are loaded in before MainWindow
creation using non-default priorities. use Tk;
Tk::CmdLine::SetArguments(); # <Process @ARGV - not worrying about
X11-specific options> Tk::CmdLine::LoadResources(-echo =>
\*STDOUT, -priority => 65, -symbol => XFILESEARCHPATH );
Tk::CmdLine::LoadResources(-echo => \*STDOUT, -priority => 75,
-symbol => XUSERFILESEARCHPATH ); my $mw = MainWindow->new();
MainLoop();
@ARGV
is processed by Tk::CmdLine before MainWindow
creation. Standard resource files are loaded in before MainWindow
creation. Individual resources are also loaded in before MainWindow
creation. use Tk; Tk::CmdLine::SetArguments(); # <Process @ARGV - not
worrying about X11-specific options> Tk::CmdLine::LoadResources();
Tk::CmdLine::SetResources( # set a single resource *Button*background:
red, widgetDefault ); Tk::CmdLine::SetResources( # set multiple
resources [ *Button*background: red, *Button*foreground: blue ],
widgetDefault ); my $mw = MainWindow->new(); MainLoop();
Home directory which may contain user application defaults files as
$HOME
/$LANG
/<CLASS> or
$HOME
/<CLASS>.
The current language (default: C).
List of FileSpec patterns (joined using the OS-dependent path delimiter, e.g. colon on UNIX) used in defining system application defaults files.
List of FileSpec patterns (joined using the OS-dependent path delimiter, e.g. colon on UNIX) used in defining user application defaults files.
Directory containing user application defaults files as
$XAPPLRESDIR
/$LANG
/<CLASS>
or $XAPPLRESDIR
/<CLASS>.
MainWindow option
1999.03.04 Ben Pavon <ben.pavon@hsc.hac.com> Rewritten as
an object-oriented module. Allow one to process command line options in
a specified array (@ARGV by default). Eliminate restrictions on the
format and location of the options within the array (previously the X11
options could not be specified in POSIX format and had to be at the
beginning of the array). Added the SetResources
() and
LoadResources
() functions to allow the definition of
resources prior to MainWindow creation.
2000.08.31 Ben Pavon <ben.pavon@hsc.hac.com> Added the
GetArguments
() method which returns the list of arguments
that have been processed by SetArguments
(). Modified
LoadResources
() to split the symbols using the OS-dependent
path delimiter defined in the Config module. Modified
LoadResources
() to eliminate a warning message when
processing patterns %l
,
%C
,
%S
.