Museum

Home

Lab Overview

Retrotechnology Articles

Online Manuals

⇒ XInitial(3X11) — Dell System V Release 4 Issue 2.2

Media Vault

Software Library

Restoration Projects

Artifacts Sought

Related Articles

XrmGetResource(3X11)

XrmMergeDatabases(3X11)

XrmPutResource(3X11)

XrmUniqueQuark(3X11)



XrmInitialize(3X11)         X Version 11(Release 5)         XrmInitialize(3X11)


NAME
      XrmInitialize, XrmParseCommand, XrmValue, XrmOptionKind, XrmOptionDescRec
      - 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
      argc_in_out
                Specifies the number of arguments and returns the number of
                remaining arguments.

      argv_in_out
                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.

      table_count
                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
      database with type ``String,'' and modifies the (argc, argv) pair to
      remove all recognized options.  If database contains NULL,
      XrmParseCommand creates 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


10/89                                                                    Page 1







XrmInitialize(3X11)         X Version 11(Release 5)         XrmInitialize(3X11)


      compared 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
      argument 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
      qualified resource name, the resourceName entry can contain multiple
      components.  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
                                  XrmoptionSkipNArgs   */
      } XrmOptionDescRec, *XrmOptionDescList;

SEE ALSO
      XrmGetResource(3X11), XrmMergeDatabases(3X11), XrmPutResource(3X11),
      XrmUniqueQuark(3X11)
      Xlib - C Language X Interface







Page 2                                                                    10/89





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