PostgreSQL Source Code git master
Loading...
Searching...
No Matches
bootstrap.h File Reference
#include "nodes/execnodes.h"
#include "nodes/parsenodes.h"
Include dependency graph for bootstrap.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define MAXATTR   40
 
#define BOOTCOL_NULL_AUTO   1
 
#define BOOTCOL_NULL_FORCE_NULL   2
 
#define BOOTCOL_NULL_FORCE_NOT_NULL   3
 

Typedefs

typedef voidyyscan_t
 

Functions

pg_noreturn void BootstrapModeMain (int argc, char *argv[], bool check_only)
 
void closerel (char *relname)
 
void boot_openrel (char *relname)
 
void DefineAttr (char *name, char *type, int attnum, int nullness)
 
void InsertOneTuple (void)
 
void InsertOneValue (char *value, int i)
 
void InsertOneNull (int i)
 
void index_register (Oid heap, Oid ind, const IndexInfo *indexInfo)
 
void build_indices (void)
 
void boot_get_type_io_data (Oid typid, int16 *typlen, bool *typbyval, char *typalign, char *typdelim, Oid *typioparam, Oid *typinput, Oid *typoutput, Oid *typcollation)
 
int boot_yyparse (yyscan_t yyscanner)
 
int boot_yylex_init (yyscan_t *yyscannerp)
 
int boot_yylex (union YYSTYPE *yylval_param, yyscan_t yyscanner)
 
pg_noreturn void boot_yyerror (yyscan_t yyscanner, const char *message)
 

Variables

PGDLLIMPORT Relation boot_reldesc
 
PGDLLIMPORT Form_pg_attribute attrtypes [MAXATTR]
 
PGDLLIMPORT int numattr
 

Macro Definition Documentation

◆ BOOTCOL_NULL_AUTO

#define BOOTCOL_NULL_AUTO   1

Definition at line 27 of file bootstrap.h.

◆ BOOTCOL_NULL_FORCE_NOT_NULL

#define BOOTCOL_NULL_FORCE_NOT_NULL   3

Definition at line 29 of file bootstrap.h.

◆ BOOTCOL_NULL_FORCE_NULL

#define BOOTCOL_NULL_FORCE_NULL   2

Definition at line 28 of file bootstrap.h.

◆ MAXATTR

#define MAXATTR   40

Definition at line 25 of file bootstrap.h.

Typedef Documentation

◆ yyscan_t

Definition at line 60 of file bootstrap.h.

Function Documentation

◆ boot_get_type_io_data()

void boot_get_type_io_data ( Oid  typid,
int16 typlen,
bool typbyval,
char typalign,
char typdelim,
Oid typioparam,
Oid typinput,
Oid typoutput,
Oid typcollation 
)
extern

Definition at line 963 of file bootstrap.c.

972{
973 if (Typ != NIL)
974 {
975 /* We have the boot-time contents of pg_type, so use it */
976 struct typmap *ap = NULL;
977 ListCell *lc;
978
979 foreach(lc, Typ)
980 {
981 ap = lfirst(lc);
982 if (ap->am_oid == typid)
983 break;
984 }
985
986 if (!ap || ap->am_oid != typid)
987 elog(ERROR, "type OID %u not found in Typ list", typid);
988
989 *typlen = ap->am_typ.typlen;
990 *typbyval = ap->am_typ.typbyval;
991 *typalign = ap->am_typ.typalign;
992 *typdelim = ap->am_typ.typdelim;
993
994 /* XXX this logic must match getTypeIOParam() */
995 if (OidIsValid(ap->am_typ.typelem))
996 *typioparam = ap->am_typ.typelem;
997 else
998 *typioparam = typid;
999
1000 *typinput = ap->am_typ.typinput;
1001 *typoutput = ap->am_typ.typoutput;
1002
1003 *typcollation = ap->am_typ.typcollation;
1004 }
1005 else
1006 {
1007 /* We don't have pg_type yet, so use the hard-wired TypInfo array */
1008 int typeindex;
1009
1010 for (typeindex = 0; typeindex < n_types; typeindex++)
1011 {
1012 if (TypInfo[typeindex].oid == typid)
1013 break;
1014 }
1015 if (typeindex >= n_types)
1016 elog(ERROR, "type OID %u not found in TypInfo", typid);
1017
1018 *typlen = TypInfo[typeindex].len;
1019 *typbyval = TypInfo[typeindex].byval;
1021 /* We assume typdelim is ',' for all boot-time types */
1022 *typdelim = ',';
1023
1024 /* XXX this logic must match getTypeIOParam() */
1025 if (OidIsValid(TypInfo[typeindex].elem))
1026 *typioparam = TypInfo[typeindex].elem;
1027 else
1028 *typioparam = typid;
1029
1031 *typoutput = TypInfo[typeindex].outproc;
1032
1033 *typcollation = TypInfo[typeindex].collation;
1034 }
1035}
static const int n_types
Definition bootstrap.c:136
static const struct typinfo TypInfo[]
Definition bootstrap.c:89
static List * Typ
Definition bootstrap.c:144
#define OidIsValid(objectId)
Definition c.h:800
#define ERROR
Definition elog.h:39
#define elog(elevel,...)
Definition elog.h:226
#define lfirst(lc)
Definition pg_list.h:172
#define NIL
Definition pg_list.h:68
char typalign
Definition pg_type.h:178
static int fb(int x)
char align
Definition bootstrap.c:82
Oid outproc
Definition bootstrap.c:86
int16 len
Definition bootstrap.c:80
bool byval
Definition bootstrap.c:81
Oid collation
Definition bootstrap.c:84
Oid elem
Definition bootstrap.c:79
Oid inproc
Definition bootstrap.c:85

