home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
PC World Komputer 1996 February
/
PCWK0296.iso
/
sharewar
/
dos
/
program
/
gs300sr1
/
gs300sr1.exe
/
INAME.H
< prev
next >
Wrap
C/C++ Source or Header
|
1994-07-27
|
5KB
|
134 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.
*/
/* iname.h */
/* Name table interface */
/* Define a name table as an opaque type. */
struct name_table_s;
typedef struct name_table_s name_table;
/* Name structure. The name table is a simple chained hash table. */
/* There is an optimization to avoid lookup for operator and other */
/* global names. */
struct name_s {
ushort next_index; /* next name in chain or 0 */
unsigned foreign_string : 1; /* string is allocated statically */
unsigned mark : 1; /* GC mark bit */
unsigned string_size : 14;
#define max_name_string 0x3fff
const byte *string_bytes;
/* pvalue specifies the definition status of the name: */
/* pvalue == pv_no_defn: no definitions */
#define pv_no_defn ((ref *)0)
/* pvalue == pv_other: other status */
#define pv_other ((ref *)1)
#define pv_valid(pvalue) ((unsigned long)(pvalue) > 1)
/* pvalue != pv_no_defn, pvalue != pv_other: pvalue is valid */
ref *pvalue; /* if only defined in systemdict */
/* or userdict, this points to */
/* the value */
};
/*typedef struct name_s name;*/ /* in iref.h */
/* Procedures for the name table. */
/* Allocate and initialize a name table. */
name_table *name_init(P1(gs_memory_t *));
/*
* The size argument for name_ref should be a ushort, but this confuses
* the Apollo compiler. The values of enterflag are:
* -1 -- don't enter (return an error) if missing;
* 0 -- enter if missing, don't copy the string, which was allocated
* statically;
* 1 -- enter if missing, copy the string;
* 2 -- enter if missing, don't copy the string, which was already
* allocated dynamically.
*/
int name_ref(P4(const byte *ptr, uint size, ref *pnref, int enterflag));
void name_string_ref(P2(const ref *pnref, ref *psref));
/* name_enter_string calls name_ref with a (permanent) C string. */
int name_enter_string(P2(const char *str, ref *pnref));
/* name_from_string essentially implements cvn. */
/* It always enters the name, and copies the executable attribute. */
int name_from_string(P2(const ref *psref, ref *pnref));
/* Compare two names for equality. */
#define name_eq(pnref1, pnref2)\
(name_index(pnref1) == name_index(pnref2))
/* Conversion between names and indices. */
#define name_index(pnref) r_size(pnref)
void name_index_ref(P2(uint index /* should be ushort */,
ref *pnref));
name *name_index_ptr(P1(uint index /* should be ushort */));
/*
* The name table is a two-level indexed table, consisting of
* nt_sub_count sub-tables of size nt_sub_size each.
*/
#define nt_log2_sub_size 7
#define nt_sub_size (1 << nt_log2_sub_size)
#define nt_sub_index_mask (nt_sub_size - 1)
#define nt_sub_count (1 << (16 - nt_log2_sub_size))
#define max_name_count ((uint)0xffff)
/*
* We scramble the assignment order within a sub-table, so that
* dictionary lookup doesn't have to scramble the index.
* The scrambling algorithm must have three properties:
* - It must map 0 to 0;
* - It must only scramble the sub-table index;
* - It must be a permutation on the sub-table index.
* We do something very simple for now.
*/
#define name_count_to_index(cnt)\
(((cnt) & (-nt_sub_size)) +\
(((cnt) * 59) & nt_sub_index_mask))
#define max_name_index ((uint)0xffff)
/*
* The reverse permutation requires finding a number R such that
* 59*R = 1 mod nt_sub_size. For nt_sub_size any power of 2 up to 2048,
* R = 243 will work.
*/
#define name_index_to_count(idx)\
(((idx) & (-nt_sub_size)) +\
(((idx) * 243) & nt_sub_index_mask))
/* Name count interface for GC and save/restore. */
uint name_count(P0());
#define name_is_since_count(pnref, ncnt)\
name_index_is_since_count(name_index(pnref), ncnt)
#define name_index_is_since_count(nidx, ncnt)\
(name_index_to_count(nidx) >= ncnt)
gs_memory_t *name_memory(P0());
/* Mark a name for the garbage collector. */
/* Return true if this is a new mark. */
bool name_mark_index(P1(uint));
/* Get the object (sub-table) containing a name. */
/* The garbage collector needs this so it can relocate pointers to names. */
void/*obj_header_t*/ *name_ref_sub_table(P1(ref *));
void/*obj_header_t*/ *name_index_ptr_sub_table(P2(uint, name *));
/* Clean up the name table before a restore, */
/* by removing names whose count is less than old_count. */
void name_restore(P1(uint old_count));