Blob Blame History Raw
/* 
 * Motif
 *
 * Copyright (c) 1987-2012, The Open Group. All rights reserved.
 *
 * These libraries and programs are free software; you can
 * redistribute them and/or modify them under the terms of the GNU
 * Lesser General Public License as published by the Free Software
 * Foundation; either version 2 of the License, or (at your option)
 * any later version.
 *
 * These libraries and programs are distributed in the hope that
 * they will be useful, but WITHOUT ANY WARRANTY; without even the
 * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
 * PURPOSE. See the GNU Lesser General Public License for more
 * details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with these librararies and programs; if not, write
 * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
 * Floor, Boston, MA 02110-1301 USA
 */ 
/* 
 * HISTORY
 */ 
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif


#ifdef REV_INFO
#ifndef lint
static char rcsid[] = "$XConsortium: Mrmlread.c /main/16 1996/11/13 14:02:28 drk $"
#endif
#endif

/*                                                                      *
 * (c) Copyright 1996 Hewlett-Packard Company                           *
 * (c) Copyright 1996 International Business Machines Corp.             *
 * (c) Copyright 1996 Sun Microsystems, Inc.                            *
 * (c) Copyright 1996 Novell, Inc.                                      *
 * (c) Copyright 1989, 1990, 1996 Digital Equipment Corporation.	*
 * (c) Copyright 1996 FUJITSU LIMITED.					*
 * (c) Copyright 1996 Hitachi.						*
 */

/*
 *++
 *  FACILITY:
 *
 *      UIL Resource Manager (URM):
 *
 *  ABSTRACT:
 *
 *	This module contains the literal read routines. All these routines
 *	read a literal from a hierarchy or IDB file into a resource context.
 *
 *--
 */


/*
 *
 *  INCLUDE FILES
 *
 */

#include <stdio.h>
#include <Mrm/MrmAppl.h>
#include <Mrm/Mrm.h>
#include "MrmosI.h"
#include "MrmMsgI.h"

/*
 *
 *  TABLE OF CONTENTS
 *
 *	UrmGetIndexedLiteral		Read indexed literal from IDB file
 *
 *	UrmGetRIDLiteral		Read RID literal from IDB file
 *
 *	UrmHGetIndexedLiteral		Read indexed literal from hierarchy
 *
 */

