1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/* Copyright (C) 2001-2020 Artifex Software, Inc.
All Rights Reserved.
This software is provided AS-IS with no warranty, either express or
implied.
This software is distributed under license and may not be copied,
modified or distributed except as expressly authorized under the terms
of the license contained in the file LICENSE in this distribution.
Refer to licensing information at http://www.artifex.com or contact
Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
CA 94945, U.S.A., +1(415)492-9861, for further information.
*/
/* This interface is deprecated and will be removed in future
* ghostscript releases. Use the interface described in
* API.htm and iapi.h.
*/
#ifndef gsdll_INCLUDED
# define gsdll_INCLUDED
#include "iapi.h"
#include "windows_.h"
#ifdef __MACOS__
#define HWND char *
#include <QDOffscreen.h>
#pragma export on
#endif
#ifdef __WINDOWS__
#define _Windows
#endif
#ifdef __IBMC__
#define GSDLLCALLLINK _System
#else
#define GSDLLCALLLINK
#endif
/* global pointer to callback */
typedef int (* GSDLLCALLLINK GSDLL_CALLBACK) (int, char *, unsigned long);
extern GSDLL_CALLBACK pgsdll_callback;
/* message values for callback */
#define GSDLL_STDIN 1 /* get count characters to str from stdin */
/* return number of characters read */
#define GSDLL_STDOUT 2 /* put count characters from str to stdout */
/* return number of characters written */
#define GSDLL_DEVICE 3 /* device = str has been opened if count=1 */
/* or closed if count=0 */
#define GSDLL_SYNC 4 /* sync_output for device str */
#define GSDLL_PAGE 5 /* output_page for device str */
#define GSDLL_SIZE 6 /* resize for device str */
/* LOWORD(count) is new xsize */
/* HIWORD(count) is new ysize */
#define GSDLL_POLL 7 /* Called from gp_check_interrupt */
/* Can be used by caller to poll the message queue */
/* Normally returns 0 */
/* To abort gsdll_execute_cont(), return a */
/* non zero error code until gsdll_execute_cont() */
/* returns */
/* return values from gsdll_init() */
#define GSDLL_INIT_IN_USE 100 /* DLL is in use */
#define GSDLL_INIT_QUIT 101 /* quit or EOF during init */
/* This is not an error. */
/* gsdll_exit() must not be called */
/* DLL exported functions */
/* for load time dynamic linking */
GSDLLEXPORT int GSDLLAPI gsdll_revision(const char * * product, const char * * copyright, long * gs_revision, long * gs_revisiondate);
GSDLLEXPORT int GSDLLAPI gsdll_init(GSDLL_CALLBACK callback, HWND hwnd, int argc, char * * argv);
GSDLLEXPORT int GSDLLAPI gsdll_execute_begin(void);
GSDLLEXPORT int GSDLLAPI gsdll_execute_cont(const char * str, int len);
GSDLLEXPORT int GSDLLAPI gsdll_execute_end(void);
GSDLLEXPORT int GSDLLAPI gsdll_exit(void);
GSDLLEXPORT int GSDLLAPI gsdll_lock_device(unsigned char *device, int flag);
/* Function pointer typedefs */
/* for run time dynamic linking */
typedef int (GSDLLAPIPTR PFN_gsdll_revision)(const char ** product,
const char ** copyright, long * revision, long * revisiondate);
typedef int (GSDLLAPIPTR PFN_gsdll_init) (GSDLL_CALLBACK, HWND, int argc, char * * argv);
typedef int (GSDLLAPIPTR PFN_gsdll_init_with_encoding) (GSDLL_CALLBACK, HWND, int argc, char * * argv, int encoding);
#ifdef __WIN32__
typedef int (GSDLLAPIPTR PFN_gsdll_initA) (GSDLL_CALLBACK, HWND, int argc, char * * argv);
typedef int (GSDLLAPIPTR PFN_gsdll_initW) (GSDLL_CALLBACK, HWND, int argc, wchar_t * * argv);
#endif
typedef int (GSDLLAPIPTR PFN_gsdll_execute_begin) (void);
typedef int (GSDLLAPIPTR PFN_gsdll_execute_cont) (const char * str, int len);
typedef int (GSDLLAPIPTR PFN_gsdll_execute_end) (void);
typedef int (GSDLLAPIPTR PFN_gsdll_exit) (void);
typedef int (GSDLLAPIPTR PFN_gsdll_lock_device) (unsigned char *, int);
#ifdef __MACOS__
#pragma export off
#endif
#endif /* gsdll_INCLUDED */
|