/*
 * dosXpreview.h
 *
 * (c) Copyright 1990-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
 */
/* $XFree86$ */

#ifndef DPS_X_PREVIEW_H
#define DPS_X_PREVIEW_H

#include <DPS/dpsXcommon.h>

typedef struct {
	long startPos;
	int nestingLevel;
	unsigned long binaryCount;
	Bool continuedLine;
} XDPSPosition;

#if defined(__cplusplus) || defined(c_plusplus)
extern "C" {
#endif

/* The rewind function should set the file pointer to the beginning of an
   area of interest.
*/

typedef void (*XDPSRewindFunction)(FILE *f,
				   DPSPointer clientData);

/* The gets function should duplicate the behavior of the fgets function,
   but it may return NULL to indicate that the area of interest is over
   even if the end of file is not yet reached.
*/

typedef char *(*XDPSGetsFunction)(char *buf,
				  int n,
				  FILE *f,
				  DPSPointer clientData);

/* XDPSSetFileFunctions defines the functions XDPSCreatePixmapForEPSF and
   XDPSImageFileIntoDrawable will use to reset the file to its beginning
   and to read the next line of the file.
*/

extern int XDPSSetFileFunctions(XDPSRewindFunction rewindFunction,
				DPSPointer rewindClientData,
				XDPSGetsFunction getsFunction,
				DPSPointer getsClientData);

/* The following two functions expect NULL as client data and are appropriate
   for dealing with a separate EPSF file.  They are the default rewind and
   gets functions, and may be used to reset the functions after changing them.
*/

extern void XDPSFileRewindFunc(FILE *f,
			       DPSPointer data);

extern char *XDPSFileGetsFunc(char *buf,
			      int n,
			      FILE *f,
			      DPSPointer data);

/* The following two functions expect the address of an XDPSPosition
   structure as client data and are appropriate for dealing with an ESPF
   file embedded in another file.  The 2.0 document structuring conventions
   %%BeginDocument and %%EndDocument are used to detect the end of the
   included file and to identify any embedded files.  The startPos
   in the XDPSPosition structure should be the first character of the
   embedded file (as found by, for example, ftell).  It must *not* include
   the initial %%BeginDocument comment for this document.  The nestingLevel,
   continuedLine, and binaryCount fields are used internally by the functions
   and should not be modified.  After calling XDPSImageFileIntoDrawable,
   startPos will be modified to be the first character after the complete
   EPSF file, or -1 if the EPSF ended with end-of-file.
*/

extern void XDPSEmbeddedEPSFRewindFunc(FILE *f,
				       DPSPointer data);

extern char *XDPSEmbeddedGetsFunc(char *buf, int n, FILE *f, DPSPointer data);

extern char *XDPSEmbeddedEPSFGetsFunc(char *buf,
				      int n,
				      FILE *f,
				      DPSPointer data);

/* XDPSCreatePixmapForEPSF creates a pixmap for use on the specified screen.
   The size of the pixmap is determined by reading the %%BoundingBox comment
   in the file, scaled by the pixelsPerPoint value.  The size of the
   pixmap is returned in pixelSize (x and y will be zero) and the bounding
   box (in points) is returned in bbox.  The context parameter may be NULL,
   in which case the shared context for the display will be used.  If a real
   context is passed, it must be registered with XDPSRegisterContext.
*/

extern int XDPSCreatePixmapForEPSF(DPSContext context,
				   Screen *screen,
				   FILE *epsf,
				   int depth,
				   double pixelsPerPoint,
				   Pixmap *p,
				   XRectangle *pixelSize,
				   XRectangle *bbox);

/* XDPSPixelsPerPoint returns the number of pixels in one point on the given
   screen.  Note that if the server lies about the resolution of the screen
   (as it often does) the lie will be repeated here. */

extern double XDPSPixelsPerPoint(Screen *screen);

/* XDPSImageFileIntoDrawable images a PostScript file into a drawable.
   The imaging will be offset by the xOffset and yOffset values, these
   must be in points.  If the clear parameter is True, the area defined
   by the bbox will be cleared to white before imaging.  If createMask is
   True, the drawable must be 1 bit deep and it will end up containing a
   1 bit everywhere that the PostScript file images, if clear is also True
   any untouched bits will be 0.  If the drawable is a pixmap, the result
   is suitable for use as a mask in X drawing call.  The context parameter
   may be NULL, in which case the shared context for the display will
   be used.  If a real context is passed, it must be registered with
   XDPSRegisterContext.  

   If waitForCompletion is True, XDPSImageFileIntoDrawable
   will wait for the imaging to be finished before returning.  If
   waitForCompletion parameter is False, XDPSImageFileIntoDrawable will wait
   for a time as specified by the XDPSSetImagingTimeout before returning
   dps_status_imaging_incomplete.  The caller checks for the completion of
   the imaging by calling XDPSCheckImagingResults periodically.

   Partial imaging may be stopped by destroying the context with
   XDPSDestroySharedContext or both DPSDestroyContext and
   XDPSUnregisterContext.  Doing anything with a context between the time
   XDPSImageFileIntoDrawable returns dps_status_imaging_incomplete and the
   time XDPSCheckImagingResults returns other than
   dps_status_imaging_incomplete will yield incorrect imaging
   results and leave the context in an undefined state, don't do it.

   If the display does not support the DPS extension, the image area as
   determined by the bbox parameter will be filled with a 50% gray stipple
   pattern, or set to solid 1's if createMask is True.

   The context parameter may be NULL, in which case the shared context
   for the display will be used.  If a real context is passed, it must
   be registered with XDPSRegisterContext.
*/

extern int XDPSImageFileIntoDrawable(DPSContext context,
				     Screen *screen,
				     Drawable dest,
				     FILE *file,
				     int drawableHeight,
				     int drawableDepth,
				     XRectangle *bbox,
				     int xOffset,
				     int yOffset,
				     double pixelsPerPoint,
				     Bool clear,
				     Bool createMask,
				     Bool waitForCompletion,
				     Bool *doneFlag);

/* XDPSCheckImagingResults checks the status of the imaging on the context.
   If the imaging is not done, it returns dps_status_imaging_incomplete, if
   it is done, it returns dps_status_success or dps_status_postscript_error,
   if the context is not currently involved in imaging it returns
   dps_status_illegal_value.

   The context parameter may be NULL, in which case the shared context
   for the display will be used.  If a real context is passed, it must
   be registered with XDPSRegisterContext.
*/

extern int XDPSCheckImagingResults(DPSContext context,
				   Screen *screen);

/* XDPSSetImagingTimeout determines how long XDPSImageFileIntoDrawable will
   wait before returning after an incomplete imaging, in milliseconds.
   XDPSImageFileIntoDrawable will start by waiting the timeout and will
   repeatedly double the wait until the imaging is complete or until
   maxDoublings have occurred.  */

extern void XDPSSetImagingTimeout(int timeout,
				  int maxDoublings);

#if defined(__cplusplus) || defined(c_plusplus)
}
#endif

#endif /* DPS_X_PREVIEW_H */