/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	This routine is a service routine for the various XmFetch...Literal
 *	routine. It fetches a literal into a context. It also fetches any
 *	other literals which are referenced.
 *
 *  FORMAL PARAMETERS:
 *
 *	hierarchy_id	id of an open hierarchy containing the literal
 *	index		index of the desired literal
 *	context_id	context in which to return literal. Literal will
 *			be fixed up.
 *	ctxlist		list of other contexts created (if needed)
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
Urm__FetchLiteral (MrmHierarchy			hierarchy_id,
		   String			index,
		   URMResourceContextPtr	context_id,
		   URMPointerListPtr		*ctxlist)
{

  /*
   *  Local variables
   */
  Cardinal		result;		/* function results */
  IDBFile		file_id = NULL;	/* file containing literal */
  long			val;		/* literal value */
  MrmType		type;		/* literal type */
  char			err_msg[300];	/* for error messages */
  Boolean		swap_needed = FALSE ;


  /*
   * read the literal into the context
   */
  result = Urm__HGetIndexedLiteral (hierarchy_id, index, context_id, &file_id);
  if ( result != MrmSUCCESS )
    {
      sprintf (err_msg, _MrmMMsg_0042, index);
      return Urm__UT_Error ("Urm__FetchLiteral", err_msg, NULL, NULL, result);
    }

  swap_needed = UrmRCByteSwap(context_id) ;

  /*
   * Acquire the literal type and value, and do any fixups which are required.
   */
  val = (long) UrmRCBuffer (context_id);
  type = UrmRCType (context_id);
  switch ( type )
    {
    case MrmRtypeIconImage:
      UrmPlistInit (10, ctxlist);
      result = Urm__CW_LoadIconImage ((RGMIconImagePtr)val, (XtPointer)val,
				      hierarchy_id, file_id, *ctxlist);
      /* LoadIconImage checks validations and handle swapping */
      swap_needed = FALSE ;
      break;
    case MrmRtypeFontList:
      /* Check for old style font list, allocate new value if necessary. */
      if (strcmp(file_id->db_version, URM1_1version) <= 0)
	{
	  int count = ((OldRGMFontListPtr)val)->count;
	  RGMFontListPtr fontlist = (RGMFontListPtr)
	    XtMalloc(sizeof(RGMFontList) + (sizeof(RGMFontItem) * (count - 1)));
	  Urm__CW_FixupValue ((long)fontlist, type, (XtPointer)val, file_id,
			      &swap_needed);
	  XtFree((char *)val);
	  UrmRCBuffer(context_id) = (char *)fontlist;
	}
      else 
	Urm__CW_FixupValue (val, type, (XtPointer)val, file_id, &swap_needed); 
      break; 
    case MrmRtypeInteger:
    case MrmRtypeBoolean:
      if ( swap_needed )
	{
	  swapbytes( (*(int *)UrmRCBuffer (context_id)) );
	  swap_needed = FALSE ;
	}
      break; 
    case MrmRtypeSingleFloat:
      if ( swap_needed )
	{
	  swapbytes( (*(int *)UrmRCBuffer (context_id)) );
	  swap_needed = FALSE ;
	}
      _MrmOSIEEEFloatToHost( (float *)UrmRCBuffer (context_id));
      break; 
    case MrmRtypeFloat:
      if ( swap_needed )
	{
	  swapdouble( (*(double *)UrmRCBuffer (context_id)) );
	  swap_needed = FALSE ;
	}
      _MrmOSIEEEDoubleToHost( (double *)UrmRCBuffer (context_id));
      break; 

    default:
      Urm__CW_FixupValue (val, type, (XtPointer)val, file_id, &swap_needed);
      break;
    }

  UrmRCSetByteSwap(context_id, swap_needed);
  return MrmSUCCESS;

}



