4.3BSD/usr/ingres/source/h/access.h

Compare this file to the similar file:
Show the results in this format:

#
/*
**  ACCESS.H -- definitions relating to the access methods.
**
**	Version:
**		@(#)access.h	8.2	2/8/85
*/

# ifndef PGSIZE


/*
**	PGSIZE is the physical size of a page.
**	MAXTUP is the maximum size of a tuple, assuming only one
**		tuple on the page.  This is PGSIZE-hdrsize, where
**		hdrsize is the size of the page header (12 bytes).
**	MAXLINENO is the maximum number of tuples on a page
**		assuming minimum size tuples (1 byte).  This is
**		constrained by the size of the lineid field of
**		the tid.
*/

# define	PGSIZE		1024		/* size of page */
# define	MAXTUP		1010		/* max size of a tuple */
# define	MAXLINENO	254		/* max tuples per page */
# define	PGPTRSIZ	4		/* size of a tid */
# define	MAXTUPS		100		/* maximum number of tups */

/* storage structure flags; < 0 means compressed */
# define	M_HEAP		5		/* paged heap */
# define	M_ISAM		11		/* indexed sequential */
# define	M_HASH		21		/* random hash */
# define	M_BTREE		31		/* BTREES */
# define	M_ORDER		41		/* ordered */
# define	M_TRUNC		99		/* internal pseudo-mode: truncated */

# define	NACCBUFS	3		/* number of access method buffers */

/* error flags */
# define	AMREAD_ERR	-1
# define	AMWRITE_ERR	-2
# define	AMNOFILE_ERR	-3	/* can't open file for a relation */
# define	AMREL_ERR	-4	/* can't open relation relation */
# define	AMATTR_ERR	-5	/* can't open attribute relation */
# define	AMNOATTS_ERR	-6	/* attribute missing or xtra in att-rel */
# define	AMCLOSE_ERR	-7	/* can't close relation */
# define	AMFIND_ERR	-8	/* unidentifiable stora  Petructure in find */
# define	AMINVL_ERR	-9	/* invalid TID */
# define	AMOPNVIEW_ERR	-10	/* attempt to open a view for rd or wr */

/* the following is the access methods buffer */
struct accbuf
{
	/* this stuff is actually stored in the relation */
	long		mainpg;		/* next main page (0 - eof) */
	long		ovflopg;	/* next ovflo page (0 - none) */
	short		nxtlino;	/* next avail line no for this page */
	char		firstup[PGSIZE - 12];	/* tuple space */
	short		linetab[1];	/* line table at end of buffer - grows down */
					/* linetab[lineno] is offset into
					** the buffer for that line; linetab[nxtlino]
					** is free space pointer */

	/* this stuff is not stored in the relation */
	long		rel_tupid;	/* unique relation id */
	long		thispage;	/* page number of the current page */
	int		filedesc;	/* file descriptor for this reln */
	struct accbuf	*modf;		/* use time link list forward pointer */
	struct accbuf	*modb;		/* back pointer */
	int		bufstatus;	/* various bits defined below */
};

/* The following assignments are status bits for accbuf.bufstatus */
# define	BUF_DIRTY	001	/* page has been changed */
# define	BUF_LOCKED	002	/* page has a page lock on it */
# define	BUF_DIRECT	004	/* this is a page from isam direct */

/* access method buffer typed differently for various internal operations */
struct
{
	char	acc_buf[NACCBUFS];
};

/* pointers to maintain the buffer */
extern struct accbuf	*Acc_head;	/* head of the LRU list */
extern struct accbuf	*Acc_tail;	/* tail of the LRU list */
extern struct accbuf	Acc_buf[NACCBUFS];	/* the buffers themselves */


/*
**  ADMIN file struct
**
**	The ADMIN struct describes the initial part of the ADMIN file
**	which exists in each database.  This file is used to initially
**	create the database, to maintain some information about the
**	database, and to access the RELATION and ATTRIBUTE relations
**	on OPENR calls.
*/

struct adminhdr
{
	char	adowner[2];	/* user code of data base owner */
	short	adflags;	/* database flags */
	short	adlength;	/* length of adminhdr */
	short	adversion;	/* database format stamp */
	short	adreldsz;	/* length of relation descriptor */
	short	adattdsz;	/* length of attribute descriptor */
};

struct admin
{
	struct adminhdr		adhdr;
	struct descriptor	adreld;
	struct descriptor	adattd;
};

/*
**  Admin status bits
**
**	These bits define the status of the database.  They are
**	contained in the adflags field of the admin struct.
*/

# define	A_DBCONCUR	0000001		/* set database concurrency */
# define	A_QRYMOD	0000002		/* database uses query modification */
# define	A_NEWFMT	0000004		/* database is post-6.2 */


/* following is buffer space for data from admin file */
extern struct admin		Admin;

/*
**  PGTUPLE -- btree index key (a tid and an index key)
*/

struct pgtuple
{
	struct tup_id	childtid;		/* the pointer comes before */
	char		childtup[MAXTUP];
};

/*
** global counters for the number of UNIX read and write
**  requests issued by the access methods.
*/

extern long	Accuread, Accuwrite;

/*
**	Global values used by everything
*/

extern char	*Acctuple;		/* pointer to canonical tuple */
extern		Accerror;		/* error no for fatal errors */
extern char	Accanon[MAXTUP];	/* canonical tuple buffer */


/* Macros for the return values of iutil/add_ovflo.c */
# define	NOBUFFER	-1	/* can't get buffer for overflow page */
# define	NOSETUP		-2	/* can't set up overflow page */
# define	NOGETCURRENT	-3	/* can't get the current page */
# define	NORMVMAIN	-4	/* can't remove the main page */
# define	NOGETOVFLO	-5	/* can't get the overflow page */
# endif PGSIZE