Museum

Home

Lab Overview

Retrotechnology Articles

Online Manuals

⇒ MrmOpnHiB(Xm) — OpenDesktop Software Development System 3.0.0

Media Vault

Software Library

Restoration Projects

Artifacts Sought


 MrmOpenHierarchyPerDisplay(Xm)                MrmOpenHierarchyPerDisplay(Xm)
                                6 January 1993


 Name

    MrmOpenHierarchyPerDisplay - allocates a hierarchy ID and opens all the
    UID files in the hierarchy

 Syntax


    #include <Mrm/MrmPublic.h>

    Cardinal MrmOpenHierarchyPerDisplay (display, num_files, file_names_list,
                                         ancillary_structures_list,
                                         hierarchy_id)
    Display *display;
    MrmCount num_files;
    String file_names_list[];
    MrmOsOpenParamPtr *ancillary_structures_list;
    MrmHierarchy *hierarchy_id;


 Description

    MrmOpenHierarchyPerDisplay allows you to specify the list of UID files
    that MRM searches in subsequent fetch operations.  All subsequent fetch
    operations return the first occurrence of the named item encountered
    while traversing the UID hierarchy from the first list element (UID file
    specification) to the last list element.  This function also allocates a
    hierarchy ID and opens all the UID files in the hierarchy.  It initial-
    izes the optimized search lists in the hierarchy.  If
    MrmOpenHierarchyPerDisplay encounters any errors during its execution,
    any files that were opened are closed.

    The application must call XtAppInitialize before calling MrmOpen-
    HierarchyPerDisplay.

    display Specifies the connection to the X server and the value to pass to
            XtResolvePathname. For more information on the Display structure,
            see the Xlib function XOpenDisplay.

    numfiles
            Specifies the number of files in the name list.

    filenameslist
            Specifies an array of character strings that identify the UID
            files.

    ancillarystructureslist
            A list of operating-system-dependent ancillary structures corre-
            sponding to such things as filenames, clobber flag, and so forth.
            This argument should be NULL for most operations.  If you need to
            reference this structure, see the definition of MrmOsOpenParamPtr
            in MrmPublic.h for more information.

    hierarchyid
            Returns the search hierarchy ID.  The search hierarchy ID identi-
            fies the list of UID files that MRM searches (in order) when per-
            forming subsequent fetch calls.

    Each UID file string in filenameslist can specify either a full path-
    name or a filename.  If a UID file string has a leading slash (/), it
    specifies a full pathname, and MRM opens the file as specified.  Other-
    wise, the UID file string specifies a filename.  In this case MRM looks
    for the file along a search path specified by the UIDPATH environment
    variable or by a default search path, which varies depending on whether
    or not the XAPPLRESDIR environment variable is set.

    The UIDPATH environment variable specifies a search path and naming con-
    ventions associated with UID files.  It can contain the substitution
    field %U, where the UID file string from the filenameslist argument to
    MrmOpenHierarchyPerDisplay is substituted for %U.  It can also contain
    the substitution fields accepted by XtResolvePathname.  The substitution
    field %T is always mapped to ``uid''.  The entire path is first searched
    with %S mapped to ``.uid'' and then, if no file is found, is searched
    again with %S mapped to NULL.  For example, the following UIDPATH value
    and MrmOpenHierarchyPerDisplay call cause MRM to open two separate UID
    files:

       UIDPATH=/uidlib/%L/%U.uid:/uidlib/%U/%L
       static char *uid_files[] = {"/usr/users/me/test.uid", "test2"};
       MrmHierarchy  *Hierarchy_id;
       MrmOpenHierarchyPerDisplay((MrmCount)2,uid_files, NULL, Hierarchy_id)


    MRM opens the first file, /usr/users/me/test.uid, as specified in the
    filenameslist argument to MrmOpenHierarchyPerDisplay, because the UID
    file string in the filenameslist argument specifies a full pathname.
    MRM looks for the second file, test2, first as /uidlib/%L/test2.uid and
    second as /uidlib/test2/%L, where the display's language string is sub-
    stituted for %L.

    After MrmOpenHierarchyPerDisplay opens the UID hierarchy, you should not
    delete or modify the UID files until you close the UID hierarchy by cal-
    ling MrmCloseHierarchy.

    If UIDPATH is not set but the environment variable XAPPLRESDIR is set,
    MRM searches the following pathnames:

       %U
       $XAPPLRESDIR/%L/uid/%N/%U
       $XAPPLRESDIR/%l/uid/%N/%U
       $XAPPLRESDIR/uid/%N/%U
       $XAPPLRESDIR/%L/uid/%U
       $XAPPLRESDIR/%l/uid/%U
       $XAPPLRESDIR/uid/%U
       $HOME/uid/%U
       $HOME/%U
       /usr/lib/X11/%L/uid/%N/%U
       /usr/lib/X11/%l/uid/%N/%U
       /usr/lib/X11/uid/%N/%U
       /usr/lib/X11/%L/uid/%U
       /usr/lib/X11/%l/uid/%U
       /usr/lib/X11/uid/%U
       /usr/include/X11/uid/%U

    If neither UIDPATH nor XAPPLRESDIR is set, MRM searches the following
    pathnames:

       %U
       $HOME/%L/uid/%N/%U
       $HOME/%l/uid/%N/%U
       $HOME/uid/%N/%U
       $HOME/%L/uid/%U
       $HOME/%l/uid/%U
       $HOME/uid/%U
       $HOME/%U
       /usr/lib/X11/%L/uid/%N/%U
       /usr/lib/X11/%l/uid/%N/%U
       /usr/lib/X11/uid/%N/%U
       /usr/lib/X11/%L/uid/%U
       /usr/lib/X11/%l/uid/%U
       /usr/lib/X11/uid/%U
       /usr/include/X11/uid/%U

    These paths are defaults that vendors may change.  For example, a vendor
    may use different directories for /usr/lib/X11 and /usr/include/X11.

    The following substitutions are used in these paths:

    %U      The UID file string, from the filenameslist argument.

    %N      The class name of the application.

    %L      The display's language string.

    %l      The language component of the display's language string.

    %S      The suffix to the file name.  The entire path is searched first
            with a suffix of ``.uil'', and if no file is found, it is
            searched again with a NULL suffix.

 Return value

    This function returns one of these status return constants:

    MrmSUCCESS
            The function executed successfully.

    MrmNOTFOUND
            File not found.

    MrmFAILURE
            The function failed.

 See also

    MrmCloseHierarchy(Xm)


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