/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	This routine reads and returns the value of a literal (named value)
 *	stored as a public resource in a single UID file. It returns a
 *	pointer to value of the literal, fixed up and converted for
 *	use as a toolkit argument. The return is always a pointer -- an
 *	integer is returned as a pointer to an integer, and a string is
 *	returned as a pointer to a string. The caller is responsible for
 *	freeing the literal's storage, which was acquired with XtMalloc.
 *
 *	This routine should not be used for fetching icon or color literals,
 *	as more information is required for converting them. If fetched,
 *	an error is returned.
 *
 *  FORMAL PARAMETERS:
 *
 *	hierarchy_id	id of an open hierarchy containing the literal
 *	index		index of the desired literal
 *	value_return	to return pointer to literal value
 *	type_return	will be set to the literal data type, from RGMrType...
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *	MrmSUCCESS	- literal found and returned
 *	MrmWRONG_TYPE	- unsupported literal type encountered
 *	MrmNOT_FOUND	- literal not found
 *	MrmFAILURE	- file system error
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal
MrmFetchLiteral (MrmHierarchy		hierarchy_id,
		 String			index,
		 Display		*display,
		 XtPointer		*value_return,
		 MrmCode		*type_return)
{

  /*
   *  Local variables
   */
  Cardinal		result;		/* function results */
  URMResourceContextPtr	context_id;	/* for the literal */
  URMPointerListPtr	ctxlist = NULL;	/* save added contexts */
  Cardinal		ndx;		/* loop index */
  int			vec_size = 0;
  int			vec_count = 0;
  _MrmDisplayToAppContext(display);

  _MrmAppLock(app);
  _MrmProcessLock();

  /*
   * Read the literal, discard the context, and return.
   */
  UrmGetResourceContext ((char *(*)())NULL, (void(*)())NULL, 0, &context_id);
  result = Urm__FetchLiteral (hierarchy_id, index, context_id, &ctxlist);
  if ( result == MrmSUCCESS )
    {
      *value_return = (XtPointer) UrmRCBuffer (context_id);
      (*type_return) = (MrmCode) UrmRCType (context_id);
      vec_size = UrmRCSize (context_id);
      switch ( *type_return )
	{
	case MrmRtypeIconImage:
	case MrmRtypeColor:
	case MrmRtypeColorTable:
	case MrmRtypeXBitmapFile:
	  if ( ctxlist != NULL )
	    {
	      for ( ndx=0 ; ndx<UrmPlistNum(ctxlist) ; ndx++ )
		UrmFreeResourceContext
		  ((URMResourceContextPtr) UrmPlistPtrN(ctxlist,ndx)) ;
	      UrmPlistFree (ctxlist) ;
	    }

	  UrmFreeResourceContext (context_id);
	  _MrmAppUnlock(app);
	  _MrmProcessUnlock();
	  return MrmWRONG_TYPE;

	case MrmRtypeChar8Vector:
	case MrmRtypeCStringVector:
	  /*
	  ** Do necessary conversions (Fixups were done by Urm__FetchLiteral)
	  */
	  vec_size -= (sizeof ( RGMTextVector ) - sizeof ( RGMTextEntry ));
	  vec_count = ((RGMTextVectorPtr)*value_return)->count;
	  result = Urm__CW_ConvertValue (NULL, (long*)value_return, 
					 (MrmType)*type_return, 0, display,
					 hierarchy_id, NULL) ;
	  if ( result != MrmSUCCESS ) 
	    {
	      _MrmAppUnlock(app);
	      _MrmProcessUnlock();
	      return MrmFAILURE;
	    }
	  Urm__CW_SafeCopyValue ((long *)value_return, (MrmType)*type_return,
				 NULL, vec_count, vec_size);
	  UrmFreeResourceContext (context_id);
	  break;

	case MrmRtypeIntegerVector:
	  /*
	  **  Do necessary conversions (Fixups were done by Urm__FetchLiteral)
	  */
	  vec_count = ((RGMIntegerVectorPtr)*value_return)->count;
	  vec_size  = vec_count * sizeof ( int * );
	  result = Urm__CW_ConvertValue (NULL, (long*)value_return, 
					 (MrmType)*type_return, 0, display,
					 hierarchy_id, NULL) ;
	  if ( result != MrmSUCCESS )
	    {
	      _MrmAppUnlock(app);
	      _MrmProcessUnlock();
	      return MrmFAILURE;
	    }
	  Urm__CW_SafeCopyValue ((long *)value_return, (MrmType)*type_return,
				 NULL, vec_count, vec_size);
	  UrmFreeResourceContext (context_id);
	  break;

	default :
	  /*
	  **  Do necessary conversions (Fixups were done by Urm__FetchLiteral)
	  */
	  result = Urm__CW_ConvertValue (NULL, (long*)value_return, 
					 (MrmType)*type_return, 0, display,
					 hierarchy_id, NULL) ;

	  switch ( *type_return )
	    {
	      /*
	       * Free the context id AND the buffer in these cases
	       */
	    case MrmRtypeTransTable:
	    case MrmRtypeClassRecName:
	    case MrmRtypeKeysym:
	      UrmFreeResourceContext (context_id);
	      break;

	    default:
	      /*
	       * Only free the context id in all other cases
	       */
	      (*(context_id->free_func)) (context_id) ;
	      break;
	    }

	  if ( result != MrmSUCCESS )
	    {
	      _MrmAppUnlock(app);
	      _MrmProcessUnlock();
	      return MrmFAILURE;
	    }
	  break;
	}
      _MrmAppUnlock(app);
      _MrmProcessUnlock();
      return MrmSUCCESS;
    }
  else
    {
      (*(context_id->free_func)) (context_id) ;
      _MrmAppUnlock(app);
      _MrmProcessUnlock();
      return result;
    }
}



