⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 postgres.h

📁 PostgreSQL 8.2中增加了很多企业用户所需要的功能和性能上的提高,其开发团队说,该版本将加速更多企业向该数据库移植.核心开发成员之一Bruce Momjian表示,在新版PostgreSQL
💻 H
字号:
/*------------------------------------------------------------------------- * * postgres.h *	  Primary include file for PostgreSQL server .c files * * This should be the first file included by PostgreSQL backend modules. * Client-side code should include postgres_fe.h instead. * * * Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group * Portions Copyright (c) 1995, Regents of the University of California * * $PostgreSQL: pgsql/src/include/postgres.h,v 1.75 2006/07/13 16:49:18 momjian Exp $ * *------------------------------------------------------------------------- *//* *---------------------------------------------------------------- *	 TABLE OF CONTENTS * *		When adding stuff to this file, please try to put stuff *		into the relevant section, or add new sections as appropriate. * *	  section	description *	  -------	------------------------------------------------ *		1)		variable-length datatypes (TOAST support) *		2)		datum type + support macros *		3)		exception handling definitions *		4)		genbki macros used by catalog/pg_xxx.h files * *	 NOTES * *	In general, this file should contain declarations that are widely needed *	in the backend environment, but are of no interest outside the backend. * *	Simple type definitions live in c.h, where they are shared with *	postgres_fe.h.	We do that since those type definitions are needed by *	frontend modules that want to deal with binary data transmission to or *	from the backend.  Type definitions in this file should be for *	representations that never escape the backend, such as Datum or *	TOASTed varlena objects. * *---------------------------------------------------------------- */#ifndef POSTGRES_H#define POSTGRES_H#include "c.h"#include "utils/elog.h"#include "utils/palloc.h"/* ---------------------------------------------------------------- *				Section 1:	variable-length datatypes (TOAST support) * ---------------------------------------------------------------- *//* ---------------- * struct varattrib is the header of a varlena object that may have been * TOASTed. * ---------------- */typedef struct varattrib{	int32		va_header;		/* External/compressed storage */	/* flags and item size */	union	{		struct		{			int32		va_rawsize;		/* Plain data size */			char		va_data[1];		/* Compressed data */		}			va_compressed;		/* Compressed stored attribute */		struct		{			int32		va_rawsize;		/* Plain data size */			int32		va_extsize;		/* External saved size */			Oid			va_valueid;		/* Unique identifier of value */			Oid			va_toastrelid;	/* RelID where to find chunks */		}			va_external;	/* External stored attribute */		char		va_data[1]; /* Plain stored attribute */	}			va_content;} varattrib;#define VARATT_FLAG_EXTERNAL	0x80000000#define VARATT_FLAG_COMPRESSED	0x40000000#define VARATT_MASK_FLAGS		0xc0000000#define VARATT_MASK_SIZE		0x3fffffff#define VARATT_SIZEP(_PTR)	(((varattrib *)(_PTR))->va_header)#define VARATT_SIZE(PTR)	(VARATT_SIZEP(PTR) & VARATT_MASK_SIZE)#define VARATT_DATA(PTR)	(((varattrib *)(PTR))->va_content.va_data)#define VARATT_CDATA(PTR)	(((varattrib *)(PTR))->va_content.va_compressed.va_data)#define VARSIZE(__PTR)		VARATT_SIZE(__PTR)#define VARDATA(__PTR)		VARATT_DATA(__PTR)#define VARATT_IS_EXTENDED(PTR)		\				((VARATT_SIZEP(PTR) & VARATT_MASK_FLAGS) != 0)#define VARATT_IS_EXTERNAL(PTR)		\				((VARATT_SIZEP(PTR) & VARATT_FLAG_EXTERNAL) != 0)#define VARATT_IS_COMPRESSED(PTR)	\				((VARATT_SIZEP(PTR) & VARATT_FLAG_COMPRESSED) != 0)/* ---------------------------------------------------------------- *				Section 2:	datum type + support macros * ---------------------------------------------------------------- *//* * Port Notes: *	Postgres makes the following assumption about machines: * *	sizeof(Datum) == sizeof(long) >= sizeof(void *) >= 4 * *	Postgres also assumes that * *	sizeof(char) == 1 * *	and that * *	sizeof(short) == 2 * *	If your machine meets these requirements, Datums should also be checked *	to see if the positioning is correct. */typedef unsigned long Datum;	/* XXX sizeof(long) >= sizeof(void *) */#define SIZEOF_DATUM SIZEOF_UNSIGNED_LONGtypedef Datum *DatumPtr;#define GET_1_BYTE(datum)	(((Datum) (datum)) & 0x000000ff)#define GET_2_BYTES(datum)	(((Datum) (datum)) & 0x0000ffff)#define GET_4_BYTES(datum)	(((Datum) (datum)) & 0xffffffff)#define SET_1_BYTE(value)	(((Datum) (value)) & 0x000000ff)#define SET_2_BYTES(value)	(((Datum) (value)) & 0x0000ffff)#define SET_4_BYTES(value)	(((Datum) (value)) & 0xffffffff)/* * DatumGetBool *		Returns boolean value of a datum. * * Note: any nonzero value will be considered TRUE. */#define DatumGetBool(X) ((bool) (((Datum) (X)) != 0))/* * BoolGetDatum *		Returns datum representation for a boolean. * * Note: any nonzero value will be considered TRUE. */#define BoolGetDatum(X) ((Datum) ((X) ? 1 : 0))/* * DatumGetChar *		Returns character value of a datum. */#define DatumGetChar(X) ((char) GET_1_BYTE(X))/* * CharGetDatum *		Returns datum representation for a character. */#define CharGetDatum(X) ((Datum) SET_1_BYTE(X))/* * Int8GetDatum *		Returns datum representation for an 8-bit integer. */#define Int8GetDatum(X) ((Datum) SET_1_BYTE(X))/* * DatumGetUInt8 *		Returns 8-bit unsigned integer value of a datum. */#define DatumGetUInt8(X) ((uint8) GET_1_BYTE(X))/* * UInt8GetDatum *		Returns datum representation for an 8-bit unsigned integer. */#define UInt8GetDatum(X) ((Datum) SET_1_BYTE(X))/* * DatumGetInt16 *		Returns 16-bit integer value of a datum. */#define DatumGetInt16(X) ((int16) GET_2_BYTES(X))/* * Int16GetDatum *		Returns datum representation for a 16-bit integer. */#define Int16GetDatum(X) ((Datum) SET_2_BYTES(X))/* * DatumGetUInt16 *		Returns 16-bit unsigned integer value of a datum. */#define DatumGetUInt16(X) ((uint16) GET_2_BYTES(X))/* * UInt16GetDatum *		Returns datum representation for a 16-bit unsigned integer. */#define UInt16GetDatum(X) ((Datum) SET_2_BYTES(X))/* * DatumGetInt32 *		Returns 32-bit integer value of a datum. */#define DatumGetInt32(X) ((int32) GET_4_BYTES(X))/* * Int32GetDatum *		Returns datum representation for a 32-bit integer. */#define Int32GetDatum(X) ((Datum) SET_4_BYTES(X))/* * DatumGetUInt32 *		Returns 32-bit unsigned integer value of a datum. */#define DatumGetUInt32(X) ((uint32) GET_4_BYTES(X))/* * UInt32GetDatum *		Returns datum representation for a 32-bit unsigned integer. */#define UInt32GetDatum(X) ((Datum) SET_4_BYTES(X))/* * DatumGetObjectId *		Returns object identifier value of a datum. */#define DatumGetObjectId(X) ((Oid) GET_4_BYTES(X))/* * ObjectIdGetDatum *		Returns datum representation for an object identifier. */#define ObjectIdGetDatum(X) ((Datum) SET_4_BYTES(X))/* * DatumGetTransactionId *		Returns transaction identifier value of a datum. */#define DatumGetTransactionId(X) ((TransactionId) GET_4_BYTES(X))/* * TransactionIdGetDatum *		Returns datum representation for a transaction identifier. */#define TransactionIdGetDatum(X) ((Datum) SET_4_BYTES((X)))/* * DatumGetCommandId *		Returns command identifier value of a datum. */#define DatumGetCommandId(X) ((CommandId) GET_4_BYTES(X))/* * CommandIdGetDatum *		Returns datum representation for a command identifier. */#define CommandIdGetDatum(X) ((Datum) SET_4_BYTES(X))/* * DatumGetPointer *		Returns pointer value of a datum. */#define DatumGetPointer(X) ((Pointer) (X))/* * PointerGetDatum *		Returns datum representation for a pointer. */#define PointerGetDatum(X) ((Datum) (X))/* * DatumGetCString *		Returns C string (null-terminated string) value of a datum. * * Note: C string is not a full-fledged Postgres type at present, * but type input functions use this conversion for their inputs. */#define DatumGetCString(X) ((char *) DatumGetPointer(X))/* * CStringGetDatum *		Returns datum representation for a C string (null-terminated string). * * Note: C string is not a full-fledged Postgres type at present, * but type output functions use this conversion for their outputs. * Note: CString is pass-by-reference; caller must ensure the pointed-to * value has adequate lifetime. */#define CStringGetDatum(X) PointerGetDatum(X)/* * DatumGetName *		Returns name value of a datum. */#define DatumGetName(X) ((Name) DatumGetPointer(X))/* * NameGetDatum *		Returns datum representation for a name. * * Note: Name is pass-by-reference; caller must ensure the pointed-to * value has adequate lifetime. */#define NameGetDatum(X) PointerGetDatum(X)/* * DatumGetInt64 *		Returns 64-bit integer value of a datum. * * Note: this macro hides the fact that int64 is currently a * pass-by-reference type.	Someday it may be pass-by-value, * at least on some platforms. */#define DatumGetInt64(X) (* ((int64 *) DatumGetPointer(X)))/* * Int64GetDatum *		Returns datum representation for a 64-bit integer. * * Note: this routine returns a reference to palloc'd space. */extern Datum Int64GetDatum(int64 X);/* * DatumGetFloat4 *		Returns 4-byte floating point value of a datum. * * Note: this macro hides the fact that float4 is currently a * pass-by-reference type.	Someday it may be pass-by-value. */#define DatumGetFloat4(X) (* ((float4 *) DatumGetPointer(X)))/* * Float4GetDatum *		Returns datum representation for a 4-byte floating point number. * * Note: this routine returns a reference to palloc'd space. */extern Datum Float4GetDatum(float4 X);/* * DatumGetFloat8 *		Returns 8-byte floating point value of a datum. * * Note: this macro hides the fact that float8 is currently a * pass-by-reference type.	Someday it may be pass-by-value, * at least on some platforms. */#define DatumGetFloat8(X) (* ((float8 *) DatumGetPointer(X)))/* * Float8GetDatum *		Returns datum representation for an 8-byte floating point number. * * Note: this routine returns a reference to palloc'd space. */extern Datum Float8GetDatum(float8 X);/* * DatumGetFloat32 *		Returns 32-bit floating point value of a datum. *		This is really a pointer, of course. * * XXX: this macro is now deprecated in favor of DatumGetFloat4. * It will eventually go away. */#define DatumGetFloat32(X) ((float32) DatumGetPointer(X))/* * Float32GetDatum *		Returns datum representation for a 32-bit floating point number. *		This is really a pointer, of course. * * XXX: this macro is now deprecated in favor of Float4GetDatum. * It will eventually go away. */#define Float32GetDatum(X) PointerGetDatum(X)/* * DatumGetFloat64 *		Returns 64-bit floating point value of a datum. *		This is really a pointer, of course. * * XXX: this macro is now deprecated in favor of DatumGetFloat8. * It will eventually go away. */#define DatumGetFloat64(X) ((float64) DatumGetPointer(X))/* * Float64GetDatum *		Returns datum representation for a 64-bit floating point number. *		This is really a pointer, of course. * * XXX: this macro is now deprecated in favor of Float8GetDatum. * It will eventually go away. */#define Float64GetDatum(X) PointerGetDatum(X)/* * Int64GetDatumFast * Float4GetDatumFast * Float8GetDatumFast * * These macros are intended to allow writing code that does not depend on * whether int64, float4, float8 are pass-by-reference types, while not * sacrificing performance when they are.  The argument must be a variable * that will exist and have the same value for as long as the Datum is needed. * In the pass-by-ref case, the address of the variable is taken to use as * the Datum.  In the pass-by-val case, these will be the same as the non-Fast * macros. */#define Int64GetDatumFast(X)  PointerGetDatum(&(X))#define Float4GetDatumFast(X) PointerGetDatum(&(X))#define Float8GetDatumFast(X) PointerGetDatum(&(X))/* ---------------------------------------------------------------- *				Section 3:	exception handling definitions *							Assert, Trap, etc macros * ---------------------------------------------------------------- */extern DLLIMPORT bool assert_enabled;/* * USE_ASSERT_CHECKING, if defined, turns on all the assertions. * - plai  9/5/90 * * It should _NOT_ be defined in releases or in benchmark copies *//* * Trap *		Generates an exception if the given condition is true. */#define Trap(condition, errorType) \	do { \		if ((assert_enabled) && (condition)) \			ExceptionalCondition(CppAsString(condition), (errorType), \								 __FILE__, __LINE__); \	} while (0)/* *	TrapMacro is the same as Trap but it's intended for use in macros: * *		#define foo(x) (AssertMacro(x != 0) && bar(x)) * *	Isn't CPP fun? */#define TrapMacro(condition, errorType) \	((bool) ((! assert_enabled) || ! (condition) || \			 (ExceptionalCondition(CppAsString(condition), (errorType), \								   __FILE__, __LINE__))))#ifndef USE_ASSERT_CHECKING#define Assert(condition)#define AssertMacro(condition)	((void)true)#define AssertArg(condition)#define AssertState(condition)#else#define Assert(condition) \		Trap(!(condition), "FailedAssertion")#define AssertMacro(condition) \		((void) TrapMacro(!(condition), "FailedAssertion"))#define AssertArg(condition) \		Trap(!(condition), "BadArgument")#define AssertState(condition) \		Trap(!(condition), "BadState")#endif   /* USE_ASSERT_CHECKING */extern int ExceptionalCondition(char *conditionName, char *errorType,					 char *fileName, int lineNumber);/* ---------------------------------------------------------------- *				Section 4: genbki macros used by catalog/pg_xxx.h files * ---------------------------------------------------------------- */#define CATALOG(name,oid)	typedef struct CppConcat(FormData_,name)#define BKI_BOOTSTRAP#define BKI_SHARED_RELATION#define BKI_WITHOUT_OIDS/* these need to expand into some harmless, repeatable declaration */#define DATA(x)   extern int no_such_variable#define DESCR(x)  extern int no_such_variable#define SHDESCR(x) extern int no_such_variabletypedef int4 aclitem;			/* PHONY definition for catalog use only */#endif   /* POSTGRES_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -