mirror of
https://github.com/postgres/postgres.git
synced 2025-08-27 07:42:10 +03:00
in PITR scenarios. We now WAL-log the replacement of old XIDs with FrozenTransactionId, so that such replacement is guaranteed to propagate to PITR slave databases. Also, rather than relying on hint-bit updates to be preserved, pg_clog is not truncated until all instances of an XID are known to have been replaced by FrozenTransactionId. Add new GUC variables and pg_autovacuum columns to allow management of the freezing policy, so that users can trade off the size of pg_clog against the amount of freezing work done. Revise the already-existing code that forces autovacuum of tables approaching the wraparound point to make it more bulletproof; also, revise the autovacuum logic so that anti-wraparound vacuuming is done per-table rather than per-database. initdb forced because of changes in pg_class, pg_database, and pg_autovacuum catalogs. Heikki Linnakangas, Simon Riggs, and Tom Lane.
******************************************************************************* * * * EXPLANATION OF THE NODE STRUCTURES * * - Andrew Yu (11/94) * * * * Copyright (c) 1994, Regents of the University of California * * * * $PostgreSQL: pgsql/src/backend/nodes/README,v 1.2 2003/11/29 22:39:45 pgsql Exp $ * * ******************************************************************************* INTRODUCTION The current node structures are plain old C structures. "Inheritance" is achieved by convention. No additional functions will be generated. Functions that manipulate node structures reside in this directory. FILES IN THIS DIRECTORY Node manipulation functions: copyfuncs.c - copying a node equalfuncs.c - comparing a node outfuncs.c - convert a node to ascii representation readfuncs.c - convert ascii representation back to a node makefuncs.c - creator functions for primitive nodes Node definitions: nodes.h - define node tags (NodeTag) pg_list.h - generic list primnodes.h - primitive nodes parsenodes.h - parse tree nodes plannodes.h - plan tree nodes relation.h - inner plan tree nodes execnodes.h - executor nodes memnodes.h - memory nodes STEPS TO ADD A NODE Suppose you wana define a node Foo: 1. add a tag (T_Foo) to the enum NodeTag in nodes.h (You may have to recompile the whole tree after doing this.) 2. add the structure definition to the appropriate ???nodes.h file. If you intend to inherit from, say a Plan node, put Plan as the first field of you definition. 3. if you intend to use copyObject, equal, nodeToString or stringToNode, add an appropriate function to copyfuncs.c, equalfuncs.c, outfuncs.c and readfuncs.c accordingly. (Except for frequently used nodes, don't bother writing a creator function in makefuncs.c) HISTORICAL NOTE Prior to the current simple C structure definitions, the Node structures uses a pseudo-inheritance system which automatically generates creator and accessor functions. Since every node inherits from LispValue, the whole thing is a mess. Here's a little anecdote: LispValue definition -- class used to support lisp structures in C. This is here because we did not want to totally rewrite planner and executor code which depended on lisp structures when we ported postgres V1 from lisp to C. -cim 4/23/90