/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	This routine fetches an icon literal from a hierarchy. It converts
 *	the icon to an X pixmap.
 *
 *  FORMAL PARAMETERS:
 *
 *	hierarchy_id	id of an open hierarchy containing the literal
 *	index		index of the desired literal
 *	screen		screen to use for pixmap
 *	display		display to use for pixmap
 *	fgpix		foreground color for pixmap
 *	bgpix		background color for pixmap
 *	pixmap_return	to return resulting X pixmap
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
MrmFetchIconLiteral (MrmHierarchy                hierarchy_id,
		     String                      index,
		     Screen                      *screen,
		     Display                     *display,
		     Pixel                       fgpix,
		     Pixel                       bgpix,
		     Pixmap                      *pixmap_return)
{

  /*
   *  Local variables
   */
  Cardinal		result;		/* function results */
  URMResourceContextPtr	context_id;	/* for the literal */
  URMPointerListPtr	ctxlist = NULL;	/* save added contexts */
  Cardinal		ndx;		/* loop index */
  MrmType		type;
  _MrmDisplayToAppContext(display);

  _MrmAppLock(app);
  _MrmProcessLock();

  /*
   * Read the literal, and deal with errors
   */
  UrmGetResourceContext ((char *(*)())NULL, (void(*)())NULL, 0, &context_id);
  result = Urm__FetchLiteral (hierarchy_id, index, context_id, &ctxlist);
  if ( result == MrmSUCCESS ) {
    type = UrmRCType(context_id);
  }
  else
    {
      if ( ctxlist != NULL )
	{
	  for ( ndx=0 ; ndx<UrmPlistNum(ctxlist) ; ndx++ )
	    UrmFreeResourceContext
	      ((URMResourceContextPtr)UrmPlistPtrN(ctxlist,ndx)) ;
	  UrmPlistFree (ctxlist) ;
	}
      UrmFreeResourceContext (context_id);
      _MrmAppUnlock(app);
      _MrmProcessUnlock();
      return result;
    }

  /*
   * Convert to X pixmap, and free resources
   */
  switch (type) {
  case MrmRtypeIconImage:
    result = UrmCreatePixmap
      ((RGMIconImagePtr)UrmRCBuffer(context_id), screen, display,
       fgpix, bgpix, pixmap_return, (Widget)NULL);
    break;
  case MrmRtypeXBitmapFile:
    result = Urm__CW_ReadBitmapFile (UrmRCBuffer(context_id), screen, 
				     fgpix, bgpix, pixmap_return, (Widget)NULL);
    break;
  default:
    result = MrmWRONG_TYPE;
  }

  if ( ctxlist != NULL )
    {
      for ( ndx=0 ; ndx<UrmPlistNum(ctxlist) ; ndx++ )
	UrmFreeResourceContext 
	  ((URMResourceContextPtr)UrmPlistPtrN(ctxlist,ndx)) ;
      UrmPlistFree (ctxlist) ;
    }
  UrmFreeResourceContext (context_id);
  _MrmAppUnlock(app);
  _MrmProcessUnlock();
  return result;

}


