home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
PC World Komputer 1996 February
/
PCWK0296.iso
/
sharewar
/
dos
/
program
/
gs300sr1
/
gs300sr1.exe
/
FILES.H
< prev
next >
Wrap
C/C++ Source or Header
|
1994-07-29
|
5KB
|
125 lines
/* Copyright (C) 1989, 1992, 1993, 1994 Aladdin Enterprises. All rights reserved.
This file is part of Aladdin Ghostscript.
Aladdin Ghostscript is distributed with NO WARRANTY OF ANY KIND. No author
or distributor accepts any responsibility for the consequences of using it,
or for whether it serves any particular purpose or works at all, unless he
or she says so in writing. Refer to the Aladdin Ghostscript Free Public
License (the "License") for full details.
Every copy of Aladdin Ghostscript must include a copy of the License,
normally in a plain ASCII text file named PUBLIC. The License grants you
the right to copy, modify and redistribute Aladdin Ghostscript, but only
under certain conditions described in the License. Among other things, the
License requires that the copyright notice and this notice be preserved on
all copies.
*/
/* files.h */
/* Common declarations for zfile.c and zfileio.c */
/* Requires stream.h */
/*
* File objects store a pointer to a stream in value.pfile.
* A file object is valid if its "size" matches the read_id or write_id
* (as appropriate) in the stream it points to. This arrangement
* allows us to detect closed files reliably, while allowing us to
* reuse closed streams for new files.
*/
#define fptr(pref) (pref)->value.pfile
#define make_file(pref,a,id,s)\
make_tasv(pref,t_file,a,id,pfile,s)
/* The standard files. */
extern stream *gs_stream_stdin;
extern bool gs_stdin_is_interactive;
extern stream *gs_stream_stdout;
extern stream *gs_stream_stderr;
/* An invalid file. */
extern stream *invalid_file_entry;
/* Macros for checking file validity. */
#define check_file_access(svar,op,acc)\
{ svar = fptr(op); /* do first, acc may refer to it */\
if ( !(acc) ) return_error(e_invalidaccess);\
}
#define file_is_valid(svar,op)\
(svar = fptr(op), (svar->read_id | svar->write_id) == r_size(op))
#define check_file(svar,op)\
{ check_type(*(op), t_file);\
if ( !file_is_valid(svar, op) ) return_error(e_invalidaccess);\
}
/*
* If a file is open for both reading and writing, its read_id, write_id,
* and stream procedures and modes reflect the current mode of use;
* an id check failure will switch it to the other mode.
*/
int file_switch_to_read(P1(ref *));
#define check_read_file(svar,op)\
{ check_read_type(*(op), t_file);\
check_read_known_file(svar, op, svar = invalid_file_entry);\
}
#define check_read_known_file(svar,op,invalid_action)\
{ svar = fptr(op);\
if ( svar->read_id != r_size(op) )\
{ if ( svar->read_id == 0 && svar->write_id == r_size(op) )\
{ int fcode = file_switch_to_read(op);\
if ( fcode < 0 ) return fcode;\
}\
else invalid_action; /* closed or reopened file */\
}\
}
int file_switch_to_write(P1(ref *));
#define check_write_file(svar,op)\
{ check_write_type(*(op), t_file);\
check_write_known_file(svar, op);\
}
#define check_write_known_file(svar,op)\
{ svar = fptr(op);\
if ( svar->write_id != r_size(op) )\
{ int fcode = file_switch_to_write(op);\
if ( fcode < 0 ) return fcode;\
}\
}
/* Data exported by zfile.c. */
/* for zfilter.c and ziodev.c */
extern const uint file_default_buffer_size;
/* Procedures exported by zfile.c. */
/* for gs.c */
FILE *lib_fopen(P1(const char *));
/* for gsmain.c */
int lib_file_open(P6(const char *, uint, byte *, uint, uint *, ref *));
/* for gsmain.c and iccinit.c */
int file_read_string(P3(const byte *, uint, ref *));
/* for os_open in ziodev.c */
#ifdef iodev_proc_fopen /* in gxiodev.h */
int file_open_stream(P6(const char *, uint, const char *, uint,
stream **, iodev_proc_fopen_t));
#endif
/* for zfilter.c */
int filter_open(P7(const char *, uint, ref *, const stream_procs _ds *,
const stream_template *, const stream_state *, stream **));
int file_ensure_buf(P2(stream *, uint));
/* for zfileio.c */
void make_stream_file(P3(ref *, stream *, const char *));
/* for ziodev.c */
int file_close_finish(P1(stream *));
int file_close_disable(P1(stream *));
/* for gsmain.c, interp.c */
int file_close(P1(ref *));
/* for ziodev.c */
stream *file_alloc_stream(P0());
/* for isave.c */
void file_save(P0());
/*void file_restore(P1(const alloc_save *));*/
/* Procedures exported by zfileio.c. */
/* for ziodev.c */
int zreadline_from(P5(stream *, byte *, uint, uint *, bool *));
/* for interp.c */
int file_check_read(P2(ref *, stream **));