References typinfo::align, typinfo::byval, typinfo::collation, typinfo::elem, elog, ERROR, fb(), typinfo::inproc, typinfo::len, lfirst, n_types, NIL, OidIsValid, typinfo::outproc, Typ, typalign, and TypInfo.

Referenced by get_type_io_data(), InsertOneProargdefaultsValue(), and InsertOneValue().

◆ boot_openrel()

void boot_openrel ( char relname)
extern

Definition at line 436 of file bootstrap.c.

437{
438 int i;
439
440 if (strlen(relname) >= NAMEDATALEN)
441 relname[NAMEDATALEN - 1] = '\0';
442
443 /*
444 * pg_type must be filled before any OPEN command is executed, hence we
445 * can now populate Typ if we haven't yet.
446 */
447 if (Typ == NIL)
449
450 if (boot_reldesc != NULL)
451 closerel(NULL);
452
453 elog(DEBUG4, "open relation %s, attrsize %d",
455
458 for (i = 0; i < numattr; i++)
459 {
460 if (attrtypes[i] == NULL)
465
466 {
468
469 elog(DEBUG4, "create attribute %d name %s len %d num %d type %u",
470 i, NameStr(at->attname), at->attlen, at->attnum,
471 at->atttypid);
472 }
473 }
474}
void closerel(char *relname)
Definition bootstrap.c:481
static void populate_typ_list(void)
Definition bootstrap.c:851
Relation boot_reldesc
Definition bootstrap.c:60
Form_pg_attribute attrtypes[MAXATTR]
Definition bootstrap.c:62
int numattr
Definition bootstrap.c:63
static Form_pg_attribute AllocateAttribute(void)
Definition bootstrap.c:1045
#define NameStr(name)
Definition c.h:777
#define DEBUG4
Definition elog.h:27
int i
Definition isn.c:77
#define NoLock
Definition lockdefs.h:34
RangeVar * makeRangeVar(char *schemaname, char *relname, int location)
Definition makefuncs.c:473
#define ATTRIBUTE_FIXED_PART_SIZE
FormData_pg_attribute * Form_pg_attribute
NameData relname
Definition pg_class.h:40
#define NAMEDATALEN
#define RelationGetNumberOfAttributes(relation)
Definition rel.h:520
TupleDesc rd_att
Definition rel.h:112
Relation table_openrv(const RangeVar *relation, LOCKMODE lockmode)
Definition table.c:83
static FormData_pg_attribute * TupleDescAttr(TupleDesc tupdesc, int i)
Definition tupdesc.h:160

References AllocateAttribute(), ATTRIBUTE_FIXED_PART_SIZE, attrtypes, boot_reldesc, closerel(), DEBUG4, elog, fb(), i, makeRangeVar(), NAMEDATALEN, NameStr, NIL, NoLock, numattr, populate_typ_list(), RelationData::rd_att, RelationGetNumberOfAttributes, relname, table_openrv(), TupleDescAttr(), and Typ.

◆ boot_yyerror()

pg_noreturn void boot_yyerror ( yyscan_t  yyscanner,
const char message 
)
extern

Definition at line 132 of file bootscanner.l.

133{
134 struct yyguts_t *yyg = (struct yyguts_t *) yyscanner; /* needed for yylineno
135 * macro */
136
137 elog(ERROR, "%s at line %d", message, yylineno);
138}

References elog, ERROR, and fb().

◆ boot_yylex()

int boot_yylex ( union YYSTYPE yylval_param,
yyscan_t  yyscanner 
)
extern

◆ boot_yylex_init()

int boot_yylex_init ( yyscan_t yyscannerp)
extern

Referenced by BootstrapModeMain().

◆ boot_yyparse()

int boot_yyparse ( yyscan_t  yyscanner)
extern

Referenced by BootstrapModeMain().

◆ BootstrapModeMain()

pg_noreturn void BootstrapModeMain ( int  argc,
char argv[],
bool  check_only 
)
extern

Definition at line 194 of file bootstrap.c.

195{
196 int i;
197 char *progname = argv[0];
198 int flag;
199 char *userDoption = NULL;
200 uint32 bootstrap_data_checksum_version = 0; /* No checksum */
201 yyscan_t scanner;
202
204
205 InitStandaloneProcess(argv[0]);
206
207 /* Set defaults, to be overridden by explicit options below */
209
210 /* an initial --boot or --check should be present */
211 Assert(argc > 1
212 && (strcmp(argv[1], "--boot") == 0
213 || strcmp(argv[1], "--check") == 0));
214 argv++;
215 argc--;
216
217 while ((flag = getopt(argc, argv, "B:c:d:D:Fkr:X:-:")) != -1)
218 {
219 switch (flag)
220 {
221 case 'B':
222 SetConfigOption("shared_buffers", optarg, PGC_POSTMASTER, PGC_S_ARGV);
223 break;
224 case '-':
225
226 /*
227 * Error if the user misplaced a special must-be-first option
228 * for dispatching to a subprogram. parse_dispatch_option()
229 * returns DISPATCH_POSTMASTER if it doesn't find a match, so
230 * error for anything else.
231 */
235 errmsg("--%s must be first argument", optarg)));
236
238 case 'c':
239 {
240 char *name,
241 *value;
242
244 if (!value)
245 {
246 if (flag == '-')
249 errmsg("--%s requires a value",
250 optarg)));
251 else
254 errmsg("-c %s requires a value",
255 optarg)));
256 }
257
259 pfree(name);
260 pfree(value);
261 break;
262 }
263 case 'D':
265 break;
266 case 'd':
267 {
268 /* Turn on debugging for the bootstrap process. */
269 char *debugstr;
270
271 debugstr = psprintf("debug%s", optarg);
272 SetConfigOption("log_min_messages", debugstr,
274 SetConfigOption("client_min_messages", debugstr,
277 }
278 break;
279 case 'F':
280 SetConfigOption("fsync", "false", PGC_POSTMASTER, PGC_S_ARGV);
281 break;
282 case 'k':
284 break;
285 case 'r':
287 break;
288 case 'X':
290 break;
291 default:
292 write_stderr("Try \"%s --help\" for more information.\n",
293 progname);
294 proc_exit(1);
295 break;
296 }
297 }
298
299 if (argc != optind)
300 {
301 write_stderr("%s: invalid command-line arguments\n", progname);
302 proc_exit(1);
303 }
304
305 /* Acquire configuration parameters */
307 proc_exit(1);
308
309 /*
310 * Validate we have been given a reasonable-looking DataDir and change
311 * into it
312 */
313 checkDataDir();
315
317
319 IgnoreSystemIndexes = true;
320
322
323 /*
324 * Even though bootstrapping runs in single-process mode, initialize
325 * postmaster child slots array so that --check can detect running out of
326 * shared memory or other resources if max_connections is set too high.
327 */
329
331
333
334 /*
335 * Estimate number of openable files. This is essential too in --check
336 * mode, because on some platforms semaphores count as open files.
337 */
339
340 /*
341 * XXX: It might make sense to move this into its own function at some
342 * point. Right now it seems like it'd cause more code duplication than
343 * it's worth.
344 */
345 if (check_only)
346 {
349 abort();
350 }
351
352 /*
353 * Do backend-like initialization for bootstrap mode
354 */
355 InitProcess();
356
357 BaseInit();
358
361
362 /*
363 * To ensure that src/common/link-canary.c is linked into the backend, we
364 * must call it from somewhere. Here is as good as anywhere.
365 */
367 elog(ERROR, "backend is incorrectly linked to frontend functions");
368
370
371 /* Initialize stuff for bootstrap-file processing */
372 for (i = 0; i < MAXATTR; i++)
373 {
374 attrtypes[i] = NULL;
375 Nulls[i] = false;
376 }
377
378 if (boot_yylex_init(&scanner) != 0)
379 elog(ERROR, "yylex_init() failed: %m");
380
381 /*
382 * Process bootstrap input.
383 */
385 boot_yyparse(scanner);
387
388 /*
389 * We should now know about all mapped relations, so it's okay to write
390 * out the initial relation mapping files.
391 */
393
394 /* Clean up and exit */
395 cleanup();
396 proc_exit(0);
397}
#define write_stderr(str)
Definition parallel.c:186
static void CheckerModeMain(void)
Definition bootstrap.c:176
static void cleanup(void)
Definition bootstrap.c:838
static void bootstrap_signals(void)
Definition bootstrap.c:409
static bool Nulls[MAXATTR]
Definition bootstrap.c:148
int boot_yylex_init(yyscan_t *yyscannerp)
#define MAXATTR
Definition bootstrap.h:25
int boot_yyparse(yyscan_t yyscanner)
#define PG_DATA_CHECKSUM_VERSION
Definition bufpage.h:206
#define Assert(condition)
Definition c.h:885
uint32_t uint32
Definition c.h:558
#define pg_fallthrough
Definition c.h:144
void * yyscan_t
Definition cubedata.h:65
int errcode(int sqlerrcode)
Definition elog.c:874
int errmsg(const char *fmt,...)
Definition elog.c:1093
#define ereport(elevel,...)
Definition elog.h:150
void set_max_safe_fds(void)
Definition fd.c:1044
bool IsUnderPostmaster
Definition globals.c:120
char OutputFileName[MAXPGPATH]
Definition globals.c:79
void SetConfigOption(const char *name, const char *value, GucContext context, GucSource source)
Definition guc.c:4196
bool SelectConfigFiles(const char *userDoption, const char *progname)
Definition guc.c:1655
void ParseLongOption(const char *string, char **name, char **value)
Definition guc.c:6205
void InitializeGUCOptions(void)
Definition guc.c:1407
@ PGC_S_DYNAMIC_DEFAULT
Definition guc.h:114
@ PGC_S_ARGV
Definition guc.h:117
@ PGC_INTERNAL
Definition guc.h:73
@ PGC_POSTMASTER
Definition guc.h:74
static struct @174 value
void proc_exit(int code)
Definition ipc.c:105
void CreateSharedMemoryAndSemaphores(void)
Definition ipci.c:191
DispatchOption parse_dispatch_option(const char *name)
Definition main.c:244
const char * progname
Definition main.c:44
char * pstrdup(const char *in)
Definition mcxt.c:1781
void pfree(void *pointer)
Definition mcxt.c:1616
@ NormalProcessing
Definition miscadmin.h:472
@ BootstrapProcessing
Definition miscadmin.h:470
#define SetProcessingMode(mode)
Definition miscadmin.h:483
void ChangeToDataDir(void)
Definition miscinit.c:409
void InitStandaloneProcess(const char *argv0)
Definition miscinit.c:175
bool IgnoreSystemIndexes
Definition miscinit.c:81
void checkDataDir(void)
Definition miscinit.c:296
void CreateDataDirLockFile(bool amPostmaster)
Definition miscinit.c:1463
#define MAXPGPATH
PGDLLIMPORT int optind
Definition getopt.c:51
int getopt(int nargc, char *const *nargv, const char *ostr)
Definition getopt.c:72
PGDLLIMPORT char * optarg
Definition getopt.c:53
void InitPostmasterChildSlots(void)
Definition pmchild.c:97
size_t strlcpy(char *dst, const char *src, size_t siz)
Definition strlcpy.c:45
static const char * userDoption
Definition postgres.c:155
#define InvalidOid
void InitializeMaxBackends(void)
Definition postinit.c:558
void BaseInit(void)
Definition postinit.c:615
void InitializeFastPathLocks(void)
Definition postinit.c:583
void InitPostgres(const char *in_dbname, Oid dboid, const char *username, Oid useroid, bits32 flags, char *out_dbname)
Definition postinit.c:718
@ DISPATCH_POSTMASTER
Definition postmaster.h:139
char * psprintf(const char *fmt,...)
Definition psprintf.c:43
void RelationMapFinishBootstrap(void)
Definition relmapper.c:625
void InitProcess(void)
Definition proc.c:379
char * flag(int b)
Definition test-ctype.c:33
const char * name
void StartTransactionCommand(void)
Definition xact.c:3080
void CommitTransactionCommand(void)
Definition xact.c:3178
void BootStrapXLOG(uint32 data_checksum_version)
Definition xlog.c:5126

References Assert, attrtypes, BaseInit(), boot_yylex_init(), boot_yyparse(), bootstrap_signals(), BootstrapProcessing, BootStrapXLOG(), ChangeToDataDir(), checkDataDir(), CheckerModeMain(), cleanup(), CommitTransactionCommand(), CreateDataDirLockFile(), CreateSharedMemoryAndSemaphores(), DISPATCH_POSTMASTER, elog, ereport, errcode(), errmsg(), ERROR, fb(), flag(), getopt(), i, IgnoreSystemIndexes, InitializeFastPathLocks(), InitializeGUCOptions(), InitializeMaxBackends(), InitPostgres(), InitPostmasterChildSlots(), InitProcess(), InitStandaloneProcess(), InvalidOid, IsUnderPostmaster, MAXATTR, MAXPGPATH, name, NormalProcessing, Nulls, optarg, optind, OutputFileName, parse_dispatch_option(), ParseLongOption(), pfree(), PG_DATA_CHECKSUM_VERSION, pg_fallthrough, pg_link_canary_is_frontend(), PGC_INTERNAL, PGC_POSTMASTER, PGC_S_ARGV, PGC_S_DYNAMIC_DEFAULT, proc_exit(), progname, psprintf(), pstrdup(), RelationMapFinishBootstrap(), SelectConfigFiles(), set_max_safe_fds(), SetConfigOption(), SetProcessingMode, StartTransactionCommand(), strlcpy(), userDoption, value, and write_stderr.

Referenced by main().

◆ build_indices()

void build_indices ( void  )
extern

Definition at line 1113 of file bootstrap.c.

1114{
1115 for (; ILHead != NULL; ILHead = ILHead->il_next)
1116 {
1117 Relation heap;
1118 Relation ind;
1119
1120 /* need not bother with locks during bootstrap */
1121 heap = table_open(ILHead->il_heap, NoLock);
1123
1124 index_build(heap, ind, ILHead->il_info, false, false);
1125
1127 table_close(heap, NoLock);
1128 }
1129}
static IndexList * ILHead
Definition bootstrap.c:166
void index_build(Relation heapRelation, Relation indexRelation, IndexInfo *indexInfo, bool isreindex, bool parallel)
Definition index.c:3000
void index_close(Relation relation, LOCKMODE lockmode)
Definition indexam.c:177
Relation index_open(Oid relationId, LOCKMODE lockmode)
Definition indexam.c:133
struct _IndexList * il_next
Definition bootstrap.c:163
IndexInfo * il_info
Definition bootstrap.c:162
void table_close(Relation relation, LOCKMODE lockmode)
Definition table.c:126
Relation table_open(Oid relationId, LOCKMODE lockmode)
Definition table.c:40

References fb(), _IndexList::il_heap, _IndexList::il_ind, _IndexList::il_info, _IndexList::il_next, ILHead, index_build(), index_close(), index_open(), NoLock, table_close(), and table_open().

