| 1 | /*------------------------------------------------------------------------- | 
|---|
| 2 | * | 
|---|
| 3 | * genbki.h | 
|---|
| 4 | *	  Required include file for all POSTGRES catalog header files | 
|---|
| 5 | * | 
|---|
| 6 | * genbki.h defines CATALOG(), BKI_BOOTSTRAP and related macros | 
|---|
| 7 | * so that the catalog header files can be read by the C compiler. | 
|---|
| 8 | * (These same words are recognized by genbki.pl to build the BKI | 
|---|
| 9 | * bootstrap file from these header files.) | 
|---|
| 10 | * | 
|---|
| 11 | * | 
|---|
| 12 | * Portions Copyright (c) 1996-2019, PostgreSQL Global Development Group | 
|---|
| 13 | * Portions Copyright (c) 1994, Regents of the University of California | 
|---|
| 14 | * | 
|---|
| 15 | * src/include/catalog/genbki.h | 
|---|
| 16 | * | 
|---|
| 17 | *------------------------------------------------------------------------- | 
|---|
| 18 | */ | 
|---|
| 19 | #ifndef GENBKI_H | 
|---|
| 20 | #define GENBKI_H | 
|---|
| 21 |  | 
|---|
| 22 | /* Introduces a catalog's structure definition */ | 
|---|
| 23 | #define CATALOG(name,oid,oidmacro)	typedef struct CppConcat(FormData_,name) | 
|---|
| 24 |  | 
|---|
| 25 | /* Options that may appear after CATALOG (on the same line) */ | 
|---|
| 26 | #define BKI_BOOTSTRAP | 
|---|
| 27 | #define BKI_SHARED_RELATION | 
|---|
| 28 | #define BKI_ROWTYPE_OID(oid,oidmacro) | 
|---|
| 29 | #define BKI_SCHEMA_MACRO | 
|---|
| 30 |  | 
|---|
| 31 | /* Options that may appear after an attribute (on the same line) */ | 
|---|
| 32 | #define BKI_FORCE_NULL | 
|---|
| 33 | #define BKI_FORCE_NOT_NULL | 
|---|
| 34 | /* Specifies a default value for a catalog field */ | 
|---|
| 35 | #define BKI_DEFAULT(value) | 
|---|
| 36 | /* Specifies a default value for auto-generated array types */ | 
|---|
| 37 | #define BKI_ARRAY_DEFAULT(value) | 
|---|
| 38 | /* | 
|---|
| 39 | * Indicates how to perform name lookups, typically for an OID or | 
|---|
| 40 | * OID-array field | 
|---|
| 41 | */ | 
|---|
| 42 | #define BKI_LOOKUP(catalog) | 
|---|
| 43 |  | 
|---|
| 44 | /* The following are never defined; they are here only for documentation. */ | 
|---|
| 45 |  | 
|---|
| 46 | /* | 
|---|
| 47 | * Variable-length catalog fields (except possibly the first not nullable one) | 
|---|
| 48 | * should not be visible in C structures, so they are made invisible by #ifdefs | 
|---|
| 49 | * of an undefined symbol.  See also MARKNOTNULL in bootstrap.c for how this is | 
|---|
| 50 | * handled. | 
|---|
| 51 | */ | 
|---|
| 52 | #undef CATALOG_VARLEN | 
|---|
| 53 |  | 
|---|
| 54 | /* | 
|---|
| 55 | * There is code in some catalog headers that needs to be visible to clients, | 
|---|
| 56 | * but we don't want clients to include the full header because of safety | 
|---|
| 57 | * issues with other code in the header.  To handle that, surround code that | 
|---|
| 58 | * should be visible to clients with "#ifdef EXPOSE_TO_CLIENT_CODE".  That | 
|---|
| 59 | * instructs genbki.pl to copy the section when generating the corresponding | 
|---|
| 60 | * "_d" header, which can be included by both client and backend code. | 
|---|
| 61 | */ | 
|---|
| 62 | #undef EXPOSE_TO_CLIENT_CODE | 
|---|
| 63 |  | 
|---|
| 64 | #endif							/* GENBKI_H */ | 
|---|
| 65 |  | 
|---|