/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	This routine fetches an icon literal from a hierarchy. It converts
 *	the icon to an X pixmap OF DEPTH 1.
 *
 *  FORMAL PARAMETERS:
 *
 *	hierarchy_id	id of an open hierarchy containing the literal
 *	index		index of the desired literal
 *	screen		screen to use for pixmap
 *	display		display to use for pixmap
 *	pixmap_return	to return resulting X pixmap
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
MrmFetchBitmapLiteral (MrmHierarchy                hierarchy_id,
		       String                      index,
		       Screen                      *screen,
		       Display                     *display,
		       Pixmap                      *pixmap_return,
		       Dimension			*width,
		       Dimension			*height)
{

  /*
   *  Local variables
   */
  Cardinal		result;		/* function results */
  URMResourceContextPtr	context_id;	/* for the literal */
  URMPointerListPtr	ctxlist = NULL;	/* save added contexts */
  Cardinal		ndx;		/* loop index */
  MrmType		type;
  RGMIconImagePtr	icon;
  _MrmDisplayToAppContext(display);

  _MrmAppLock(app);
  _MrmProcessLock();

  /*
   * Read the literal, and deal with errors
   */
  UrmGetResourceContext ((char *(*)())NULL, (void(*)())NULL, 0, &context_id);
  result = Urm__FetchLiteral (hierarchy_id, index, context_id, &ctxlist);
  if ( result == MrmSUCCESS ) {
    type = UrmRCType(context_id);
  }
  else
    {
      if ( ctxlist != NULL )
	{
	  for ( ndx=0 ; ndx<UrmPlistNum(ctxlist) ; ndx++ )
	    UrmFreeResourceContext 
	      ((URMResourceContextPtr)UrmPlistPtrN(ctxlist,ndx)) ;
	  UrmPlistFree (ctxlist) ;
	}
      UrmFreeResourceContext (context_id);
      _MrmAppUnlock(app);
      _MrmProcessUnlock();
      return result;
    }

  /*
   * Convert to X pixmap, and free resources
   */
  switch (type) {
  case MrmRtypeIconImage:
    icon = (RGMIconImagePtr)UrmRCBuffer(context_id);
    result = UrmCreateBitmap 
      (icon, screen, display,
       pixmap_return);
    *width = icon->width;
    *height = icon->height;
    break;
    /*
      >>> Andy research here if we can do this for a depth of 1
      case MrmRtypeXBitmapFile:
      result = Urm__CW_ReadBitmapFile (UrmRCBuffer(context_id), screen, 
      fgpix, bgpix, pixmap_return);
      break;
      */
  default:
    result = MrmWRONG_TYPE;
  }

  if ( ctxlist != NULL )
    {
      for ( ndx=0 ; ndx<UrmPlistNum(ctxlist) ; ndx++ )
	UrmFreeResourceContext 
	  ((URMResourceContextPtr)UrmPlistPtrN(ctxlist,ndx)) ;
      UrmPlistFree (ctxlist) ;
    }
  UrmFreeResourceContext (context_id);
  _MrmAppUnlock(app);
  _MrmProcessUnlock();
  return result;

}


/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	This routine fetches a named color literal from a UID file, and
 *	converts it to a pixel value.
 *
 *  FORMAL PARAMETERS:
 *
 *	hierarchy_id	id of an open hierarchy containing the literal
 *	index		index of the desired literal
 *	display		display to use for pixmap
 *	cmap		color map ID. If NULL, the default color map is used
 *	pixel_return	to return the pixel value for the color
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
MrmFetchColorLiteral (MrmHierarchy                hierarchy_id,
		      String                      index,
		      Display                     *display,
		      Colormap                    cmap,
		      Pixel                       *pixel_return)
{

  /*
   *  Local variables
   */
  Cardinal		result;		/* function results */
  URMResourceContextPtr	context_id;	/* for the literal */
  URMPointerListPtr	ctxlist = NULL;	/* save added contexts */
  Cardinal		ndx;		/* loop index */
  RGMColorDescPtr	colorptr;
  char			err_msg[300] ;
  _MrmDisplayToAppContext(display);

  _MrmAppLock(app);
  _MrmProcessLock();

  /*
   * Read the literal, and deal with errors.
   */
  UrmGetResourceContext ((char *(*)())NULL, (void(*)())NULL, 0, &context_id);
  result = Urm__FetchLiteral (hierarchy_id, index, context_id, &ctxlist);
  if ( result == MrmSUCCESS )
    if (UrmRCType(context_id) != MrmRtypeColor)
      result = MrmWRONG_TYPE;
  if ( result != MrmSUCCESS)
    {
      if ( ctxlist != NULL )
	{
	  for ( ndx=0 ; ndx<UrmPlistNum(ctxlist) ; ndx++ )
	    UrmFreeResourceContext 
	      ((URMResourceContextPtr)UrmPlistPtrN(ctxlist,ndx)) ;
	  UrmPlistFree (ctxlist) ;
	}
      UrmFreeResourceContext (context_id);
      _MrmAppUnlock(app);
      _MrmProcessUnlock();
      return result;
    }

  /*
   * Convert to X named color, and free resources
   */
  colorptr = (RGMColorDescPtr) UrmRCBuffer(context_id);

  switch (colorptr->desc_type)
    {
    case URMColorDescTypeName:
      result = Urm__UT_GetNamedColorPixel
	(display, cmap, colorptr, pixel_return, 
	 XBlackPixelOfScreen(XDefaultScreenOfDisplay(display)));
      break;
    case URMColorDescTypeRGB:
      result = Urm__UT_GetColorPixel
	(display, cmap, colorptr, pixel_return,
	 XBlackPixelOfScreen(XDefaultScreenOfDisplay(display)));
      break;
    default:
      sprintf(err_msg, "%s", _MrmMMsg_0040);
      result = Urm__UT_Error ("MrmFetchColorLiteral",
			      err_msg, NULL, NULL, MrmFAILURE) ;
      _MrmAppUnlock(app);
      _MrmProcessUnlock();
      return result;
    };
  UrmFreeResourceContext (context_id);

  /* partial success only returned when a color allocation fails, but
     we've tried to make a reasonable substitution */
  if (result == MrmPARTIAL_SUCCESS) result = MrmSUCCESS;
  _MrmAppUnlock(app);
  _MrmProcessUnlock();
  return result;

}



