mirror of
https://github.com/postgres/postgres.git
synced 2026-02-17 01:31:07 -05:00
In the v11-era commits that taught genbki.pl to resolve symbolic OID references in the initial catalog data, we didn't bother to make every last reference symbolic; some of the catalogs have so few initial rows that it didn't seem worthwhile. However, the new project policy that OIDs assigned by new patches should be automatically renumberable changes this calculus. A patch that wants to add a row in one of these catalogs would have a problem when the OID it assigns gets renumbered. Hence, do the mop-up work needed to make all OID references in initial data be symbolic, and establish an associated project policy that we'll never again write a hard-wired OID reference there. No catversion bump since the contents of postgres.bki aren't actually changed by this commit. Discussion: https://postgr.es/m/CAH2-WzmMTGMcPuph4OvsO7Ykut0AOCF_i-=eaochT0dd2BN9CQ@mail.gmail.com
83 lines
2 KiB
C
83 lines
2 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* pg_database.h
|
|
* definition of the "database" system catalog (pg_database)
|
|
*
|
|
*
|
|
* Portions Copyright (c) 1996-2019, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* src/include/catalog/pg_database.h
|
|
*
|
|
* NOTES
|
|
* The Catalog.pm module reads this file and derives schema
|
|
* information.
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef PG_DATABASE_H
|
|
#define PG_DATABASE_H
|
|
|
|
#include "catalog/genbki.h"
|
|
#include "catalog/pg_database_d.h"
|
|
|
|
/* ----------------
|
|
* pg_database definition. cpp turns this into
|
|
* typedef struct FormData_pg_database
|
|
* ----------------
|
|
*/
|
|
CATALOG(pg_database,1262,DatabaseRelationId) BKI_SHARED_RELATION BKI_ROWTYPE_OID(1248,DatabaseRelation_Rowtype_Id) BKI_SCHEMA_MACRO
|
|
{
|
|
/* oid */
|
|
Oid oid;
|
|
|
|
/* database name */
|
|
NameData datname;
|
|
|
|
/* owner of database */
|
|
Oid datdba BKI_DEFAULT(PGUID);
|
|
|
|
/* character encoding */
|
|
int32 encoding;
|
|
|
|
/* LC_COLLATE setting */
|
|
NameData datcollate;
|
|
|
|
/* LC_CTYPE setting */
|
|
NameData datctype;
|
|
|
|
/* allowed as CREATE DATABASE template? */
|
|
bool datistemplate;
|
|
|
|
/* new connections allowed? */
|
|
bool datallowconn;
|
|
|
|
/* max connections allowed (-1=no limit) */
|
|
int32 datconnlimit;
|
|
|
|
/* highest OID to consider a system OID */
|
|
Oid datlastsysoid;
|
|
|
|
/* all Xids < this are frozen in this DB */
|
|
TransactionId datfrozenxid;
|
|
|
|
/* all multixacts in the DB are >= this */
|
|
TransactionId datminmxid;
|
|
|
|
/* default table space for this DB */
|
|
Oid dattablespace BKI_LOOKUP(pg_tablespace);
|
|
|
|
#ifdef CATALOG_VARLEN /* variable-length fields start here */
|
|
/* access permissions */
|
|
aclitem datacl[1];
|
|
#endif
|
|
} 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;
|
|
|
|
#endif /* PG_DATABASE_H */
|