#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;
The application must call XtAppInitialize before calling MrmOpenHierarchyPerDisplay.
Each UID file string in file_names_list can specify either a full pathname or a filename. If a UID file string has a leading slash (/), it specifies a full pathname, and MRM opens the file as specified. Otherwise, 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 conventions associated with UID files. It can contain the substitution field %U, where the UID file string from the file_names_list 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 file_names_list argument to MrmOpenHierarchyPerDisplay, because the UID file string in the file_names_list 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 substituted for %L.
After MrmOpenHierarchyPerDisplay opens the UID hierarchy, you should not delete or modify the UID files until you close the UID hierarchy by calling 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/%UIf 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/%UThese 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: