LCOV - code coverage report
Current view: top level - src/include/nodes - nodes.h (source / functions) Coverage Total Hit
Test: PostgreSQL 19devel Lines: 100.0 % 4 4
Test Date: 2026-03-03 13:15:30 Functions: 100.0 % 1 1
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /*-------------------------------------------------------------------------
       2              :  *
       3              :  * nodes.h
       4              :  *    Definitions for tagged nodes.
       5              :  *
       6              :  *
       7              :  * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
       8              :  * Portions Copyright (c) 1994, Regents of the University of California
       9              :  *
      10              :  * src/include/nodes/nodes.h
      11              :  *
      12              :  *-------------------------------------------------------------------------
      13              :  */
      14              : #ifndef NODES_H
      15              : #define NODES_H
      16              : 
      17              : /*
      18              :  * The first field of every node is NodeTag. Each node created (with makeNode)
      19              :  * will have one of the following tags as the value of its first field.
      20              :  *
      21              :  * Note that inserting or deleting node types changes the numbers of other
      22              :  * node types later in the list.  This is no problem during development, since
      23              :  * the node numbers are never stored on disk.  But don't do it in a released
      24              :  * branch, because that would represent an ABI break for extensions.
      25              :  */
      26              : typedef enum NodeTag
      27              : {
      28              :     T_Invalid = 0,
      29              : 
      30              : #include "nodes/nodetags.h"
      31              : } NodeTag;
      32              : 
      33              : /*
      34              :  * pg_node_attr() - Used in node definitions to set extra information for
      35              :  * gen_node_support.pl
      36              :  *
      37              :  * Attributes can be attached to a node as a whole (place the attribute
      38              :  * specification on the first line after the struct's opening brace)
      39              :  * or to a specific field (place it at the end of that field's line).  The
      40              :  * argument is a comma-separated list of attributes.  Unrecognized attributes
      41              :  * cause an error.
      42              :  *
      43              :  * Valid node attributes:
      44              :  *
      45              :  * - abstract: Abstract types are types that cannot be instantiated but that
      46              :  *   can be supertypes of other types.  We track their fields, so that
      47              :  *   subtypes can use them, but we don't emit a node tag, so you can't
      48              :  *   instantiate them.
      49              :  *
      50              :  * - custom_copy_equal: Has custom implementations in copyfuncs.c and
      51              :  *   equalfuncs.c.
      52              :  *
      53              :  * - custom_read_write: Has custom implementations in outfuncs.c and
      54              :  *   readfuncs.c.
      55              :  *
      56              :  * - custom_query_jumble: Has custom implementation in queryjumblefuncs.c.
      57              :  *   Also available as a node field attribute.
      58              :  *
      59              :  * - no_copy: Does not support copyObject() at all.
      60              :  *
      61              :  * - no_equal: Does not support equal() at all.
      62              :  *
      63              :  * - no_copy_equal: Shorthand for both no_copy and no_equal.
      64              :  *
      65              :  * - no_query_jumble: Does not support JumbleQuery() at all.
      66              :  *
      67              :  * - no_read: Does not support nodeRead() at all.
      68              :  *
      69              :  * - nodetag_only: Does not support copyObject(), equal(), jumbleQuery()
      70              :  *   outNode() or nodeRead().
      71              :  *
      72              :  * - special_read_write: Has special treatment in outNode() and nodeRead().
      73              :  *
      74              :  * - nodetag_number(VALUE): assign the specified nodetag number instead of
      75              :  *   an auto-generated number.  Typically this would only be used in stable
      76              :  *   branches, to give a newly-added node type a number without breaking ABI
      77              :  *   by changing the numbers of existing node types.
      78              :  *
      79              :  * Node types can be supertypes of other types whether or not they are marked
      80              :  * abstract: if a node struct appears as the first field of another struct
      81              :  * type, then it is the supertype of that type.  The no_copy, no_equal,
      82              :  * no_query_jumble and no_read node attributes are automatically inherited
      83              :  * from the supertype.  (Notice that nodetag_only does not inherit, so it's
      84              :  * not quite equivalent to a combination of other attributes.)
      85              :  *
      86              :  * Valid node field attributes:
      87              :  *
      88              :  * - array_size(OTHERFIELD): This field is a dynamically allocated array with
      89              :  *   size indicated by the mentioned other field.  The other field is either a
      90              :  *   scalar or a list, in which case the length of the list is used.
      91              :  *
      92              :  * - copy_as(VALUE): In copyObject(), replace the field's value with VALUE.
      93              :  *
      94              :  * - copy_as_scalar: In copyObject(), copy the field as a scalar value
      95              :  *   (e.g. a pointer) even if it is a node-type pointer.
      96              :  *
      97              :  * - equal_as_scalar: In equal(), compare the field as a scalar value
      98              :  *   even if it is a node-type pointer.
      99              :  *
     100              :  * - equal_ignore: Ignore the field for equality.
     101              :  *
     102              :  * - equal_ignore_if_zero: Ignore the field for equality if it is zero.
     103              :  *   (Otherwise, compare normally.)
     104              :  *
     105              :  * - custom_query_jumble: Has custom implementation in queryjumblefuncs.c
     106              :  *   for the field of a node.  Also available as a node attribute.
     107              :  *
     108              :  * - query_jumble_ignore: Ignore the field for the query jumbling.  Note
     109              :  *   that typmod and collation information are usually irrelevant for the
     110              :  *   query jumbling.
     111              :  *
     112              :  * - query_jumble_squash: Squash multiple values during query jumbling.
     113              :  *
     114              :  * - query_jumble_location: Mark the field as a location to track.  This is
     115              :  *   only allowed for integer fields that include "location" in their name.
     116              :  *
     117              :  * - read_as(VALUE): In nodeRead(), replace the field's value with VALUE.
     118              :  *
     119              :  * - read_write_ignore: Ignore the field for read/write.  This is only allowed
     120              :  *   if the node type is marked no_read or read_as() is also specified.
     121              :  *
     122              :  * - write_only_relids, write_only_nondefault_pathtarget, write_only_req_outer:
     123              :  *   Special handling for Path struct; see there.
     124              :  *
     125              :  */
     126              : #define pg_node_attr(...)
     127              : 
     128              : /*
     129              :  * The first field of a node of any type is guaranteed to be the NodeTag.
     130              :  * Hence the type of any node can be gotten by casting it to Node. Declaring
     131              :  * a variable to be of Node * (instead of void *) can also facilitate
     132              :  * debugging.
     133              :  */
     134              : typedef struct Node
     135              : {
     136              :     NodeTag     type;
     137              : } Node;
     138              : 
     139              : #define nodeTag(nodeptr)        (((const Node*)(nodeptr))->type)
     140              : 
     141              : /*
     142              :  * newNode -
     143              :  *    create a new node of the specified size and tag the node with the
     144              :  *    specified tag.
     145              :  *
     146              :  * !WARNING!: Avoid using newNode directly. You should be using the
     147              :  *    macro makeNode.  eg. to create a Query node, use makeNode(Query)
     148              :  */
     149              : static inline Node *
     150    147677406 : newNode(size_t size, NodeTag tag)
     151              : {
     152              :     Node       *result;
     153              : 
     154              :     Assert(size >= sizeof(Node));    /* need the tag, at least */
     155    147677406 :     result = (Node *) palloc0(size);
     156    147677406 :     result->type = tag;
     157              : 
     158    147677406 :     return result;
     159              : }
     160              : 
     161              : #define makeNode(_type_)        ((_type_ *) newNode(sizeof(_type_),T_##_type_))
     162              : #define NodeSetTag(nodeptr,t)   (((Node*)(nodeptr))->type = (t))
     163              : 
     164              : #define IsA(nodeptr,_type_)     (nodeTag(nodeptr) == T_##_type_)
     165              : 
     166              : /*
     167              :  * castNode(type, ptr) casts ptr to "type *", and if assertions are enabled,
     168              :  * verifies that the node has the appropriate type (using its nodeTag()).
     169              :  *
     170              :  * Use an inline function when assertions are enabled, to avoid multiple
     171              :  * evaluations of the ptr argument (which could e.g. be a function call).
     172              :  */
     173              : #ifdef USE_ASSERT_CHECKING
     174              : static inline Node *
     175              : castNodeImpl(NodeTag type, void *ptr)
     176              : {
     177              :     Assert(ptr == NULL || nodeTag(ptr) == type);
     178              :     return (Node *) ptr;
     179              : }
     180              : #define castNode(_type_, nodeptr) ((_type_ *) castNodeImpl(T_##_type_, nodeptr))
     181              : #else
     182              : #define castNode(_type_, nodeptr) ((_type_ *) (nodeptr))
     183              : #endif                          /* USE_ASSERT_CHECKING */
     184              : 
     185              : 
     186              : /* ----------------------------------------------------------------
     187              :  *                    extern declarations follow
     188              :  * ----------------------------------------------------------------
     189              :  */
     190              : 
     191              : #ifndef FRONTEND
     192              : 
     193              : /*
     194              :  * nodes/{outfuncs.c,print.c}
     195              :  */
     196              : struct Bitmapset;               /* not to include bitmapset.h here */
     197              : struct StringInfoData;          /* not to include stringinfo.h here */
     198              : 
     199              : extern void outNode(struct StringInfoData *str, const void *obj);
     200              : extern void outToken(struct StringInfoData *str, const char *s);
     201              : extern void outBitmapset(struct StringInfoData *str,
     202              :                          const struct Bitmapset *bms);
     203              : extern void outDatum(struct StringInfoData *str, Datum value,
     204              :                      int typlen, bool typbyval);
     205              : extern char *nodeToString(const void *obj);
     206              : extern char *nodeToStringWithLocations(const void *obj);
     207              : extern char *bmsToString(const struct Bitmapset *bms);
     208              : 
     209              : /*
     210              :  * nodes/{readfuncs.c,read.c}
     211              :  */
     212              : extern void *stringToNode(const char *str);
     213              : #ifdef DEBUG_NODE_TESTS_ENABLED
     214              : extern void *stringToNodeWithLocations(const char *str);
     215              : #endif
     216              : extern struct Bitmapset *readBitmapset(void);
     217              : extern Datum readDatum(bool typbyval);
     218              : extern bool *readBoolCols(int numCols);
     219              : extern int *readIntCols(int numCols);
     220              : extern Oid *readOidCols(int numCols);
     221              : extern int16 *readAttrNumberCols(int numCols);
     222              : 
     223              : /*
     224              :  * nodes/copyfuncs.c
     225              :  */
     226              : extern void *copyObjectImpl(const void *from);
     227              : 
     228              : /* cast result back to argument type, if supported by compiler */
     229              : #ifdef HAVE_TYPEOF
     230              : #define copyObject(obj) ((typeof(obj)) copyObjectImpl(obj))
     231              : #else
     232              : #define copyObject(obj) copyObjectImpl(obj)
     233              : #endif
     234              : 
     235              : /*
     236              :  * nodes/equalfuncs.c
     237              :  */
     238              : extern bool equal(const void *a, const void *b);
     239              : 
     240              : #endif                          /* !FRONTEND */
     241              : 
     242              : 
     243              : /*
     244              :  * Typedef for parse location.  This is just an int, but this way
     245              :  * gen_node_support.pl knows which fields should get special treatment for
     246              :  * location values.
     247              :  *
     248              :  * -1 is used for unknown.
     249              :  */
     250              : typedef int ParseLoc;
     251              : 
     252              : /*
     253              :  * Typedefs for identifying qualifier selectivities, plan costs, and row
     254              :  * counts as such.  These are just plain "double"s, but declaring a variable
     255              :  * as Selectivity, Cost, or Cardinality makes the intent more obvious.
     256              :  *
     257              :  * These could have gone into plannodes.h or some such, but many files
     258              :  * depend on them...
     259              :  */
     260              : typedef double Selectivity;     /* fraction of tuples a qualifier will pass */
     261              : typedef double Cost;            /* execution cost (in page-access units) */
     262              : typedef double Cardinality;     /* (estimated) number of rows or other integer
     263              :                                  * count */
     264              : 
     265              : 
     266              : /*
     267              :  * CmdType -
     268              :  *    enums for type of operation represented by a Query or PlannedStmt
     269              :  *
     270              :  * This is needed in both parsenodes.h and plannodes.h, so put it here...
     271              :  */
     272              : typedef enum CmdType
     273              : {
     274              :     CMD_UNKNOWN,
     275              :     CMD_SELECT,                 /* select stmt */
     276              :     CMD_UPDATE,                 /* update stmt */
     277              :     CMD_INSERT,                 /* insert stmt */
     278              :     CMD_DELETE,                 /* delete stmt */
     279              :     CMD_MERGE,                  /* merge stmt */
     280              :     CMD_UTILITY,                /* cmds like create, destroy, copy, vacuum,
     281              :                                  * etc. */
     282              :     CMD_NOTHING,                /* dummy command for instead nothing rules
     283              :                                  * with qual */
     284              : } CmdType;
     285              : 
     286              : 
     287              : /*
     288              :  * JoinType -
     289              :  *    enums for types of relation joins
     290              :  *
     291              :  * JoinType determines the exact semantics of joining two relations using
     292              :  * a matching qualification.  For example, it tells what to do with a tuple
     293              :  * that has no match in the other relation.
     294              :  *
     295              :  * This is needed in both parsenodes.h and plannodes.h, so put it here...
     296              :  */
     297              : typedef enum JoinType
     298              : {
     299              :     /*
     300              :      * The canonical kinds of joins according to the SQL JOIN syntax. Only
     301              :      * these codes can appear in parser output (e.g., JoinExpr nodes).
     302              :      */
     303              :     JOIN_INNER,                 /* matching tuple pairs only */
     304              :     JOIN_LEFT,                  /* pairs + unmatched LHS tuples */
     305              :     JOIN_FULL,                  /* pairs + unmatched LHS + unmatched RHS */
     306              :     JOIN_RIGHT,                 /* pairs + unmatched RHS tuples */
     307              : 
     308              :     /*
     309              :      * Semijoins and anti-semijoins (as defined in relational theory) do not
     310              :      * appear in the SQL JOIN syntax, but there are standard idioms for
     311              :      * representing them (e.g., using EXISTS).  The planner recognizes these
     312              :      * cases and converts them to joins.  So the planner and executor must
     313              :      * support these codes.  NOTE: in JOIN_SEMI output, it is unspecified
     314              :      * which matching RHS row is joined to.  In JOIN_ANTI output, the row is
     315              :      * guaranteed to be null-extended.
     316              :      */
     317              :     JOIN_SEMI,                  /* 1 copy of each LHS row that has match(es) */
     318              :     JOIN_ANTI,                  /* 1 copy of each LHS row that has no match */
     319              :     JOIN_RIGHT_SEMI,            /* 1 copy of each RHS row that has match(es) */
     320              :     JOIN_RIGHT_ANTI,            /* 1 copy of each RHS row that has no match */
     321              : 
     322              :     /*
     323              :      * These codes are used internally in the planner, but are not supported
     324              :      * by the executor (nor, indeed, by most of the planner).
     325              :      */
     326              :     JOIN_UNIQUE_OUTER,          /* LHS has be made unique */
     327              :     JOIN_UNIQUE_INNER,          /* RHS has be made unique */
     328              : 
     329              :     /*
     330              :      * We might need additional join types someday.
     331              :      */
     332              : } JoinType;
     333              : 
     334              : /*
     335              :  * OUTER joins are those for which pushed-down quals must behave differently
     336              :  * from the join's own quals.  This is in fact everything except INNER, SEMI
     337              :  * and RIGHT_SEMI joins.  However, this macro must also exclude the
     338              :  * JOIN_UNIQUE symbols since those are temporary proxies for what will
     339              :  * eventually be an INNER join.
     340              :  *
     341              :  * Note: semijoins are a hybrid case, but we choose to treat them as not
     342              :  * being outer joins.  This is okay principally because the SQL syntax makes
     343              :  * it impossible to have a pushed-down qual that refers to the inner relation
     344              :  * of a semijoin; so there is no strong need to distinguish join quals from
     345              :  * pushed-down quals.  This is convenient because for almost all purposes,
     346              :  * quals attached to a semijoin can be treated the same as innerjoin quals.
     347              :  */
     348              : #define IS_OUTER_JOIN(jointype) \
     349              :     (((1 << (jointype)) & \
     350              :       ((1 << JOIN_LEFT) | \
     351              :        (1 << JOIN_FULL) | \
     352              :        (1 << JOIN_RIGHT) | \
     353              :        (1 << JOIN_ANTI) | \
     354              :        (1 << JOIN_RIGHT_ANTI))) != 0)
     355              : 
     356              : /*
     357              :  * AggStrategy -
     358              :  *    overall execution strategies for Agg plan nodes
     359              :  *
     360              :  * This is needed in both pathnodes.h and plannodes.h, so put it here...
     361              :  */
     362              : typedef enum AggStrategy
     363              : {
     364              :     AGG_PLAIN,                  /* simple agg across all input rows */
     365              :     AGG_SORTED,                 /* grouped agg, input must be sorted */
     366              :     AGG_HASHED,                 /* grouped agg, use internal hashtable */
     367              :     AGG_MIXED,                  /* grouped agg, hash and sort both used */
     368              : } AggStrategy;
     369              : 
     370              : /*
     371              :  * AggSplit -
     372              :  *    splitting (partial aggregation) modes for Agg plan nodes
     373              :  *
     374              :  * This is needed in both pathnodes.h and plannodes.h, so put it here...
     375              :  */
     376              : 
     377              : /* Primitive options supported by nodeAgg.c: */
     378              : #define AGGSPLITOP_COMBINE      0x01    /* substitute combinefn for transfn */
     379              : #define AGGSPLITOP_SKIPFINAL    0x02    /* skip finalfn, return state as-is */
     380              : #define AGGSPLITOP_SERIALIZE    0x04    /* apply serialfn to output */
     381              : #define AGGSPLITOP_DESERIALIZE  0x08    /* apply deserialfn to input */
     382              : 
     383              : /* Supported operating modes (i.e., useful combinations of these options): */
     384              : typedef enum AggSplit
     385              : {
     386              :     /* Basic, non-split aggregation: */
     387              :     AGGSPLIT_SIMPLE = 0,
     388              :     /* Initial phase of partial aggregation, with serialization: */
     389              :     AGGSPLIT_INITIAL_SERIAL = AGGSPLITOP_SKIPFINAL | AGGSPLITOP_SERIALIZE,
     390              :     /* Final phase of partial aggregation, with deserialization: */
     391              :     AGGSPLIT_FINAL_DESERIAL = AGGSPLITOP_COMBINE | AGGSPLITOP_DESERIALIZE,
     392              : } AggSplit;
     393              : 
     394              : /* Test whether an AggSplit value selects each primitive option: */
     395              : #define DO_AGGSPLIT_COMBINE(as)     (((as) & AGGSPLITOP_COMBINE) != 0)
     396              : #define DO_AGGSPLIT_SKIPFINAL(as)   (((as) & AGGSPLITOP_SKIPFINAL) != 0)
     397              : #define DO_AGGSPLIT_SERIALIZE(as)   (((as) & AGGSPLITOP_SERIALIZE) != 0)
     398              : #define DO_AGGSPLIT_DESERIALIZE(as) (((as) & AGGSPLITOP_DESERIALIZE) != 0)
     399              : 
     400              : /*
     401              :  * SetOpCmd and SetOpStrategy -
     402              :  *    overall semantics and execution strategies for SetOp plan nodes
     403              :  *
     404              :  * This is needed in both pathnodes.h and plannodes.h, so put it here...
     405              :  */
     406              : typedef enum SetOpCmd
     407              : {
     408              :     SETOPCMD_INTERSECT,
     409              :     SETOPCMD_INTERSECT_ALL,
     410              :     SETOPCMD_EXCEPT,
     411              :     SETOPCMD_EXCEPT_ALL,
     412              : } SetOpCmd;
     413              : 
     414              : typedef enum SetOpStrategy
     415              : {
     416              :     SETOP_SORTED,               /* input must be sorted */
     417              :     SETOP_HASHED,               /* use internal hashtable */
     418              : } SetOpStrategy;
     419              : 
     420              : /*
     421              :  * OnConflictAction -
     422              :  *    "ON CONFLICT" clause type of query
     423              :  *
     424              :  * This is needed in both parsenodes.h and plannodes.h, so put it here...
     425              :  */
     426              : typedef enum OnConflictAction
     427              : {
     428              :     ONCONFLICT_NONE,            /* No "ON CONFLICT" clause */
     429              :     ONCONFLICT_NOTHING,         /* ON CONFLICT ... DO NOTHING */
     430              :     ONCONFLICT_UPDATE,          /* ON CONFLICT ... DO UPDATE */
     431              :     ONCONFLICT_SELECT,          /* ON CONFLICT ... DO SELECT */
     432              : } OnConflictAction;
     433              : 
     434              : /*
     435              :  * LimitOption -
     436              :  *  LIMIT option of query
     437              :  *
     438              :  * This is needed in both parsenodes.h and plannodes.h, so put it here...
     439              :  */
     440              : typedef enum LimitOption
     441              : {
     442              :     LIMIT_OPTION_COUNT,         /* FETCH FIRST... ONLY */
     443              :     LIMIT_OPTION_WITH_TIES,     /* FETCH FIRST... WITH TIES */
     444              : } LimitOption;
     445              : 
     446              : #endif                          /* NODES_H */
        

Generated by: LCOV version 2.0-1