/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	UrmGetIndexedLiteral searches a single database file for a literal
 *	given its index (i.e. it gets a public literal from a single file).
 *	It returns the literal as the contents of the context buffer. The
 *	group which is fetched is always URMgLiteral. The literal type
 *	filter is taken from the context; if unmodified in the context
 *	as obtained from UrmGetResourceContext, there is no filtering
 *	(type=RGMtNul).
 *
 *	The buffer contents will be as follows for some common literal
 *	types obtained from a .UID file. Note that in some cases that
 *	the caller must fix up offsets to be memory pointers.
 *
 *	UrmRCType(context_id) == MrmRtypeChar8:
 *		UrmRCBuffer(context_id) contains a nul-terminated
 *		ASCII string
 *
 *	UrmRCType(context_id) == MrmRtypeCString:
 *		UrmRCBuffer(context_id) contains a compound string
 *
 *	UrmRCType(context_id) == MrmRtypeChar8Vector:
 *	UrmRCType(context_id) == MrmRtypeCStringVector:
 *		UrmRCBuffer(context_id) contains an RGM text vector
 *		or stringtable (RGMTextVector). The items in the
 *		text vector contain offsets into the buffer which
 *		locate either nul-terminated ASCII strings or compound
 *		compound strings. These may be relocated to memory
 *		pointers by adding the buffer address to the offset, i.e.
 *		item[n].text_item.pointer = item[n].text_item.offset+bufadr
 *
 *  FORMAL PARAMETERS:
 *
 *	file_id		id of an open URM database file (IDB file)
 *	index		index of the desired literal
 *	context_id	resource context into which to read the literal
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *	MrmSUCCESS	operation succeeded
 *	MrmBAD_CONTEXT	invalid resource context
 *	Other		See UrmIdbGetIndexedResource
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
UrmGetIndexedLiteral (IDBFile			file_id ,
		      String			index ,
		      URMResourceContextPtr	context_id )
{

  /*
   *  Local variables
   */
  MrmType		lit_type ;	/* the type of the literal */


  /*
   * Validate context, then attempt the read.
   */
  if ( ! UrmRCValid(context_id) )
    return Urm__UT_Error ("UrmGetIndexedLiteral", _MrmMMsg_0043,
			  file_id, context_id, MrmBAD_CONTEXT) ;

  lit_type = UrmRCType (context_id) ;
  return UrmIdbGetIndexedResource
    (file_id, index, URMgLiteral, lit_type, context_id) ;

}


