Museum

Home

Lab Overview

Retrotechnology Articles

Online Manuals

⇒ XInitial(XS) — OpenDesktop Software Development System 3.0.0

Media Vault

Software Library

Restoration Projects

Artifacts Sought

Related Articles

XrmGetResource(XS)

XrmMergeDatabases(XS)

XrmPutResource(XS)

XrmUniqueQuark(XS)


 XrmInitialize(XS) X Version 11 (Release 5) 6 January 1993  XrmInitialize(XS)


 Name

    XrmInitialize - initialize the Resource Manager, Resource Manager
    structures, and parse the command line

 Syntax


    void XrmInitialize();

    void XrmParseCommand(database, table, table_count, name, argc_in_out,
                         argv_in_out)
          XrmDatabase *database;
          XrmOptionDescList table;
          int table_count;
          char *name;
          int *argc_in_out;
          char **argv_in_out;


 Arguments


    argcinout    Specifies the number of arguments and returns the number
                   of remaining arguments.

    argvinout    Specifies the command line arguments and returns the
                   remaining arguments.

    database       Specifies the resource database.

    name           Specifies the application name.

    table          Specifies the table of command line arguments to be
                   parsed.

    tablecount    Specifies the number of entries in the table.

 Description

    The XrmInitialize function initialize the resource manager.  It must be
    called before any other Xrm functions are used.

    The XrmParseCommand function parses an (argc, argv) pair according to the
    specified option table, loads recognized options into the specified data-
    base with type ``String,'' and modifies the (argc, argv) pair to remove
    all recognized options.  If database contains NULL, XrmParseCommand cre-
    ates a new database and returns a pointer to it.  Otherwise, entries are
    added to the database specified.  If a database is created, it is created
    in the current locale.

    The specified table is used to parse the command line.  Recognized
    options in the table are removed from argv, and entries are added to the
    specified resource database.  The table entries contain information on
    the option string, the option name, the style of option, and a value to
    provide if the option kind is XrmoptionNoArg.  The option names are com-
    pared byte-for-byte to arguments in argv, independent of any locale.  The
    resource values given in the table are stored in the resource database
    without modification.  All resource database entries are created using a
    ``String'' representation type.  The argc argument specifies the number
    of arguments in argv and is set on return to the remaining number of
    arguments that were not parsed.  The name argument should be the name of
    your application for use in building the database entry.  The name argu-
    ment is prefixed to the resourceName in the option table before storing a
    database entry.  No separating (binding) character is inserted, so the
    table must contain either a period (.) or an asterisk (*) as the first
    character in each resourceName entry.  To specify a more completely qual-
    ified resource name, the resourceName entry can contain multiple com-
    ponents.  If the name argument and the resourceNames are not in the Host
    Portable Character Encoding the result is implementation dependent.

 Structures

    The XrmValue, XrmOptionKind, and XrmOptionDescRec structures contain:

    typedef struct {
          unsigned int size;
          XPointer addr;
    } XrmValue, *XrmValuePtr;


    typedef enum {
        XrmoptionNoArg,        /* Value is specified in
                                  XrmOptionDescRec.value */
        XrmoptionIsArg,        /* Value is the option string itself */
        XrmoptionStickyArg,    /* Value is characters immediately following
                                  option */
        XrmoptionSepArg,       /* Value is next argument in argv */
        XrmoptionResArg,       /* Resource and value in next argument in argv */
        XrmoptionSkipArg,      /* Ignore this option and the next argument in
                                  argv */
        XrmoptionSkipLine,     /* Ignore this option and the rest of argv */
        XrmoptionSkipNArgs     /* Ignore this option and the next
                                  XrmOptionDescRec.value arguments in argv */
    } XrmOptionKind;


    typedef struct {
        char *option;          /* Option specification string in argv */
        char *specifier;       /* Binding and resource name (sans application
                                  name) */
        XrmOptionKind argKind; /* Which style of option it is */
        XPointer value;        /* Value to provide if XrmoptionNoArg or
                                  XmoptionSkipNArgs */
    } XrmOptionDescRec, *XrmOptionDescList;


 See also

    XrmGetResource(XS), XrmMergeDatabases(XS), XrmPutResource(XS),
    XrmUniqueQuark(XS)
    Xlib - C Language X Interface


Typewritten Software • bear@typewritten.org • Edmonds, WA 98026