/*
* dpsdict.h
*
* (c) Copyright 1988-1994 Adobe Systems Incorporated.
* All rights reserved.
*
* Permission to use, copy, modify, distribute, and sublicense this software
* and its documentation for any purpose and without fee is hereby granted,
* provided that the above copyright notices appear in all copies and that
* both those copyright notices and this permission notice appear in
* supporting documentation and that the name of Adobe Systems Incorporated
* not be used in advertising or publicity pertaining to distribution of the
* software without specific, written prior permission. No trademark license
* to use the Adobe trademarks is hereby granted. If the Adobe trademark
* "Display PostScript"(tm) is used to describe this software, its
* functionality or for any other purpose, such use shall be limited to a
* statement that this software works in conjunction with the Display
* PostScript system. Proper trademark attribution to reflect Adobe's
* ownership of the trademark shall be given whenever any such reference to
* the Display PostScript system is made.
*
* ADOBE MAKES NO REPRESENTATIONS ABOUT THE SUITABILITY OF THE SOFTWARE FOR
* ANY PURPOSE. IT IS PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY.
* ADOBE DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL
* IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NON- INFRINGEMENT OF THIRD PARTY RIGHTS. IN NO EVENT SHALL ADOBE BE LIABLE
* TO YOU OR ANY OTHER PARTY FOR ANY SPECIAL, INDIRECT, OR CONSEQUENTIAL
* DAMAGES OR ANY DAMAGES WHATSOEVER WHETHER IN AN ACTION OF CONTRACT,
* NEGLIGENCE, STRICT LIABILITY OR ANY OTHER ACTION ARISING OUT OF OR IN
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ADOBE WILL NOT
* PROVIDE ANY TRAINING OR OTHER SUPPORT FOR THE SOFTWARE.
*
* Adobe, PostScript, and Display PostScript are trademarks of Adobe Systems
* Incorporated which may be registered in certain jurisdictions
*
* Author: Adobe Systems Incorporated
*/
#ifndef PSWDICT_H
#define PSWDICT_H
#include <X11/X.h>
#include "publictypes.h"
typedef struct _PSWDictRec *PSWDict;
/* Opaque designator for a dictionary */
typedef int PSWDictValue; /* non-negative */
/* PROCEDURES */
/* The name parameters defined below are NULL-terminated C strings.
None of the name parameters are handed off, i.e. the caller is
responsible for managing their storage. */
extern PSWDict DPSCreatePSWDict(integer /* nEntries */);
/* nEntries is a hint. Creates and returns a new dictionary */
extern void DPSDestroyPSWDict(PSWDict /* dict */);
/* Destroys a dictionary */
extern PSWDictValue DPSWDictLookup(PSWDict /* dict */, char * /* name */);
/* -1 => not found. */
extern PSWDictValue DPSWDictEnter
(PSWDict /* dict */, char * /* name */, PSWDictValue /* value */);
/* 0 => normal return (not found)
-1 => found. If found, the old value gets replaced with the new one.
caller must ensure continuing validity of name. */
extern PSWDictValue DPSWDictRemove(PSWDict /* dict */, char * /* name */);
/* -1 => not found. If found, value is returned. */
extern Atom DPSMakeAtom(char * /* name */);
/* name characters are copied. */
#endif /* PSWDICT_H */