stcu - routines that provide a compilation unit symbol
table interface
#include <syms.h> pCHDRR st_cuinit ();
void st_setchdr(
pCHDRR pchdr ); pCHDRR st_currentpchdr(
void ); void st_free(
void ); long st_extadd(
long iss,
long value,
long st,
long sc,
long index ); pEXTR st_pext_iext(
long iext ); pEXTR st_pext_rndx(
RNDXR rndx ); long st_iextmax(
void ); long st_extstradd(
char *str ); char *st_str_extiss(
long iss ); long st_idn_index_fext(
long index,
long fext ); long st_idn_rndx(
RNDXR rndx ); pRNDXR st_pdn_idn(
long idn ); RNDXR st_rndx_idn(
long idn ); void st_setidn(
long idndest,
long idnsrc );
The stcu() routines provide an interface to objects that
occur once per object rather than once per file descriptor
(for example, external symbols, strings, and dense numbers).
The routines provide access to the current chdr
(compile time hdr), which represents the symbol table in
running processes with pointers to symbol table sections
rather than indices and offsets used in the disk file representation.
A new symbol table can be created with st_cuinit(). This
routine creates and initializes a CHDRR. The CHDRR is the
current chdr and is used in all later calls. Note: A chdr
can also be created with the read routines (see stio(3)).
The st_cuinit() routine returns a pointer to the new CHDRR
record. Returns a pointer the current chdr. Sets the
current chdr to the pchdr argument and sets the per file
structures to reflect a change in symbol tables. Frees
all constituent structures associated with the current
chdr. Lets you add to the externals table. It returns the
index to the new external for future reference and use.
The ifd field for the external is filled in by the current
file (see stfd(3)). Returns pointers to the external,
given a index referencing them. The latter routine
requires a relative index where the index field should be
the index in external symbols and the rfd field should be
the constant ST_EXTIFD. Note: The externals contain the
same structure as symbols (see the SYMR and EXTR definitions).
Returns the current number of entries in the
external symbol table.
The iss field in external symbols (the index into
string space) must point into external string
space. Adds a null-terminated string to the external
string space and returns its index. Converts
that index into a pointer to the external string.
The dense number table provides a convenience to
the code optimizer, generator, and assembler. This
table lets them reference symbols from different
files and externals with unique densely packed numbers.
Returns a new dense number table index,
given an index into the symbol table of the current
file (or if fext is set, the externals table).
Returns a new dense number, but expects a RNDXR to
specify both the file index and the symbol index
rather than implying the file index from the current
file. The RNDXR contains two fields: an index
into the externals table and a file index (rsyms
can point into the symbol table, as well). The file
index is ST_EXTIFD for externals. Returns a RNDX,
given an index into the dense number table.
Returns a pointer to the RNDXR index by the idn
argument.
stfe(3), stfd(3)
stcu(3)
[ Back ] |