diff options
| author | Bruce Momjian <bruce@momjian.us> | 1998-08-06 05:13:14 +0000 | 
|---|---|---|
| committer | Bruce Momjian <bruce@momjian.us> | 1998-08-06 05:13:14 +0000 | 
| commit | af5fde7491670e2deb7966a99c25a9b69b7bc86f (patch) | |
| tree | 16cabda6c2ea1a8ca37fbbe97e5f5ae75e171b4d /src/include | |
| parent | 8962ec4bc4a0020ad60089250647fb2264cfd258 (diff) | |
Make large objects their own relkind type.  Fix dups in pg_class_mb
files.  Fix sequence creation hack for relkind type.
Diffstat (limited to 'src/include')
| -rw-r--r-- | src/include/catalog/heap.h | 5 | ||||
| -rw-r--r-- | src/include/catalog/pg_attribute_mb.h | 469 | ||||
| -rw-r--r-- | src/include/catalog/pg_class.h | 3 | ||||
| -rw-r--r-- | src/include/catalog/pg_class_mb.h | 167 | ||||
| -rw-r--r-- | src/include/catalog/pg_database_mb.h | 60 | ||||
| -rw-r--r-- | src/include/commands/creatinh.h | 4 | 
6 files changed, 10 insertions, 698 deletions
| diff --git a/src/include/catalog/heap.h b/src/include/catalog/heap.h index e43ac0cd0e7..3caebe74449 100644 --- a/src/include/catalog/heap.h +++ b/src/include/catalog/heap.h @@ -6,7 +6,7 @@   *   * Copyright (c) 1994, Regents of the University of California   * - * $Id: heap.h,v 1.12 1998/02/26 04:40:38 momjian Exp $ + * $Id: heap.h,v 1.13 1998/08/06 05:13:01 momjian Exp $   *   *-------------------------------------------------------------------------   */ @@ -17,7 +17,8 @@  extern Relation heap_create(char *relname, TupleDesc att); -extern Oid	heap_create_with_catalog(char relname[], TupleDesc tupdesc); +extern Oid	heap_create_with_catalog(char *relname, +									 TupleDesc tupdesc, char relkind);  extern void heap_destroy_with_catalog(char relname[]);  extern void heap_destroy(Relation r); diff --git a/src/include/catalog/pg_attribute_mb.h b/src/include/catalog/pg_attribute_mb.h index de5adbae3ec..c7cbfa30ec9 100644 --- a/src/include/catalog/pg_attribute_mb.h +++ b/src/include/catalog/pg_attribute_mb.h @@ -7,474 +7,7 @@   *   * Copyright (c) 1994, Regents of the University of California   * - * $Id: pg_attribute_mb.h,v 1.1 1998/07/27 03:21:57 scrappy Exp $ - * - * NOTES - *	  the genbki.sh script reads this file and generates .bki - *	  information from the DATA() statements. - * - *	  utils/cache/relcache.c requires some hard-coded tuple descriptors - *	  for some of the system catalogs so if the schema for any of - *	  these changes, be sure and change the appropriate Schema_xxx - *	  macros!  -cim 2/5/91 - * - *------------------------------------------------------------------------- - */ -#ifndef PG_ATTRIBUTE_H -#define PG_ATTRIBUTE_H - -/* ---------------- - *		postgres.h contains the system type definintions and the - *		CATALOG(), BOOTSTRAP and DATA() sugar words so this file - *		can be read by both genbki.sh and the C compiler. - * ---------------- - */ - -/* ---------------- - *		pg_attribute definition.  cpp turns this into - *		typedef struct FormData_pg_attribute - * - *		If you change the following, make sure you change the structs for - *		system attributes in heap.c and index.c also. - * ---------------- - */ -CATALOG(pg_attribute) BOOTSTRAP -{ -	Oid			attrelid; -	NameData	attname; -	Oid			atttypid; - -	/* -	 * atttypid is the OID of the instance in Catalog Class pg_type that -	 * defines the data type of this attribute (e.g. int4).  Information -	 * in that instance is redundant with the attlen, attbyval, and -	 * attalign attributes of this instance, so they had better match or -	 * Postgres will fail. -	 */ -	float4		attdisbursion; -	int2		attlen; - -	/* -	 * attlen is a copy of the typlen field from pg_type for this -	 * attribute.  See atttypid above.	See struct TypeTupleFormData for -	 * definition. -	 */ -	int2		attnum; - -	/* -	 * attnum is the "attribute number" for the attribute:	A value that -	 * uniquely identifies this attribute within its class. For user -	 * attributes, Attribute numbers are greater than 0 and not greater -	 * than the number of attributes in the class. I.e. if the Class -	 * pg_class says that Class XYZ has 10 attributes, then the user -	 * attribute numbers in Class pg_attribute must be 1-10. -	 * -	 * System attributes have attribute numbers less than 0 that are unique -	 * within the class, but not constrained to any particular range. -	 * -	 * Note that (attnum - 1) is often used as the index to an array. -	 */ -	int4		attnelems; - -	int4		attcacheoff; - -	/* -	 * fastgetattr() uses attcacheoff to cache byte offsets of attributes -	 * in heap tuples.	The data actually stored in pg_attribute (-1) -	 * indicates no cached value.  But when we copy these tuples into a -	 * tuple descriptor, we may then update attcacheoff in the copies. -	 * This speeds up the attribute walking process. -	 */ - -	int4		atttypmod; - -	/* -	 * atttypmod records type-specific modifications supplied at table -	 * creation time, and passes it to input and output functions as the -	 * third argument. -	 */ - -	bool		attbyval; - -	/* -	 * attbyval is a copy of the typbyval field from pg_type for this -	 * attribute.  See atttypid above.	See struct TypeTupleFormData for -	 * definition. -	 */ -	bool		attisset; -	char		attalign; - -	/* -	 * attalign is a copy of the typalign field from pg_type for this -	 * attribute.  See atttypid above.	See struct TypeTupleFormData for -	 * definition. -	 */ -	bool		attnotnull; - -	/* This flag represents the "NOT NULL" constraint */ -	bool		atthasdef; - -	/* Has DEFAULT value or not */ -} FormData_pg_attribute; - -/* - * someone should figure out how to do this properly. (The problem is - * the size of the C struct is not the same as the size of the tuple.) - */ -#define ATTRIBUTE_TUPLE_SIZE \ -	(offsetof(FormData_pg_attribute,atthasdef) + sizeof(char)) - -/* ---------------- - *		Form_pg_attribute corresponds to a pointer to a tuple with - *		the format of pg_attribute relation. - * ---------------- - */ -typedef FormData_pg_attribute *AttributeTupleForm; - -/* ---------------- - *		compiler constants for pg_attribute - * ---------------- - */ - -#define Natts_pg_attribute				14 -#define Anum_pg_attribute_attrelid		1 -#define Anum_pg_attribute_attname		2 -#define Anum_pg_attribute_atttypid		3 -#define Anum_pg_attribute_attdisbursion 4 -#define Anum_pg_attribute_attlen		5 -#define Anum_pg_attribute_attnum		6 -#define Anum_pg_attribute_attnelems		7 -#define Anum_pg_attribute_attcacheoff	8 -#define Anum_pg_attribute_atttypmod		9 -#define Anum_pg_attribute_attbyval		10 -#define Anum_pg_attribute_attisset		11 -#define Anum_pg_attribute_attalign		12 -#define Anum_pg_attribute_attnotnull	13 -#define Anum_pg_attribute_atthasdef		14 - - -/* ---------------- - *		SCHEMA_ macros for declaring hardcoded tuple descriptors. - *		these are used in utils/cache/relcache.c - * ---------------- -#define SCHEMA_NAME(x) CppConcat(Name_,x) -#define SCHEMA_DESC(x) CppConcat(Desc_,x) -#define SCHEMA_NATTS(x) CppConcat(Natts_,x) -#define SCHEMA_DEF(x) \ -	FormData_pg_attribute \ -	SCHEMA_DESC(x) [ SCHEMA_NATTS(x) ] = \ -	{ \ -		CppConcat(Schema_,x) \ -	} - */ - -/* ---------------- - *		initial contents of pg_attribute - * ---------------- - */ - -/* ---------------- - *		pg_type schema - * ---------------- - */ -#define Schema_pg_type \ -{ 1247, {"typname"},	   19, 0, NAMEDATALEN,  1, 0, -1, -1, '\0', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typowner"},	   26, 0,	4,	2, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typlen"},		   21, 0,	2,	3, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1247, {"typprtlen"},     21, 0,	2,	4, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1247, {"typbyval"},	   16, 0,	1,	5, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1247, {"typtype"},	   18, 0,	1,	6, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1247, {"typisdefined"},  16, 0,	1,	7, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1247, {"typdelim"},	   18, 0,	1,	8, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1247, {"typrelid"},	   26, 0,	4,	9, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typelem"},	   26, 0,	4, 10, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typinput"},	   24, 0,	4, 11, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typoutput"},     24, 0,	4, 12, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typreceive"},    24, 0,	4, 13, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typsend"},	   24, 0,	4, 14, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1247, {"typalign"},	   18, 0,	1, 15, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1247, {"typdefault"},    25, 0,  -1, 16, 0, -1, -1, '\0'	, '\0', 'i', '\0', '\0' } - -DATA(insert OID = 0 ( 1247 typname			19 0 NAMEDATALEN   1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1247 typowner			26 0  4   2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 typlen			21 0  2   3 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1247 typprtlen		21 0  2   4 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1247 typbyval			16 0  1   5 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1247 typtype			18 0  1   6 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1247 typisdefined		16 0  1   7 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1247 typdelim			18 0  1   8 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1247 typrelid			26 0  4   9 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 typelem			26 0  4  10 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 typinput			24 0  4  11 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 typoutput		24 0  4  12 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 typreceive		24 0  4  13 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 typsend			24 0  4  14 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 typalign			18 0  1  15 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1247 typdefault		25 0 -1  16 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1247 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1247 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1247 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1247 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1247 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_database - * ---------------- - */ -DATA(insert OID = 0 ( 1262 datname			19 0 NAMEDATALEN   1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1262 datdba			23 0  4   2 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1262 encoding			23 0  4   3 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1262 datpath			25 0 -1   4 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1262 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1262 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1262 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1262 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1262 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1262 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_proc - * ---------------- - */ -#define Schema_pg_proc \ -{ 1255, {"proname"},			19, 0, NAMEDATALEN,  1, 0, -1, -1, '\0', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"proowner"},			26, 0,  4,  2, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"prolang"},			26, 0,  4,  3, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"proisinh"},			16, 0,  1,  4, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1255, {"proistrusted"},		16, 0,  1,  5, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1255, {"proiscachable"},		16, 0,  1,  6, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1255, {"pronargs"},			21, 0,  2,  7, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1255, {"proretset"},			16, 0,  1,  8, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1255, {"prorettype"},			26, 0,  4,  9, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"proargtypes"},		30, 0, 32, 10, 0, -1, -1,	'\0', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"probyte_pct"},		23, 0,  4, 11, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"properbyte_cpu"},		23, 0,  4, 12, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"propercall_cpu"},		23, 0,  4, 13, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"prooutin_ratio"},		23, 0,  4, 14, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"prosrc"},				25, 0, -1,  15,	0, -1, -1, '\0', '\0', 'i', '\0', '\0' }, \ -{ 1255, {"probin"},				17, 0, -1,  16,	0, -1, -1, '\0', '\0', 'i', '\0', '\0' } - -DATA(insert OID = 0 ( 1255 proname			19 0 NAMEDATALEN   1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1255 proowner			26 0  4   2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 prolang			26 0  4   3 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 proisinh			16 0  1   4 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1255 proistrusted		16 0  1   5 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1255 proiscachable	16 0  1   6 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1255 pronargs			21 0  2   7 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1255 proretset		16 0  1   8 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1255 prorettype		26 0  4   9 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 proargtypes		30 0 32  10 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1255 probyte_pct		23 0  4  11 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 properbyte_cpu	23 0  4  12 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 propercall_cpu	23 0  4  13 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 prooutin_ratio	23 0  4  14 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 prosrc			25 0 -1  15 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1255 probin			17 0 -1  16 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1255 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1255 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1255 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1255 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1255 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_shadow - * ---------------- - */ -DATA(insert OID = 0 ( 1260 usename		19	0 NAMEDATALEN	1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1260 usesysid		23	0	4	2 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1260 usecreatedb	16	0	1	3 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1260 usetrace		16	0	1	4 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1260 usesuper		16	0	1	5 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1260 usecatupd	16	0	1	6 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1260 passwd		25	0  -1	7 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1260 valuntil		702 0	4	8 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1260 ctid			27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1260 oid			26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1260 xmin			28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1260 cmin			29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1260 xmax			28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1260 cmax			29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_group - * ---------------- - */ -DATA(insert OID = 0 ( 1261 groname			19 0 NAMEDATALEN  1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1261 grosysid			23 0  4   2 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1261 grolist		  1007 0 -1   3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1261 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1261 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1261 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1261 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1261 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1261 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_attribute - * ---------------- - */ -#define Schema_pg_attribute \ -{ 1249, {"attrelid"},	  26, 0,	4,	1, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1249, {"attname"},	  19, 0, NAMEDATALEN,	2, 0, -1, -1, '\0', '\0', 'i', '\0', '\0' }, \ -{ 1249, {"atttypid"},	  26, 0,	4,	3, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1249, {"attdisbursion"}, 700, 0,	4,	4, 0, -1, -1, '\0', '\0', 'i', '\0', '\0' }, \ -{ 1249, {"attlen"},		  21, 0,	2,	5, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1249, {"attnum"},		  21, 0,	2,	6, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1249, {"attnelems"},	  23, 0,	4,	7, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1249, {"attcacheoff"},  23, 0,	4,	8, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1249, {"atttypmod"},	  21, 0,	4,	9, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1249, {"attbyval"},	  16, 0,	1, 10, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1249, {"attisset"},	  16, 0,	1, 11, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1249, {"attalign"},	  18, 0,	1, 12, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1249, {"attnotnull"},  16, 0,	1, 13, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1249, {"atthasdef"},   16, 0,	1, 14, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' } - -DATA(insert OID = 0 ( 1249 attrelid			26 0  4   1 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1249 attname			19 0 NAMEDATALEN  2 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1249 atttypid			26 0  4   3 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1249 attdisbursion   700 0  4   4 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1249 attlen			21 0  2   5 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1249 attnum			21 0  2   6 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1249 attnelems		23 0  4   7 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1249 attcacheoff		23 0  4   8 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1249 atttypmod		21 0  4   9 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1249 attbyval			16 0  1  10 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1249 attisset			16 0  1  11 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1249 attalign			18 0  1  12 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1249 attnotnull		16 0  1  13 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1249 atthasdef		16 0  1  14 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1249 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1249 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1249 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1249 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1249 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1249 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_class - * ---------------- - */ -#define Schema_pg_class \ -{ 1259, {"relname"},	   19, 0, NAMEDATALEN,  1, 0, -1, -1, '\0', '\0', 'i', '\0', '\0' }, \ -{ 1259, {"reltype"},	   26, 0,	4,	2, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1259, {"relowner"},	   26, 0,	4,	3, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1259, {"relam"},		   26, 0,	4,	4, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1259, {"relpages"},	   23,	0,  4,  5, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1259, {"reltuples"},     23,	0,  4,  6, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' }, \ -{ 1259, {"relhasindex"},   16,	0,  1,  7, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1259, {"relisshared"},   16,	0,  1,  8, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1259, {"relkind"},	   18,	0,  1,  9, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1259, {"relnatts"},	   21,	0,  2, 10, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1259, {"relchecks"},     21, 0,	2, 11, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1259, {"reltriggers"},   21, 0,	2, 12, 0, -1, -1, '\001', '\0', 's', '\0', '\0' }, \ -{ 1259, {"relhasrules"},   16,	0,  1, 13, 0, -1, -1, '\001', '\0', 'c', '\0', '\0' }, \ -{ 1259, {"relacl"},	 	 1034, 0, -1, 14, 0, -1, -1,	'\0', '\0', 'i', '\0', '\0' } - -DATA(insert OID = 0 ( 1259 relname			19 0 NAMEDATALEN   1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1259 reltype			26 0  4   2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1259 relowner			26 0  4   3 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1259 relam			26 0  4   4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1259 relpages			23 0  4   5 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1259 reltuples		23 0  4   6 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1259 relhasindex		16 0  1   7 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1259 relisshared		16 0  1   8 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1259 relkind			18 0  1   9 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1259 relnatts			21 0  2  10 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1259 relchecks		21 0  2  11 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1259 reltriggers		21 0  2  12 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1259 relhasrules		16 0  1  13 0 -1 -1 t f c f f)); -DATA(insert OID = 0 ( 1259 relacl		  1034 0 -1  14 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1259 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1259 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1259 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1259 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1259 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1259 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_attrdef - * ---------------- - */ -DATA(insert OID = 0 ( 1215 adrelid			26 0  4   1 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1215 adnum			21 0  2   2 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1215 adbin			25 0 -1   3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1215 adsrc			25 0 -1   4 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1215 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1215 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1215 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1215 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1215 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1215 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_relcheck - * ---------------- - */ -DATA(insert OID = 0 ( 1216 rcrelid			26 0  4   1 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1216 rcname			19 0  NAMEDATALEN  2 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1216 rcbin			25 0 -1   3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1216 rcsrc			25 0 -1   4 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1216 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1216 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1216 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1216 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1216 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1216 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_trigger - * ---------------- - */ -DATA(insert OID = 0 ( 1219 tgrelid			26 0  4   1 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1219 tgname			19 0  NAMEDATALEN  2 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1219 tgfoid			26 0  4   3 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1219 tgtype			21 0  2   4 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1219 tgnargs			21 0  2   5 0 -1 -1 t f s f f)); -DATA(insert OID = 0 ( 1219 tgattr			22 0 16   6 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1219 tgargs			17 0 -1   7 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1219 ctid				27 0  6  -1 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1219 oid				26 0  4  -2 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1219 xmin				28 0  4  -3 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1219 cmin				29 0  4  -4 0 -1 -1 t f i f f)); -DATA(insert OID = 0 ( 1219 xmax				28 0  4  -5 0 -1 -1 f f i f f)); -DATA(insert OID = 0 ( 1219 cmax				29 0  4  -6 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_variable - this relation is modified by special purpose access - *				  method code.	The following is garbage but is needed - *				  so that the reldesc code works properly. - * ---------------- - */ -#define Schema_pg_variable \ -{ 1264, {"varfoo"},  26, 0, 4, 1, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' } - -DATA(insert OID = 0 ( 1264 varfoo			26 0  4   1 0 -1 -1 t f i f f)); - -/* ---------------- - *		pg_log - this relation is modified by special purpose access - *				  method code.	The following is garbage but is needed - *				  so that the reldesc code works properly. - * ---------------- - */ -#define Schema_pg_log \ -{ 1269, {"logfoo"},  26, 0, 4, 1, 0, -1, -1, '\001', '\0', 'i', '\0', '\0' } - -DATA(insert OID = 0 ( 1269 logfoo			26 0  4   1 0 -1 -1 t f i f f)); - -#endif							/* PG_ATTRIBUTE_H */ - -/*------------------------------------------------------------------------- - * - * pg_attribute.h-- - *	  definition of the system "attribute" relation (pg_attribute) - *	  along with the relation's initial contents. - * - * - * Copyright (c) 1994, Regents of the University of California - * - * $Id: pg_attribute_mb.h,v 1.1 1998/07/27 03:21:57 scrappy Exp $ + * $Id: pg_attribute_mb.h,v 1.2 1998/08/06 05:13:03 momjian Exp $   *   * NOTES   *	  the genbki.sh script reads this file and generates .bki diff --git a/src/include/catalog/pg_class.h b/src/include/catalog/pg_class.h index 223c60f8945..1702a2e0e1d 100644 --- a/src/include/catalog/pg_class.h +++ b/src/include/catalog/pg_class.h @@ -7,7 +7,7 @@   *   * Copyright (c) 1994, Regents of the University of California   * - * $Id: pg_class.h,v 1.20 1998/02/26 04:40:52 momjian Exp $ + * $Id: pg_class.h,v 1.21 1998/08/06 05:13:05 momjian Exp $   *   * NOTES   *	  ``pg_relation'' is being replaced by ``pg_class''.  currently @@ -157,6 +157,7 @@ DESCR("");  #define RelOid_pg_trigger		1219  #define		  RELKIND_INDEX			  'i'		/* secondary index */ +#define		  RELKIND_LOBJECT		  'l'		/* large objects */  #define		  RELKIND_RELATION		  'r'		/* cataloged heap */  #define		  RELKIND_SPECIAL		  's'		/* special (non-heap) */  #define		  RELKIND_SEQUENCE		  'S'		/* SEQUENCE relation */ diff --git a/src/include/catalog/pg_class_mb.h b/src/include/catalog/pg_class_mb.h index 09bc745d120..5135e4403aa 100644 --- a/src/include/catalog/pg_class_mb.h +++ b/src/include/catalog/pg_class_mb.h @@ -7,172 +7,7 @@   *   * Copyright (c) 1994, Regents of the University of California   * - * $Id: pg_class_mb.h,v 1.1 1998/07/27 03:21:58 scrappy Exp $ - * - * NOTES - *	  ``pg_relation'' is being replaced by ``pg_class''.  currently - *	  we are only changing the name in the catalogs but someday the - *	  code will be changed too. -cim 2/26/90 - *	  [it finally happens.	-ay 11/5/94] - * - *	  the genbki.sh script reads this file and generates .bki - *	  information from the DATA() statements. - * - *------------------------------------------------------------------------- - */ -#ifndef PG_RELATION_H -#define PG_RELATION_H - -/* ---------------- - *		postgres.h contains the system type definintions and the - *		CATALOG(), BOOTSTRAP and DATA() sugar words so this file - *		can be read by both genbki.sh and the C compiler. - * ---------------- - */ - -/* ---------------- - *		pg_class definition.  cpp turns this into - *		typedef struct FormData_pg_class - * - *		Note: the #if 0, #endif around the BKI_BEGIN.. END block - *			  below keeps cpp from seeing what is meant for the - *			  genbki script: pg_relation is now called pg_class, but - *			  only in the catalogs -cim 2/26/90 - * ---------------- - */ - -/* ---------------- - *		This structure is actually variable-length (the last attribute is - *		a POSTGRES array).	Hence, sizeof(FormData_pg_class) does not - *		describe the fixed-length or actual size of the structure. - *		FormData_pg_class.relacl may not be correctly aligned, either, - *		if aclitem and struct varlena don't align together.  Hence, - *		you MUST use heap_getattr() to get the relacl field. - * ---------------- - */ -CATALOG(pg_class) BOOTSTRAP -{ -	NameData	relname; -	Oid			reltype; -	Oid			relowner; -	Oid			relam; -	int4		relpages; -	int4		reltuples; -	bool		relhasindex; -	bool		relisshared; -	char		relkind; -	int2		relnatts; - -	/* -	 * relnatts is the number of user attributes this class has.  There -	 * must be exactly this many instances in Class pg_attribute for this -	 * class which have attnum > 0 (= user attribute). -	 */ -	int2		relchecks;		/* # of CHECK constraints, not stored in -								 * db? */ -	int2		reltriggers;	/* # of TRIGGERs */ -	bool		relhasrules; -	aclitem		relacl[1];		/* this is here for the catalog */ -} FormData_pg_class; - -#define CLASS_TUPLE_SIZE \ -	 (offsetof(FormData_pg_class,relhasrules) + sizeof(bool)) - -/* ---------------- - *		Form_pg_class corresponds to a pointer to a tuple with - *		the format of pg_class relation. - * ---------------- - */ -typedef FormData_pg_class *Form_pg_class; - -/* ---------------- - *		compiler constants for pg_class - * ---------------- - */ - -/* ---------------- - *		Natts_pg_class_fixed is used to tell routines that insert new - *		pg_class tuples (as opposed to replacing old ones) that there's no - *		relacl field. - * ---------------- - */ -#define Natts_pg_class_fixed			13 -#define Natts_pg_class					14 -#define Anum_pg_class_relname			1 -#define Anum_pg_class_reltype			2 -#define Anum_pg_class_relowner			3 -#define Anum_pg_class_relam				4 -#define Anum_pg_class_relpages			5 -#define Anum_pg_class_reltuples			6 -#define Anum_pg_class_relhasindex		7 -#define Anum_pg_class_relisshared		8 -#define Anum_pg_class_relkind			9 -#define Anum_pg_class_relnatts			10 -#define Anum_pg_class_relchecks			11 -#define Anum_pg_class_reltriggers		12 -#define Anum_pg_class_relhasrules		13 -#define Anum_pg_class_relacl			14 - -/* ---------------- - *		initial contents of pg_class - * ---------------- - */ - -DATA(insert OID = 1247 (  pg_type 71		  PGUID 0 0 0 f f r 16 0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1249 (  pg_attribute 75	  PGUID 0 0 0 f f r 14 0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1255 (  pg_proc 81		  PGUID 0 0 0 f f r 16 0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1259 (  pg_class 83		  PGUID 0 0 0 f f r 14 0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1260 (  pg_shadow 86		  PGUID 0 0 0 f t r 8  0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1261 (  pg_group 87		  PGUID 0 0 0 f t s 3  0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1262 (  pg_database 88	  PGUID 0 0 0 f t r 4  0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1264 (  pg_variable 90	  PGUID 0 0 0 f t s 2  0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1269 (  pg_log  99		  PGUID 0 0 0 f t s 1  0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1215 (  pg_attrdef 109	  PGUID 0 0 0 t t r 4  0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1216 (  pg_relcheck 110	  PGUID 0 0 0 t t r 4  0 0 f _null_ )); -DESCR(""); -DATA(insert OID = 1219 (  pg_trigger 111	  PGUID 0 0 0 t t r 7  0 0 f _null_ )); -DESCR(""); - -#define RelOid_pg_type			1247 -#define RelOid_pg_attribute		1249 -#define RelOid_pg_proc			1255 -#define RelOid_pg_class			1259 -#define RelOid_pg_shadow		1260 -#define RelOid_pg_group			1261 -#define RelOid_pg_database		1262 -#define RelOid_pg_variable		1264 -#define RelOid_pg_log			1269 -#define RelOid_pg_attrdef		1215 -#define RelOid_pg_relcheck		1216 -#define RelOid_pg_trigger		1219 - -#define		  RELKIND_INDEX			  'i'		/* secondary index */ -#define		  RELKIND_RELATION		  'r'		/* cataloged heap */ -#define		  RELKIND_SPECIAL		  's'		/* special (non-heap) */ -#define		  RELKIND_SEQUENCE		  'S'		/* SEQUENCE relation */ -#define		  RELKIND_UNCATALOGED	  'u'		/* temporary heap */ - -#endif							/* PG_RELATION_H */ -/*------------------------------------------------------------------------- - * - * pg_class.h-- - *	  definition of the system "relation" relation (pg_class) - *	  along with the relation's initial contents. - * - * - * Copyright (c) 1994, Regents of the University of California - * - * $Id: pg_class_mb.h,v 1.1 1998/07/27 03:21:58 scrappy Exp $ + * $Id: pg_class_mb.h,v 1.2 1998/08/06 05:13:07 momjian Exp $   *   * NOTES   *	  ``pg_relation'' is being replaced by ``pg_class''.  currently diff --git a/src/include/catalog/pg_database_mb.h b/src/include/catalog/pg_database_mb.h index a9ff602a6fc..0b778a5d509 100644 --- a/src/include/catalog/pg_database_mb.h +++ b/src/include/catalog/pg_database_mb.h @@ -7,65 +7,7 @@   *   * Copyright (c) 1994, Regents of the University of California   * - * $Id: pg_database_mb.h,v 1.1 1998/07/27 03:21:58 scrappy Exp $ - * - * NOTES - *	  the genbki.sh script reads this file and generates .bki - *	  information from the DATA() statements. - * - *------------------------------------------------------------------------- - */ -#ifndef PG_DATABASE_H -#define PG_DATABASE_H - -/* ---------------- - *		postgres.h contains the system type definintions and the - *		CATALOG(), BOOTSTRAP and DATA() sugar words so this file - *		can be read by both genbki.sh and the C compiler. - * ---------------- - */ - -/* ---------------- - *		pg_database definition.  cpp turns this into - *		typedef struct FormData_pg_database - * ---------------- - */ -CATALOG(pg_database) BOOTSTRAP -{ -	NameData	datname; -	int4		datdba; -	int4		encoding; -	text		datpath;		/* VARIABLE LENGTH FIELD */ -} FormData_pg_database; -/* ---------------- - *		Form_pg_database corresponds to a pointer to a tuple with - *		the format of pg_database relation. - * ---------------- - */ -typedef FormData_pg_database *Form_pg_database; - -/* ---------------- - *		compiler constants for pg_database - * ---------------- - */ -#define Natts_pg_database				4 -#define Anum_pg_database_datname		1 -#define Anum_pg_database_datdba			2 -#define Anum_pg_database_encoding		3 -#define Anum_pg_database_datpath		4 - - -#endif							/* PG_DATABASE_H */ -/*------------------------------------------------------------------------- - * - * pg_database.h-- - *	  definition of the system "database" relation (pg_database) - *	  along with the relation's initial contents. - * - * - * Copyright (c) 1994, Regents of the University of California - * - * $Id: pg_database_mb.h,v 1.1 1998/07/27 03:21:58 scrappy Exp $ + * $Id: pg_database_mb.h,v 1.2 1998/08/06 05:13:09 momjian Exp $   *   * NOTES   *	  the genbki.sh script reads this file and generates .bki diff --git a/src/include/commands/creatinh.h b/src/include/commands/creatinh.h index 21208ad958d..f4e5f396682 100644 --- a/src/include/commands/creatinh.h +++ b/src/include/commands/creatinh.h @@ -6,7 +6,7 @@   *   * Copyright (c) 1994, Regents of the University of California   * - * $Id: creatinh.h,v 1.6 1997/11/26 01:12:12 momjian Exp $ + * $Id: creatinh.h,v 1.7 1998/08/06 05:13:10 momjian Exp $   *   *-------------------------------------------------------------------------   */ @@ -15,7 +15,7 @@  #include "nodes/parsenodes.h" -extern void DefineRelation(CreateStmt *stmt); +extern void DefineRelation(CreateStmt *stmt, char relkind);  extern void RemoveRelation(char *name);  #endif							/* CREATINH_H */ | 