/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	UrmGetRIDLiteral retrieves a literal from a single database file
 *	given its resource id as an accessor. It returns the literal record.
 *
 *  FORMAL PARAMETERS:
 *
 *	file_id		id of an open URM database file (IDB file)
 *	resource_id	resource id for literal
 *	context_id	literal context in which to return record read in
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *	MrmSUCCESS	operation succeeded
 *	MrmNOT_FOUND	literal not found
 *	MrmFAILURE	operation failed, further reason not given.
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
UrmGetRIDLiteral (IDBFile			file_id ,
		  MrmResource_id		resource_id ,
		  URMResourceContextPtr	context_id )
{

  /*
   *  Local variables
   */
  MrmType		lit_type ;	/* the type of the literal */


  /*
   * Validate context, then attempt the read.
   */
  if ( ! UrmRCValid(context_id) )
    return Urm__UT_Error ("UrmGetRIDLiteral", _MrmMMsg_0043,
			  file_id, context_id, MrmBAD_CONTEXT) ;

  lit_type = UrmRCType (context_id) ;
  return UrmIdbGetRIDResource
    (file_id, resource_id, URMgLiteral, lit_type, context_id) ;

}


/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	Urm__HGetIndexedLiteral is exactly like UrmGetLiteral except
 *	that it searches a hierarchy for the literal rather than reading
 *	from a single file.
 *
 *  FORMAL PARAMETERS:
 *
 *	hierarchy_id	hierarchy to be searched
 *	index		index of the desired literal
 *	context_id	resource context into which to read the literal
 *	file_id_return	to return IDB file in which literal was found
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *	MrmSUCCESS	operation succeeded
 *	MrmBAD_CONTEXT	invalid resource context
 *	Other		See UrmIdbGetIndexedResource
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
Urm__HGetIndexedLiteral (MrmHierarchy		hierarchy_id ,
			 String			index ,
			 URMResourceContextPtr	context_id ,
			 IDBFile		*file_id_return )
{

  /*
   *  Local variables
   */
  MrmType			lit_type ;	/* the type of the literal */

  /*
   * Validate hierarchy and context, then attempt the read.
   */
  if ( hierarchy_id == NULL )
    return Urm__UT_Error ("Urm__HGetIndexedLiteral", _MrmMMsg_0023,
			  NULL, NULL, MrmBAD_HIERARCHY) ;
  if ( ! MrmHierarchyValid(hierarchy_id) )
    return Urm__UT_Error ("Urm__HGetIndexedLiteral", _MrmMMsg_0024,
			  NULL, NULL, MrmBAD_HIERARCHY) ;
  if ( ! UrmRCValid(context_id) )
    return Urm__UT_Error ("Urm__HGetIndexedLiteral", _MrmMMsg_0043,
			  NULL, context_id, MrmBAD_CONTEXT) ;

  lit_type = UrmRCType (context_id) ;
  return UrmHGetIndexedResource
    (hierarchy_id, index, URMgLiteral, lit_type, context_id, file_id_return) ;

}



/*
 *++
 *
 *  PROCEDURE DESCRIPTION:
 *
 *	UrmHGetIndexedLiteral is exactly like UrmGetLiteral except
 *	that it searches a hierarchy for the literal rather than reading
 *	from a single file.
 *
 *  FORMAL PARAMETERS:
 *
 *	hierarchy_id	hierarchy to be searched
 *	index		index of the desired literal
 *	context_id	resource context into which to read the literal
 *
 *  IMPLICIT INPUTS:
 *
 *  IMPLICIT OUTPUTS:
 *
 *  FUNCTION VALUE:
 *
 *	MrmSUCCESS	operation succeeded
 *	MrmBAD_CONTEXT	invalid resource context
 *	Other		See UrmIdbGetIndexedResource
 *
 *  SIDE EFFECTS:
 *
 *--
 */

Cardinal 
UrmHGetIndexedLiteral (MrmHierarchy		hierarchy_id ,
		       String			index ,
		       URMResourceContextPtr	context_id )
{

  /*
   *  Local variables
   */
  IDBFile			dummy ;		/* unused file return */

  return Urm__HGetIndexedLiteral (hierarchy_id, index, context_id, &dummy) ;
}