◆ closerel()

void closerel ( char relname)
extern

Definition at line 481 of file bootstrap.c.

482{
483 if (relname)
484 {
485 if (boot_reldesc)
486 {
488 elog(ERROR, "close of %s when %s was expected",
490 }
491 else
492 elog(ERROR, "close of %s before any relation was opened",
493 relname);
494 }
495
496 if (boot_reldesc == NULL)
497 elog(ERROR, "no open relation to close");
498 else
499 {
500 elog(DEBUG4, "close relation %s",
504 }
505}
#define RelationGetRelationName(relation)
Definition rel.h:548

References boot_reldesc, DEBUG4, elog, ERROR, fb(), NoLock, RelationGetRelationName, relname, and table_close().

Referenced by boot_openrel(), cleanup(), and DefineAttr().

◆ DefineAttr()

void DefineAttr ( char name,
char type,
int  attnum,
int  nullness 
)
extern

Definition at line 518 of file bootstrap.c.

519{
520 Oid typeoid;
521
522 if (boot_reldesc != NULL)
523 {
524 elog(WARNING, "no open relations allowed with CREATE command");
525 closerel(NULL);
526 }
527
528 if (attrtypes[attnum] == NULL)
531
533 elog(DEBUG4, "column %s %s", NameStr(attrtypes[attnum]->attname), type);
534 attrtypes[attnum]->attnum = attnum + 1;
535
536 typeoid = gettype(type);
537
538 if (Typ != NIL)
539 {
540 attrtypes[attnum]->atttypid = Ap->am_oid;
541 attrtypes[attnum]->attlen = Ap->am_typ.typlen;
542 attrtypes[attnum]->attbyval = Ap->am_typ.typbyval;
543 attrtypes[attnum]->attalign = Ap->am_typ.typalign;
544 attrtypes[attnum]->attstorage = Ap->am_typ.typstorage;
545 attrtypes[attnum]->attcompression = InvalidCompressionMethod;
546 attrtypes[attnum]->attcollation = Ap->am_typ.typcollation;
547 /* if an array type, assume 1-dimensional attribute */
548 if (Ap->am_typ.typelem != InvalidOid && Ap->am_typ.typlen < 0)
549 attrtypes[attnum]->attndims = 1;
550 else
551 attrtypes[attnum]->attndims = 0;
552 }
553 else
554 {
555 attrtypes[attnum]->atttypid = TypInfo[typeoid].oid;
556 attrtypes[attnum]->attlen = TypInfo[typeoid].len;
557 attrtypes[attnum]->attbyval = TypInfo[typeoid].byval;
558 attrtypes[attnum]->attalign = TypInfo[typeoid].align;
559 attrtypes[attnum]->attstorage = TypInfo[typeoid].storage;
560 attrtypes[attnum]->attcompression = InvalidCompressionMethod;
561 attrtypes[attnum]->attcollation = TypInfo[typeoid].collation;
562 /* if an array type, assume 1-dimensional attribute */
563 if (TypInfo[typeoid].elem != InvalidOid &&
564 attrtypes[attnum]->attlen < 0)
565 attrtypes[attnum]->attndims = 1;
566 else
567 attrtypes[attnum]->attndims = 0;
568 }
569
570 /*
571 * If a system catalog column is collation-aware, force it to use C
572 * collation, so that its behavior is independent of the database's
573 * collation. This is essential to allow template0 to be cloned with a
574 * different database collation.
575 */
576 if (OidIsValid(attrtypes[attnum]->attcollation))
577 attrtypes[attnum]->attcollation = C_COLLATION_OID;
578
579 attrtypes[attnum]->atttypmod = -1;
580 attrtypes[attnum]->attislocal = true;
581
583 {
584 attrtypes[attnum]->attnotnull = true;
585 }
587 {
588 attrtypes[attnum]->attnotnull = false;
589 }
590 else
591 {
593
594 /*
595 * Mark as "not null" if type is fixed-width and prior columns are
596 * likewise fixed-width and not-null. This corresponds to case where
597 * column can be accessed directly via C struct declaration.
598 */
599 if (attrtypes[attnum]->attlen > 0)
600 {
601 int i;
602
603 /* check earlier attributes */
604 for (i = 0; i < attnum; i++)
605 {
606 if (attrtypes[i]->attlen <= 0 ||
608 break;
609 }
610 if (i == attnum)
611 attrtypes[attnum]->attnotnull = true;
612 }
613 }
614}
static Oid gettype(char *type)
Definition bootstrap.c:891
static struct typmap * Ap
Definition bootstrap.c:145
#define BOOTCOL_NULL_FORCE_NULL
Definition bootstrap.h:28
#define BOOTCOL_NULL_FORCE_NOT_NULL
Definition bootstrap.h:29
#define BOOTCOL_NULL_AUTO
Definition bootstrap.h:27
#define MemSet(start, val, len)
Definition c.h:1035
#define WARNING
Definition elog.h:36
void namestrcpy(Name name, const char *str)
Definition name.c:233
NameData attname
int16 attnum
int16 attlen
bool attnotnull
unsigned int Oid
Oid oid
Definition bootstrap.c:78
char storage
Definition bootstrap.c:83
Oid am_oid
Definition bootstrap.c:140
FormData_pg_type am_typ
Definition bootstrap.c:141
#define InvalidCompressionMethod
const char * type

References typinfo::align, AllocateAttribute(), typmap::am_oid, typmap::am_typ, Ap, Assert, attlen, attname, attnotnull, attnum, ATTRIBUTE_FIXED_PART_SIZE, attrtypes, boot_reldesc, BOOTCOL_NULL_AUTO, BOOTCOL_NULL_FORCE_NOT_NULL, BOOTCOL_NULL_FORCE_NULL, typinfo::byval, closerel(), typinfo::collation, DEBUG4, elog, fb(), gettype(), i, InvalidCompressionMethod, InvalidOid, typinfo::len, MemSet, name, NameStr, namestrcpy(), NIL, typinfo::oid, OidIsValid, typinfo::storage, Typ, type, TypInfo, and WARNING.

◆ index_register()

void index_register ( Oid  heap,
Oid  ind,
const IndexInfo indexInfo 
)
extern

Definition at line 1063 of file bootstrap.c.

1066{
1069
1070 /*
1071 * XXX mao 10/31/92 -- don't gc index reldescs, associated info at
1072 * bootstrap time. we'll declare the indexes now, but want to create them
1073 * later.
1074 */
1075
1076 if (nogc == NULL)
1078 "BootstrapNoGC",
1080
1082
1084 newind->il_heap = heap;
1085 newind->il_ind = ind;
1086 newind->il_info = palloc_object(IndexInfo);
1087
1088 memcpy(newind->il_info, indexInfo, sizeof(IndexInfo));
1089 /* expressions will likely be null, but may as well copy it */
1090 newind->il_info->ii_Expressions =
1091 copyObject(indexInfo->ii_Expressions);
1092 newind->il_info->ii_ExpressionsState = NIL;
1093 /* predicate will likely be null, but may as well copy it */
1094 newind->il_info->ii_Predicate =
1095 copyObject(indexInfo->ii_Predicate);
1096 newind->il_info->ii_PredicateState = NULL;
1097 /* no exclusion constraints at bootstrap time, so no need to copy */
1098 Assert(indexInfo->ii_ExclusionOps == NULL);
1099 Assert(indexInfo->ii_ExclusionProcs == NULL);
1100 Assert(indexInfo->ii_ExclusionStrats == NULL);
1101
1102 newind->il_next = ILHead;
1103 ILHead = newind;
1104
1106}
static MemoryContext nogc
Definition bootstrap.c:150
#define palloc_object(type)
Definition fe_memutils.h:74
#define AllocSetContextCreate
Definition memutils.h:129
#define ALLOCSET_DEFAULT_SIZES
Definition memutils.h:160
#define copyObject(obj)
Definition nodes.h:232
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition palloc.h:124
uint16 * ii_ExclusionStrats
Definition execnodes.h:194
Oid * ii_ExclusionOps
Definition execnodes.h:190
List * ii_Expressions
Definition execnodes.h:180
Oid * ii_ExclusionProcs
Definition execnodes.h:192
List * ii_Predicate
Definition execnodes.h:185

References ALLOCSET_DEFAULT_SIZES, AllocSetContextCreate, Assert, copyObject, fb(), IndexInfo::ii_ExclusionOps, IndexInfo::ii_ExclusionProcs, IndexInfo::ii_ExclusionStrats, IndexInfo::ii_Expressions, IndexInfo::ii_Predicate, ILHead, MemoryContextSwitchTo(), NIL, nogc, and palloc_object.

Referenced by index_create().

◆ InsertOneNull()

void InsertOneNull ( int  i)
extern

Definition at line 820 of file bootstrap.c.

821{
822 elog(DEBUG4, "inserting column %d NULL", i);
823 Assert(i >= 0 && i < MAXATTR);
824 if (TupleDescAttr(boot_reldesc->rd_att, i)->attnotnull)
825 elog(ERROR,
826 "NULL value specified for not-null column \"%s\" of relation \"%s\"",
830 Nulls[i] = true;
831}
static Datum values[MAXATTR]
Definition bootstrap.c:147
static Datum PointerGetDatum(const void *X)
Definition postgres.h:352

References Assert, boot_reldesc, DEBUG4, elog, ERROR, fb(), i, MAXATTR, NameStr, Nulls, PointerGetDatum(), RelationData::rd_att, RelationGetRelationName, TupleDescAttr(), and values.

◆ InsertOneTuple()

void InsertOneTuple ( void  )
extern

Definition at line 625 of file bootstrap.c.

626{
627 HeapTuple tuple;
628 TupleDesc tupDesc;
629 int i;
630
631 elog(DEBUG4, "inserting row with %d columns", numattr);
632
634 tuple = heap_form_tuple(tupDesc, values, Nulls);
635 pfree(tupDesc); /* just free's tupDesc, not the attrtypes */
636
638 heap_freetuple(tuple);
639 elog(DEBUG4, "row inserted");
640
641 /*
642 * Reset null markers for next tuple
643 */
644 for (i = 0; i < numattr; i++)
645 Nulls[i] = false;
646}
void simple_heap_insert(Relation relation, HeapTuple tup)
Definition heapam.c:2785
HeapTuple heap_form_tuple(TupleDesc tupleDescriptor, const Datum *values, const bool *isnull)
Definition heaptuple.c:1117
void heap_freetuple(HeapTuple htup)
Definition heaptuple.c:1435
TupleDesc CreateTupleDesc(int natts, Form_pg_attribute *attrs)
Definition tupdesc.c:212

References attrtypes, boot_reldesc, CreateTupleDesc(), DEBUG4, elog, heap_form_tuple(), heap_freetuple(), i, Nulls, numattr, pfree(), simple_heap_insert(), and values.

◆ InsertOneValue()

void InsertOneValue ( char value,
int  i 
)
extern

Definition at line 653 of file bootstrap.c.

654{
656 Oid typoid;
657 int16 typlen;
658 bool typbyval;
659 char typalign;
660 char typdelim;
661 Oid typioparam;
663 Oid typoutput;
664 Oid typcollation;
665
666 Assert(i >= 0 && i < MAXATTR);
667
668 elog(DEBUG4, "inserting column %d value \"%s\"", i, value);
669
671 typoid = attr->atttypid;
672
674 &typlen, &typbyval, &typalign,
675 &typdelim, &typioparam,
676 &typinput, &typoutput,
677 &typcollation);
678
679 /*
680 * pg_node_tree values can't be inserted normally (pg_node_tree_in would
681 * just error out), so provide special cases for such columns that we
682 * would like to fill during bootstrap.
683 */
684 if (typoid == PG_NODE_TREEOID)
685 {
686 /* pg_proc.proargdefaults */
690 else /* maybe other cases later */
691 elog(ERROR, "can't handle pg_node_tree input for %s.%s",
693 NameStr(attr->attname));
694 }
695 else
696 {
697 /* Normal case */
698 values[i] = OidInputFunctionCall(typinput, value, typioparam, -1);
699 }
700
701 /*
702 * We use ereport not elog here so that parameters aren't evaluated unless
703 * the message is going to be printed, which generally it isn't
704 */
706 (errmsg_internal("inserted -> %s",
707 OidOutputFunctionCall(typoutput, values[i]))));
708}
void boot_get_type_io_data(Oid typid, int16 *typlen, bool *typbyval, char *typalign, char *typdelim, Oid *typioparam, Oid *typinput, Oid *typoutput, Oid *typcollation)
Definition bootstrap.c:963
static void InsertOneProargdefaultsValue(char *value)
Definition bootstrap.c:720
int16_t int16
Definition c.h:553
int int errmsg_internal(const char *fmt,...) pg_attribute_printf(1
Datum OidInputFunctionCall(Oid functionId, char *str, Oid typioparam, int32 typmod)
Definition fmgr.c:1754
char * OidOutputFunctionCall(Oid functionId, Datum val)
Definition fmgr.c:1763
#define RelationGetRelid(relation)
Definition rel.h:514
#define RelationGetDescr(relation)
Definition rel.h:540

References Assert, boot_get_type_io_data(), boot_reldesc, DEBUG4, elog, ereport, errmsg_internal(), ERROR, fb(), i, InsertOneProargdefaultsValue(), MAXATTR, NameStr, OidInputFunctionCall(), OidOutputFunctionCall(), RelationGetDescr, RelationGetRelationName, RelationGetRelid, TupleDescAttr(), typalign, value, and values.

Variable Documentation

◆ attrtypes

Definition at line 62 of file bootstrap.c.

Referenced by boot_openrel(), BootstrapModeMain(), DefineAttr(), and InsertOneTuple().

◆ boot_reldesc

PGDLLIMPORT Relation boot_reldesc
extern

◆ numattr

PGDLLIMPORT int numattr
extern

Definition at line 63 of file bootstrap.c.

Referenced by boot_openrel(), InsertOneTuple(), and tsvector_update_trigger().