Remove code sections obsoleted by node support automation
authorPeter Eisentraut <peter@eisentraut.org>
Sat, 9 Jul 2022 13:06:01 +0000 (15:06 +0200)
committerPeter Eisentraut <peter@eisentraut.org>
Sat, 9 Jul 2022 13:06:01 +0000 (15:06 +0200)
This removes the code sections that were ifdef'ed out by
964d01ae90c314eb31132c2e7712d5d9fc237331.

src/backend/nodes/copyfuncs.c
src/backend/nodes/equalfuncs.c
src/backend/nodes/outfuncs.c
src/backend/nodes/readfuncs.c
src/include/nodes/nodes.h

index b72c79f2dfe2871985313d0b478c73909ad4e06e..b8e40a4195ac6884903716fb41a9a682cd9d3802 100644 (file)
@@ -3,13 +3,6 @@
  * copyfuncs.c
  *       Copy functions for Postgres tree nodes.
  *
- * NOTE: we currently support copying all node types found in parse and
- * plan trees.  We do not support copying executor state trees; there
- * is no need for that, and no point in maintaining all the code that
- * would be needed.  We also do not support copying Path trees, mainly
- * because the circular linkages between RelOptInfo and Path nodes can't
- * be handled easily in a simple depth-first traversal.
- *
  *
  * Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
  * Portions Copyright (c) 1994, Regents of the University of California
 
 #include "copyfuncs.funcs.c"
 
-#ifdef OBSOLETE
-/* ****************************************************************
- *                                      plannodes.h copy functions
- * ****************************************************************
- */
-
-/*
- * _copyPlannedStmt
- */
-static PlannedStmt *
-_copyPlannedStmt(const PlannedStmt *from)
-{
-       PlannedStmt *newnode = makeNode(PlannedStmt);
-
-       COPY_SCALAR_FIELD(commandType);
-       COPY_SCALAR_FIELD(queryId);
-       COPY_SCALAR_FIELD(hasReturning);
-       COPY_SCALAR_FIELD(hasModifyingCTE);
-       COPY_SCALAR_FIELD(canSetTag);
-       COPY_SCALAR_FIELD(transientPlan);
-       COPY_SCALAR_FIELD(dependsOnRole);
-       COPY_SCALAR_FIELD(parallelModeNeeded);
-       COPY_SCALAR_FIELD(jitFlags);
-       COPY_NODE_FIELD(planTree);
-       COPY_NODE_FIELD(rtable);
-       COPY_NODE_FIELD(resultRelations);
-       COPY_NODE_FIELD(appendRelations);
-       COPY_NODE_FIELD(subplans);
-       COPY_BITMAPSET_FIELD(rewindPlanIDs);
-       COPY_NODE_FIELD(rowMarks);
-       COPY_NODE_FIELD(relationOids);
-       COPY_NODE_FIELD(invalItems);
-       COPY_NODE_FIELD(paramExecTypes);
-       COPY_NODE_FIELD(utilityStmt);
-       COPY_LOCATION_FIELD(stmt_location);
-       COPY_SCALAR_FIELD(stmt_len);
-
-       return newnode;
-}
-
-/*
- * CopyPlanFields
- *
- *             This function copies the fields of the Plan node.  It is used by
- *             all the copy functions for classes which inherit from Plan.
- */
-static void
-CopyPlanFields(const Plan *from, Plan *newnode)
-{
-       COPY_SCALAR_FIELD(startup_cost);
-       COPY_SCALAR_FIELD(total_cost);
-       COPY_SCALAR_FIELD(plan_rows);
-       COPY_SCALAR_FIELD(plan_width);
-       COPY_SCALAR_FIELD(parallel_aware);
-       COPY_SCALAR_FIELD(parallel_safe);
-       COPY_SCALAR_FIELD(async_capable);
-       COPY_SCALAR_FIELD(plan_node_id);
-       COPY_NODE_FIELD(targetlist);
-       COPY_NODE_FIELD(qual);
-       COPY_NODE_FIELD(lefttree);
-       COPY_NODE_FIELD(righttree);
-       COPY_NODE_FIELD(initPlan);
-       COPY_BITMAPSET_FIELD(extParam);
-       COPY_BITMAPSET_FIELD(allParam);
-}
-
-/*
- * _copyResult
- */
-static Result *
-_copyResult(const Result *from)
-{
-       Result     *newnode = makeNode(Result);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(resconstantqual);
-
-       return newnode;
-}
-
-/*
- * _copyProjectSet
- */
-static ProjectSet *
-_copyProjectSet(const ProjectSet *from)
-{
-       ProjectSet *newnode = makeNode(ProjectSet);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       return newnode;
-}
-
-/*
- * _copyModifyTable
- */
-static ModifyTable *
-_copyModifyTable(const ModifyTable *from)
-{
-       ModifyTable *newnode = makeNode(ModifyTable);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(operation);
-       COPY_SCALAR_FIELD(canSetTag);
-       COPY_SCALAR_FIELD(nominalRelation);
-       COPY_SCALAR_FIELD(rootRelation);
-       COPY_SCALAR_FIELD(partColsUpdated);
-       COPY_NODE_FIELD(resultRelations);
-       COPY_NODE_FIELD(updateColnosLists);
-       COPY_NODE_FIELD(withCheckOptionLists);
-       COPY_NODE_FIELD(returningLists);
-       COPY_NODE_FIELD(fdwPrivLists);
-       COPY_BITMAPSET_FIELD(fdwDirectModifyPlans);
-       COPY_NODE_FIELD(rowMarks);
-       COPY_SCALAR_FIELD(epqParam);
-       COPY_SCALAR_FIELD(onConflictAction);
-       COPY_NODE_FIELD(arbiterIndexes);
-       COPY_NODE_FIELD(onConflictSet);
-       COPY_NODE_FIELD(onConflictCols);
-       COPY_NODE_FIELD(onConflictWhere);
-       COPY_SCALAR_FIELD(exclRelRTI);
-       COPY_NODE_FIELD(exclRelTlist);
-       COPY_NODE_FIELD(mergeActionLists);
-
-       return newnode;
-}
-
-/*
- * _copyAppend
- */
-static Append *
-_copyAppend(const Append *from)
-{
-       Append     *newnode = makeNode(Append);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_BITMAPSET_FIELD(apprelids);
-       COPY_NODE_FIELD(appendplans);
-       COPY_SCALAR_FIELD(nasyncplans);
-       COPY_SCALAR_FIELD(first_partial_plan);
-       COPY_NODE_FIELD(part_prune_info);
-
-       return newnode;
-}
 
 /*
- * _copyMergeAppend
+ * Support functions for nodes with custom_copy_equal attribute
  */
-static MergeAppend *
-_copyMergeAppend(const MergeAppend *from)
-{
-       MergeAppend *newnode = makeNode(MergeAppend);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_BITMAPSET_FIELD(apprelids);
-       COPY_NODE_FIELD(mergeplans);
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(sortColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(sortOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(collations, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(nullsFirst, from->numCols * sizeof(bool));
-       COPY_NODE_FIELD(part_prune_info);
-
-       return newnode;
-}
 
-/*
- * _copyRecursiveUnion
- */
-static RecursiveUnion *
-_copyRecursiveUnion(const RecursiveUnion *from)
+static Const *
+_copyConst(const Const *from)
 {
-       RecursiveUnion *newnode = makeNode(RecursiveUnion);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(wtParam);
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(dupColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(dupOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(dupCollations, from->numCols * sizeof(Oid));
-       COPY_SCALAR_FIELD(numGroups);
-
-       return newnode;
-}
+       Const      *newnode = makeNode(Const);
 
-/*
- * _copyBitmapAnd
- */
-static BitmapAnd *
-_copyBitmapAnd(const BitmapAnd *from)
-{
-       BitmapAnd  *newnode = makeNode(BitmapAnd);
+       COPY_SCALAR_FIELD(consttype);
+       COPY_SCALAR_FIELD(consttypmod);
+       COPY_SCALAR_FIELD(constcollid);
+       COPY_SCALAR_FIELD(constlen);
 
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
+       if (from->constbyval || from->constisnull)
+       {
+               /*
+                * passed by value so just copy the datum. Also, don't try to copy
+                * struct when value is null!
+                */
+               newnode->constvalue = from->constvalue;
+       }
+       else
+       {
+               /*
+                * passed by reference.  We need a palloc'd copy.
+                */
+               newnode->constvalue = datumCopy(from->constvalue,
+                                                                               from->constbyval,
+                                                                               from->constlen);
+       }
 
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(bitmapplans);
+       COPY_SCALAR_FIELD(constisnull);
+       COPY_SCALAR_FIELD(constbyval);
+       COPY_LOCATION_FIELD(location);
 
        return newnode;
 }
 
-/*
- * _copyBitmapOr
- */
-static BitmapOr *
-_copyBitmapOr(const BitmapOr *from)
+static A_Const *
+_copyA_Const(const A_Const *from)
 {
-       BitmapOr   *newnode = makeNode(BitmapOr);
+       A_Const    *newnode = makeNode(A_Const);
 
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
+       COPY_SCALAR_FIELD(isnull);
+       if (!from->isnull)
+       {
+               /* This part must duplicate other _copy*() functions. */
+               COPY_SCALAR_FIELD(val.node.type);
+               switch (nodeTag(&from->val))
+               {
+                       case T_Integer:
+                               COPY_SCALAR_FIELD(val.ival.ival);
+                               break;
+                       case T_Float:
+                               COPY_STRING_FIELD(val.fval.fval);
+                               break;
+                       case T_Boolean:
+                               COPY_SCALAR_FIELD(val.boolval.boolval);
+                               break;
+                       case T_String:
+                               COPY_STRING_FIELD(val.sval.sval);
+                               break;
+                       case T_BitString:
+                               COPY_STRING_FIELD(val.bsval.bsval);
+                               break;
+                       default:
+                               elog(ERROR, "unrecognized node type: %d",
+                                        (int) nodeTag(&from->val));
+                               break;
+               }
+       }
 
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(isshared);
-       COPY_NODE_FIELD(bitmapplans);
+       COPY_LOCATION_FIELD(location);
 
        return newnode;
 }
 
-/*
- * _copyGather
- */
-static Gather *
-_copyGather(const Gather *from)
+static ExtensibleNode *
+_copyExtensibleNode(const ExtensibleNode *from)
 {
-       Gather     *newnode = makeNode(Gather);
+       ExtensibleNode *newnode;
+       const ExtensibleNodeMethods *methods;
 
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
+       methods = GetExtensibleNodeMethods(from->extnodename, false);
+       newnode = (ExtensibleNode *) newNode(methods->node_size,
+                                                                                T_ExtensibleNode);
+       COPY_STRING_FIELD(extnodename);
 
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(num_workers);
-       COPY_SCALAR_FIELD(rescan_param);
-       COPY_SCALAR_FIELD(single_copy);
-       COPY_SCALAR_FIELD(invisible);
-       COPY_BITMAPSET_FIELD(initParam);
+       /* copy the private fields */
+       methods->nodeCopy(newnode, from);
 
        return newnode;
 }
 
-/*
- * _copyGatherMerge
- */
-static GatherMerge *
-_copyGatherMerge(const GatherMerge *from)
-{
-       GatherMerge *newnode = makeNode(GatherMerge);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(num_workers);
-       COPY_SCALAR_FIELD(rescan_param);
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(sortColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(sortOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(collations, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(nullsFirst, from->numCols * sizeof(bool));
-       COPY_BITMAPSET_FIELD(initParam);
-
-       return newnode;
-}
 
 /*
- * CopyScanFields
+ * copyObjectImpl -- implementation of copyObject(); see nodes/nodes.h
  *
- *             This function copies the fields of the Scan node.  It is used by
- *             all the copy functions for classes which inherit from Scan.
- */
-static void
-CopyScanFields(const Scan *from, Scan *newnode)
-{
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       COPY_SCALAR_FIELD(scanrelid);
-}
-
-/*
- * _copyScan
- */
-static Scan *
-_copyScan(const Scan *from)
-{
-       Scan       *newnode = makeNode(Scan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       return newnode;
-}
-
-/*
- * _copySeqScan
- */
-static SeqScan *
-_copySeqScan(const SeqScan *from)
-{
-       SeqScan    *newnode = makeNode(SeqScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       return newnode;
-}
-
-/*
- * _copySampleScan
- */
-static SampleScan *
-_copySampleScan(const SampleScan *from)
-{
-       SampleScan *newnode = makeNode(SampleScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(tablesample);
-
-       return newnode;
-}
-
-/*
- * _copyIndexScan
- */
-static IndexScan *
-_copyIndexScan(const IndexScan *from)
-{
-       IndexScan  *newnode = makeNode(IndexScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(indexid);
-       COPY_NODE_FIELD(indexqual);
-       COPY_NODE_FIELD(indexqualorig);
-       COPY_NODE_FIELD(indexorderby);
-       COPY_NODE_FIELD(indexorderbyorig);
-       COPY_NODE_FIELD(indexorderbyops);
-       COPY_SCALAR_FIELD(indexorderdir);
-
-       return newnode;
-}
-
-/*
- * _copyIndexOnlyScan
- */
-static IndexOnlyScan *
-_copyIndexOnlyScan(const IndexOnlyScan *from)
-{
-       IndexOnlyScan *newnode = makeNode(IndexOnlyScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(indexid);
-       COPY_NODE_FIELD(indexqual);
-       COPY_NODE_FIELD(recheckqual);
-       COPY_NODE_FIELD(indexorderby);
-       COPY_NODE_FIELD(indextlist);
-       COPY_SCALAR_FIELD(indexorderdir);
-
-       return newnode;
-}
-
-/*
- * _copyBitmapIndexScan
- */
-static BitmapIndexScan *
-_copyBitmapIndexScan(const BitmapIndexScan *from)
-{
-       BitmapIndexScan *newnode = makeNode(BitmapIndexScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(indexid);
-       COPY_SCALAR_FIELD(isshared);
-       COPY_NODE_FIELD(indexqual);
-       COPY_NODE_FIELD(indexqualorig);
-
-       return newnode;
-}
-
-/*
- * _copyBitmapHeapScan
- */
-static BitmapHeapScan *
-_copyBitmapHeapScan(const BitmapHeapScan *from)
-{
-       BitmapHeapScan *newnode = makeNode(BitmapHeapScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(bitmapqualorig);
-
-       return newnode;
-}
-
-/*
- * _copyTidScan
- */
-static TidScan *
-_copyTidScan(const TidScan *from)
-{
-       TidScan    *newnode = makeNode(TidScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(tidquals);
-
-       return newnode;
-}
-
-/*
- * _copyTidRangeScan
- */
-static TidRangeScan *
-_copyTidRangeScan(const TidRangeScan *from)
-{
-       TidRangeScan *newnode = makeNode(TidRangeScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(tidrangequals);
-
-       return newnode;
-}
-
-/*
- * _copySubqueryScan
+ * Create a copy of a Node tree or list.  This is a "deep" copy: all
+ * substructure is copied too, recursively.
  */
-static SubqueryScan *
-_copySubqueryScan(const SubqueryScan *from)
+void *
+copyObjectImpl(const void *from)
 {
-       SubqueryScan *newnode = makeNode(SubqueryScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(subplan);
-       COPY_SCALAR_FIELD(scanstatus);
+       void       *retval;
 
-       return newnode;
-}
+       if (from == NULL)
+               return NULL;
 
-/*
- * _copyFunctionScan
- */
-static FunctionScan *
-_copyFunctionScan(const FunctionScan *from)
-{
-       FunctionScan *newnode = makeNode(FunctionScan);
+       /* Guard against stack overflow due to overly complex expressions */
+       check_stack_depth();
 
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
+       switch (nodeTag(from))
+       {
+#include "copyfuncs.switch.c"
 
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(functions);
-       COPY_SCALAR_FIELD(funcordinality);
-
-       return newnode;
-}
-
-/*
- * _copyTableFuncScan
- */
-static TableFuncScan *
-_copyTableFuncScan(const TableFuncScan *from)
-{
-       TableFuncScan *newnode = makeNode(TableFuncScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(tablefunc);
-
-       return newnode;
-}
-
-/*
- * _copyValuesScan
- */
-static ValuesScan *
-_copyValuesScan(const ValuesScan *from)
-{
-       ValuesScan *newnode = makeNode(ValuesScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(values_lists);
-
-       return newnode;
-}
-
-/*
- * _copyCteScan
- */
-static CteScan *
-_copyCteScan(const CteScan *from)
-{
-       CteScan    *newnode = makeNode(CteScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(ctePlanId);
-       COPY_SCALAR_FIELD(cteParam);
-
-       return newnode;
-}
-
-/*
- * _copyNamedTuplestoreScan
- */
-static NamedTuplestoreScan *
-_copyNamedTuplestoreScan(const NamedTuplestoreScan *from)
-{
-       NamedTuplestoreScan *newnode = makeNode(NamedTuplestoreScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_STRING_FIELD(enrname);
-
-       return newnode;
-}
-
-/*
- * _copyWorkTableScan
- */
-static WorkTableScan *
-_copyWorkTableScan(const WorkTableScan *from)
-{
-       WorkTableScan *newnode = makeNode(WorkTableScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(wtParam);
-
-       return newnode;
-}
-
-/*
- * _copyForeignScan
- */
-static ForeignScan *
-_copyForeignScan(const ForeignScan *from)
-{
-       ForeignScan *newnode = makeNode(ForeignScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(operation);
-       COPY_SCALAR_FIELD(resultRelation);
-       COPY_SCALAR_FIELD(fs_server);
-       COPY_NODE_FIELD(fdw_exprs);
-       COPY_NODE_FIELD(fdw_private);
-       COPY_NODE_FIELD(fdw_scan_tlist);
-       COPY_NODE_FIELD(fdw_recheck_quals);
-       COPY_BITMAPSET_FIELD(fs_relids);
-       COPY_SCALAR_FIELD(fsSystemCol);
-
-       return newnode;
-}
-
-/*
- * _copyCustomScan
- */
-static CustomScan *
-_copyCustomScan(const CustomScan *from)
-{
-       CustomScan *newnode = makeNode(CustomScan);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyScanFields((const Scan *) from, (Scan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(flags);
-       COPY_NODE_FIELD(custom_plans);
-       COPY_NODE_FIELD(custom_exprs);
-       COPY_NODE_FIELD(custom_private);
-       COPY_NODE_FIELD(custom_scan_tlist);
-       COPY_BITMAPSET_FIELD(custom_relids);
-
-       /*
-        * NOTE: The method field of CustomScan is required to be a pointer to a
-        * static table of callback functions.  So we don't copy the table itself,
-        * just reference the original one.
-        */
-       COPY_SCALAR_FIELD(methods);
-
-       return newnode;
-}
-
-/*
- * CopyJoinFields
- *
- *             This function copies the fields of the Join node.  It is used by
- *             all the copy functions for classes which inherit from Join.
- */
-static void
-CopyJoinFields(const Join *from, Join *newnode)
-{
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       COPY_SCALAR_FIELD(jointype);
-       COPY_SCALAR_FIELD(inner_unique);
-       COPY_NODE_FIELD(joinqual);
-}
-
-
-/*
- * _copyNestLoop
- */
-static NestLoop *
-_copyNestLoop(const NestLoop *from)
-{
-       NestLoop   *newnode = makeNode(NestLoop);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyJoinFields((const Join *) from, (Join *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(nestParams);
-
-       return newnode;
-}
-
-
-/*
- * _copyMergeJoin
- */
-static MergeJoin *
-_copyMergeJoin(const MergeJoin *from)
-{
-       MergeJoin  *newnode = makeNode(MergeJoin);
-       int                     numCols;
-
-       /*
-        * copy node superclass fields
-        */
-       CopyJoinFields((const Join *) from, (Join *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(skip_mark_restore);
-       COPY_NODE_FIELD(mergeclauses);
-       numCols = list_length(from->mergeclauses);
-       COPY_POINTER_FIELD(mergeFamilies, numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(mergeCollations, numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(mergeStrategies, numCols * sizeof(int));
-       COPY_POINTER_FIELD(mergeNullsFirst, numCols * sizeof(bool));
-
-       return newnode;
-}
-
-/*
- * _copyHashJoin
- */
-static HashJoin *
-_copyHashJoin(const HashJoin *from)
-{
-       HashJoin   *newnode = makeNode(HashJoin);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyJoinFields((const Join *) from, (Join *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(hashclauses);
-       COPY_NODE_FIELD(hashoperators);
-       COPY_NODE_FIELD(hashcollations);
-       COPY_NODE_FIELD(hashkeys);
-
-       return newnode;
-}
-
-
-/*
- * _copyMaterial
- */
-static Material *
-_copyMaterial(const Material *from)
-{
-       Material   *newnode = makeNode(Material);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       return newnode;
-}
-
-
-/*
- * _copyMemoize
- */
-static Memoize *
-_copyMemoize(const Memoize *from)
-{
-       Memoize    *newnode = makeNode(Memoize);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(numKeys);
-       COPY_POINTER_FIELD(hashOperators, sizeof(Oid) * from->numKeys);
-       COPY_POINTER_FIELD(collations, sizeof(Oid) * from->numKeys);
-       COPY_NODE_FIELD(param_exprs);
-       COPY_SCALAR_FIELD(singlerow);
-       COPY_SCALAR_FIELD(binary_mode);
-       COPY_SCALAR_FIELD(est_entries);
-       COPY_BITMAPSET_FIELD(keyparamids);
-
-       return newnode;
-}
-
-
-/*
- * CopySortFields
- *
- *             This function copies the fields of the Sort node.  It is used by
- *             all the copy functions for classes which inherit from Sort.
- */
-static void
-CopySortFields(const Sort *from, Sort *newnode)
-{
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(sortColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(sortOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(collations, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(nullsFirst, from->numCols * sizeof(bool));
-}
-
-/*
- * _copySort
- */
-static Sort *
-_copySort(const Sort *from)
-{
-       Sort       *newnode = makeNode(Sort);
-
-       /*
-        * copy node superclass fields
-        */
-       CopySortFields(from, newnode);
-
-       return newnode;
-}
-
-
-/*
- * _copyIncrementalSort
- */
-static IncrementalSort *
-_copyIncrementalSort(const IncrementalSort *from)
-{
-       IncrementalSort *newnode = makeNode(IncrementalSort);
-
-       /*
-        * copy node superclass fields
-        */
-       CopySortFields((const Sort *) from, (Sort *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(nPresortedCols);
-
-       return newnode;
-}
-
-
-/*
- * _copyGroup
- */
-static Group *
-_copyGroup(const Group *from)
-{
-       Group      *newnode = makeNode(Group);
-
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(grpColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(grpOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(grpCollations, from->numCols * sizeof(Oid));
-
-       return newnode;
-}
-
-/*
- * _copyAgg
- */
-static Agg *
-_copyAgg(const Agg *from)
-{
-       Agg                *newnode = makeNode(Agg);
-
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       COPY_SCALAR_FIELD(aggstrategy);
-       COPY_SCALAR_FIELD(aggsplit);
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(grpColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(grpOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(grpCollations, from->numCols * sizeof(Oid));
-       COPY_SCALAR_FIELD(numGroups);
-       COPY_SCALAR_FIELD(transitionSpace);
-       COPY_BITMAPSET_FIELD(aggParams);
-       COPY_NODE_FIELD(groupingSets);
-       COPY_NODE_FIELD(chain);
-
-       return newnode;
-}
-
-/*
- * _copyWindowAgg
- */
-static WindowAgg *
-_copyWindowAgg(const WindowAgg *from)
-{
-       WindowAgg  *newnode = makeNode(WindowAgg);
-
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       COPY_SCALAR_FIELD(winref);
-       COPY_SCALAR_FIELD(partNumCols);
-       COPY_POINTER_FIELD(partColIdx, from->partNumCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(partOperators, from->partNumCols * sizeof(Oid));
-       COPY_POINTER_FIELD(partCollations, from->partNumCols * sizeof(Oid));
-       COPY_SCALAR_FIELD(ordNumCols);
-       COPY_POINTER_FIELD(ordColIdx, from->ordNumCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(ordOperators, from->ordNumCols * sizeof(Oid));
-       COPY_POINTER_FIELD(ordCollations, from->ordNumCols * sizeof(Oid));
-       COPY_SCALAR_FIELD(frameOptions);
-       COPY_NODE_FIELD(startOffset);
-       COPY_NODE_FIELD(endOffset);
-       COPY_NODE_FIELD(runCondition);
-       COPY_NODE_FIELD(runConditionOrig);
-       COPY_SCALAR_FIELD(startInRangeFunc);
-       COPY_SCALAR_FIELD(endInRangeFunc);
-       COPY_SCALAR_FIELD(inRangeColl);
-       COPY_SCALAR_FIELD(inRangeAsc);
-       COPY_SCALAR_FIELD(inRangeNullsFirst);
-       COPY_SCALAR_FIELD(topWindow);
-
-       return newnode;
-}
-
-/*
- * _copyUnique
- */
-static Unique *
-_copyUnique(const Unique *from)
-{
-       Unique     *newnode = makeNode(Unique);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(uniqColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(uniqOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(uniqCollations, from->numCols * sizeof(Oid));
-
-       return newnode;
-}
-
-/*
- * _copyHash
- */
-static Hash *
-_copyHash(const Hash *from)
-{
-       Hash       *newnode = makeNode(Hash);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(hashkeys);
-       COPY_SCALAR_FIELD(skewTable);
-       COPY_SCALAR_FIELD(skewColumn);
-       COPY_SCALAR_FIELD(skewInherit);
-       COPY_SCALAR_FIELD(rows_total);
-
-       return newnode;
-}
-
-/*
- * _copySetOp
- */
-static SetOp *
-_copySetOp(const SetOp *from)
-{
-       SetOp      *newnode = makeNode(SetOp);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_SCALAR_FIELD(cmd);
-       COPY_SCALAR_FIELD(strategy);
-       COPY_SCALAR_FIELD(numCols);
-       COPY_POINTER_FIELD(dupColIdx, from->numCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(dupOperators, from->numCols * sizeof(Oid));
-       COPY_POINTER_FIELD(dupCollations, from->numCols * sizeof(Oid));
-       COPY_SCALAR_FIELD(flagColIdx);
-       COPY_SCALAR_FIELD(firstFlag);
-       COPY_SCALAR_FIELD(numGroups);
-
-       return newnode;
-}
-
-/*
- * _copyLockRows
- */
-static LockRows *
-_copyLockRows(const LockRows *from)
-{
-       LockRows   *newnode = makeNode(LockRows);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(rowMarks);
-       COPY_SCALAR_FIELD(epqParam);
-
-       return newnode;
-}
-
-/*
- * _copyLimit
- */
-static Limit *
-_copyLimit(const Limit *from)
-{
-       Limit      *newnode = makeNode(Limit);
-
-       /*
-        * copy node superclass fields
-        */
-       CopyPlanFields((const Plan *) from, (Plan *) newnode);
-
-       /*
-        * copy remainder of node
-        */
-       COPY_NODE_FIELD(limitOffset);
-       COPY_NODE_FIELD(limitCount);
-       COPY_SCALAR_FIELD(limitOption);
-       COPY_SCALAR_FIELD(uniqNumCols);
-       COPY_POINTER_FIELD(uniqColIdx, from->uniqNumCols * sizeof(AttrNumber));
-       COPY_POINTER_FIELD(uniqOperators, from->uniqNumCols * sizeof(Oid));
-       COPY_POINTER_FIELD(uniqCollations, from->uniqNumCols * sizeof(Oid));
-
-       return newnode;
-}
-
-/*
- * _copyNestLoopParam
- */
-static NestLoopParam *
-_copyNestLoopParam(const NestLoopParam *from)
-{
-       NestLoopParam *newnode = makeNode(NestLoopParam);
-
-       COPY_SCALAR_FIELD(paramno);
-       COPY_NODE_FIELD(paramval);
-
-       return newnode;
-}
-
-/*
- * _copyPlanRowMark
- */
-static PlanRowMark *
-_copyPlanRowMark(const PlanRowMark *from)
-{
-       PlanRowMark *newnode = makeNode(PlanRowMark);
-
-       COPY_SCALAR_FIELD(rti);
-       COPY_SCALAR_FIELD(prti);
-       COPY_SCALAR_FIELD(rowmarkId);
-       COPY_SCALAR_FIELD(markType);
-       COPY_SCALAR_FIELD(allMarkTypes);
-       COPY_SCALAR_FIELD(strength);
-       COPY_SCALAR_FIELD(waitPolicy);
-       COPY_SCALAR_FIELD(isParent);
-
-       return newnode;
-}
-
-static PartitionPruneInfo *
-_copyPartitionPruneInfo(const PartitionPruneInfo *from)
-{
-       PartitionPruneInfo *newnode = makeNode(PartitionPruneInfo);
-
-       COPY_NODE_FIELD(prune_infos);
-       COPY_BITMAPSET_FIELD(other_subplans);
-
-       return newnode;
-}
-
-static PartitionedRelPruneInfo *
-_copyPartitionedRelPruneInfo(const PartitionedRelPruneInfo *from)
-{
-       PartitionedRelPruneInfo *newnode = makeNode(PartitionedRelPruneInfo);
-
-       COPY_SCALAR_FIELD(rtindex);
-       COPY_BITMAPSET_FIELD(present_parts);
-       COPY_SCALAR_FIELD(nparts);
-       COPY_POINTER_FIELD(subplan_map, from->nparts * sizeof(int));
-       COPY_POINTER_FIELD(subpart_map, from->nparts * sizeof(int));
-       COPY_POINTER_FIELD(relid_map, from->nparts * sizeof(Oid));
-       COPY_NODE_FIELD(initial_pruning_steps);
-       COPY_NODE_FIELD(exec_pruning_steps);
-       COPY_BITMAPSET_FIELD(execparamids);
-
-       return newnode;
-}
-
-/*
- * _copyPartitionPruneStepOp
- */
-static PartitionPruneStepOp *
-_copyPartitionPruneStepOp(const PartitionPruneStepOp *from)
-{
-       PartitionPruneStepOp *newnode = makeNode(PartitionPruneStepOp);
-
-       COPY_SCALAR_FIELD(step.step_id);
-       COPY_SCALAR_FIELD(opstrategy);
-       COPY_NODE_FIELD(exprs);
-       COPY_NODE_FIELD(cmpfns);
-       COPY_BITMAPSET_FIELD(nullkeys);
-
-       return newnode;
-}
-
-/*
- * _copyPartitionPruneStepCombine
- */
-static PartitionPruneStepCombine *
-_copyPartitionPruneStepCombine(const PartitionPruneStepCombine *from)
-{
-       PartitionPruneStepCombine *newnode = makeNode(PartitionPruneStepCombine);
-
-       COPY_SCALAR_FIELD(step.step_id);
-       COPY_SCALAR_FIELD(combineOp);
-       COPY_NODE_FIELD(source_stepids);
-
-       return newnode;
-}
-
-/*
- * _copyPlanInvalItem
- */
-static PlanInvalItem *
-_copyPlanInvalItem(const PlanInvalItem *from)
-{
-       PlanInvalItem *newnode = makeNode(PlanInvalItem);
-
-       COPY_SCALAR_FIELD(cacheId);
-       COPY_SCALAR_FIELD(hashValue);
-
-       return newnode;
-}
-
-/* ****************************************************************
- *                                        primnodes.h copy functions
- * ****************************************************************
- */
-
-/*
- * _copyAlias
- */
-static Alias *
-_copyAlias(const Alias *from)
-{
-       Alias      *newnode = makeNode(Alias);
-
-       COPY_STRING_FIELD(aliasname);
-       COPY_NODE_FIELD(colnames);
-
-       return newnode;
-}
-
-/*
- * _copyRangeVar
- */
-static RangeVar *
-_copyRangeVar(const RangeVar *from)
-{
-       RangeVar   *newnode = makeNode(RangeVar);
-
-       COPY_STRING_FIELD(catalogname);
-       COPY_STRING_FIELD(schemaname);
-       COPY_STRING_FIELD(relname);
-       COPY_SCALAR_FIELD(inh);
-       COPY_SCALAR_FIELD(relpersistence);
-       COPY_NODE_FIELD(alias);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyTableFunc
- */
-static TableFunc *
-_copyTableFunc(const TableFunc *from)
-{
-       TableFunc  *newnode = makeNode(TableFunc);
-
-       COPY_SCALAR_FIELD(functype);
-       COPY_NODE_FIELD(ns_uris);
-       COPY_NODE_FIELD(ns_names);
-       COPY_NODE_FIELD(docexpr);
-       COPY_NODE_FIELD(rowexpr);
-       COPY_NODE_FIELD(colnames);
-       COPY_NODE_FIELD(coltypes);
-       COPY_NODE_FIELD(coltypmods);
-       COPY_NODE_FIELD(colcollations);
-       COPY_NODE_FIELD(colexprs);
-       COPY_NODE_FIELD(coldefexprs);
-       COPY_NODE_FIELD(colvalexprs);
-       COPY_BITMAPSET_FIELD(notnulls);
-       COPY_NODE_FIELD(plan);
-       COPY_SCALAR_FIELD(ordinalitycol);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyIntoClause
- */
-static IntoClause *
-_copyIntoClause(const IntoClause *from)
-{
-       IntoClause *newnode = makeNode(IntoClause);
-
-       COPY_NODE_FIELD(rel);
-       COPY_NODE_FIELD(colNames);
-       COPY_STRING_FIELD(accessMethod);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(onCommit);
-       COPY_STRING_FIELD(tableSpaceName);
-       COPY_NODE_FIELD(viewQuery);
-       COPY_SCALAR_FIELD(skipData);
-
-       return newnode;
-}
-
-/*
- * We don't need a _copyExpr because Expr is an abstract supertype which
- * should never actually get instantiated.  Also, since it has no common
- * fields except NodeTag, there's no need for a helper routine to factor
- * out copying the common fields...
- */
-
-/*
- * _copyVar
- */
-static Var *
-_copyVar(const Var *from)
-{
-       Var                *newnode = makeNode(Var);
-
-       COPY_SCALAR_FIELD(varno);
-       COPY_SCALAR_FIELD(varattno);
-       COPY_SCALAR_FIELD(vartype);
-       COPY_SCALAR_FIELD(vartypmod);
-       COPY_SCALAR_FIELD(varcollid);
-       COPY_SCALAR_FIELD(varlevelsup);
-       COPY_SCALAR_FIELD(varnosyn);
-       COPY_SCALAR_FIELD(varattnosyn);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * _copyConst
- */
-static Const *
-_copyConst(const Const *from)
-{
-       Const      *newnode = makeNode(Const);
-
-       COPY_SCALAR_FIELD(consttype);
-       COPY_SCALAR_FIELD(consttypmod);
-       COPY_SCALAR_FIELD(constcollid);
-       COPY_SCALAR_FIELD(constlen);
-
-       if (from->constbyval || from->constisnull)
-       {
-               /*
-                * passed by value so just copy the datum. Also, don't try to copy
-                * struct when value is null!
-                */
-               newnode->constvalue = from->constvalue;
-       }
-       else
-       {
-               /*
-                * passed by reference.  We need a palloc'd copy.
-                */
-               newnode->constvalue = datumCopy(from->constvalue,
-                                                                               from->constbyval,
-                                                                               from->constlen);
-       }
-
-       COPY_SCALAR_FIELD(constisnull);
-       COPY_SCALAR_FIELD(constbyval);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-#ifdef OBSOLETE
-/*
- * _copyParam
- */
-static Param *
-_copyParam(const Param *from)
-{
-       Param      *newnode = makeNode(Param);
-
-       COPY_SCALAR_FIELD(paramkind);
-       COPY_SCALAR_FIELD(paramid);
-       COPY_SCALAR_FIELD(paramtype);
-       COPY_SCALAR_FIELD(paramtypmod);
-       COPY_SCALAR_FIELD(paramcollid);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyAggref
- */
-static Aggref *
-_copyAggref(const Aggref *from)
-{
-       Aggref     *newnode = makeNode(Aggref);
-
-       COPY_SCALAR_FIELD(aggfnoid);
-       COPY_SCALAR_FIELD(aggtype);
-       COPY_SCALAR_FIELD(aggcollid);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_SCALAR_FIELD(aggtranstype);
-       COPY_NODE_FIELD(aggargtypes);
-       COPY_NODE_FIELD(aggdirectargs);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(aggorder);
-       COPY_NODE_FIELD(aggdistinct);
-       COPY_NODE_FIELD(aggfilter);
-       COPY_SCALAR_FIELD(aggstar);
-       COPY_SCALAR_FIELD(aggvariadic);
-       COPY_SCALAR_FIELD(aggkind);
-       COPY_SCALAR_FIELD(agglevelsup);
-       COPY_SCALAR_FIELD(aggsplit);
-       COPY_SCALAR_FIELD(aggno);
-       COPY_SCALAR_FIELD(aggtransno);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyGroupingFunc
- */
-static GroupingFunc *
-_copyGroupingFunc(const GroupingFunc *from)
-{
-       GroupingFunc *newnode = makeNode(GroupingFunc);
-
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(refs);
-       COPY_NODE_FIELD(cols);
-       COPY_SCALAR_FIELD(agglevelsup);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyWindowFunc
- */
-static WindowFunc *
-_copyWindowFunc(const WindowFunc *from)
-{
-       WindowFunc *newnode = makeNode(WindowFunc);
-
-       COPY_SCALAR_FIELD(winfnoid);
-       COPY_SCALAR_FIELD(wintype);
-       COPY_SCALAR_FIELD(wincollid);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(aggfilter);
-       COPY_SCALAR_FIELD(winref);
-       COPY_SCALAR_FIELD(winstar);
-       COPY_SCALAR_FIELD(winagg);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copySubscriptingRef
- */
-static SubscriptingRef *
-_copySubscriptingRef(const SubscriptingRef *from)
-{
-       SubscriptingRef *newnode = makeNode(SubscriptingRef);
-
-       COPY_SCALAR_FIELD(refcontainertype);
-       COPY_SCALAR_FIELD(refelemtype);
-       COPY_SCALAR_FIELD(refrestype);
-       COPY_SCALAR_FIELD(reftypmod);
-       COPY_SCALAR_FIELD(refcollid);
-       COPY_NODE_FIELD(refupperindexpr);
-       COPY_NODE_FIELD(reflowerindexpr);
-       COPY_NODE_FIELD(refexpr);
-       COPY_NODE_FIELD(refassgnexpr);
-
-       return newnode;
-}
-
-/*
- * _copyFuncExpr
- */
-static FuncExpr *
-_copyFuncExpr(const FuncExpr *from)
-{
-       FuncExpr   *newnode = makeNode(FuncExpr);
-
-       COPY_SCALAR_FIELD(funcid);
-       COPY_SCALAR_FIELD(funcresulttype);
-       COPY_SCALAR_FIELD(funcretset);
-       COPY_SCALAR_FIELD(funcvariadic);
-       COPY_SCALAR_FIELD(funcformat);
-       COPY_SCALAR_FIELD(funccollid);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyNamedArgExpr *
- */
-static NamedArgExpr *
-_copyNamedArgExpr(const NamedArgExpr *from)
-{
-       NamedArgExpr *newnode = makeNode(NamedArgExpr);
-
-       COPY_NODE_FIELD(arg);
-       COPY_STRING_FIELD(name);
-       COPY_SCALAR_FIELD(argnumber);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyOpExpr
- */
-static OpExpr *
-_copyOpExpr(const OpExpr *from)
-{
-       OpExpr     *newnode = makeNode(OpExpr);
-
-       COPY_SCALAR_FIELD(opno);
-       COPY_SCALAR_FIELD(opfuncid);
-       COPY_SCALAR_FIELD(opresulttype);
-       COPY_SCALAR_FIELD(opretset);
-       COPY_SCALAR_FIELD(opcollid);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyDistinctExpr (same as OpExpr)
- */
-static DistinctExpr *
-_copyDistinctExpr(const DistinctExpr *from)
-{
-       DistinctExpr *newnode = makeNode(DistinctExpr);
-
-       COPY_SCALAR_FIELD(opno);
-       COPY_SCALAR_FIELD(opfuncid);
-       COPY_SCALAR_FIELD(opresulttype);
-       COPY_SCALAR_FIELD(opretset);
-       COPY_SCALAR_FIELD(opcollid);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyNullIfExpr (same as OpExpr)
- */
-static NullIfExpr *
-_copyNullIfExpr(const NullIfExpr *from)
-{
-       NullIfExpr *newnode = makeNode(NullIfExpr);
-
-       COPY_SCALAR_FIELD(opno);
-       COPY_SCALAR_FIELD(opfuncid);
-       COPY_SCALAR_FIELD(opresulttype);
-       COPY_SCALAR_FIELD(opretset);
-       COPY_SCALAR_FIELD(opcollid);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyScalarArrayOpExpr
- */
-static ScalarArrayOpExpr *
-_copyScalarArrayOpExpr(const ScalarArrayOpExpr *from)
-{
-       ScalarArrayOpExpr *newnode = makeNode(ScalarArrayOpExpr);
-
-       COPY_SCALAR_FIELD(opno);
-       COPY_SCALAR_FIELD(opfuncid);
-       COPY_SCALAR_FIELD(hashfuncid);
-       COPY_SCALAR_FIELD(negfuncid);
-       COPY_SCALAR_FIELD(useOr);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyBoolExpr
- */
-static BoolExpr *
-_copyBoolExpr(const BoolExpr *from)
-{
-       BoolExpr   *newnode = makeNode(BoolExpr);
-
-       COPY_SCALAR_FIELD(boolop);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copySubLink
- */
-static SubLink *
-_copySubLink(const SubLink *from)
-{
-       SubLink    *newnode = makeNode(SubLink);
-
-       COPY_SCALAR_FIELD(subLinkType);
-       COPY_SCALAR_FIELD(subLinkId);
-       COPY_NODE_FIELD(testexpr);
-       COPY_NODE_FIELD(operName);
-       COPY_NODE_FIELD(subselect);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copySubPlan
- */
-static SubPlan *
-_copySubPlan(const SubPlan *from)
-{
-       SubPlan    *newnode = makeNode(SubPlan);
-
-       COPY_SCALAR_FIELD(subLinkType);
-       COPY_NODE_FIELD(testexpr);
-       COPY_NODE_FIELD(paramIds);
-       COPY_SCALAR_FIELD(plan_id);
-       COPY_STRING_FIELD(plan_name);
-       COPY_SCALAR_FIELD(firstColType);
-       COPY_SCALAR_FIELD(firstColTypmod);
-       COPY_SCALAR_FIELD(firstColCollation);
-       COPY_SCALAR_FIELD(useHashTable);
-       COPY_SCALAR_FIELD(unknownEqFalse);
-       COPY_SCALAR_FIELD(parallel_safe);
-       COPY_NODE_FIELD(setParam);
-       COPY_NODE_FIELD(parParam);
-       COPY_NODE_FIELD(args);
-       COPY_SCALAR_FIELD(startup_cost);
-       COPY_SCALAR_FIELD(per_call_cost);
-
-       return newnode;
-}
-
-/*
- * _copyAlternativeSubPlan
- */
-static AlternativeSubPlan *
-_copyAlternativeSubPlan(const AlternativeSubPlan *from)
-{
-       AlternativeSubPlan *newnode = makeNode(AlternativeSubPlan);
-
-       COPY_NODE_FIELD(subplans);
-
-       return newnode;
-}
-
-/*
- * _copyFieldSelect
- */
-static FieldSelect *
-_copyFieldSelect(const FieldSelect *from)
-{
-       FieldSelect *newnode = makeNode(FieldSelect);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(fieldnum);
-       COPY_SCALAR_FIELD(resulttype);
-       COPY_SCALAR_FIELD(resulttypmod);
-       COPY_SCALAR_FIELD(resultcollid);
-
-       return newnode;
-}
-
-/*
- * _copyFieldStore
- */
-static FieldStore *
-_copyFieldStore(const FieldStore *from)
-{
-       FieldStore *newnode = makeNode(FieldStore);
-
-       COPY_NODE_FIELD(arg);
-       COPY_NODE_FIELD(newvals);
-       COPY_NODE_FIELD(fieldnums);
-       COPY_SCALAR_FIELD(resulttype);
-
-       return newnode;
-}
-
-/*
- * _copyRelabelType
- */
-static RelabelType *
-_copyRelabelType(const RelabelType *from)
-{
-       RelabelType *newnode = makeNode(RelabelType);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(resulttype);
-       COPY_SCALAR_FIELD(resulttypmod);
-       COPY_SCALAR_FIELD(resultcollid);
-       COPY_SCALAR_FIELD(relabelformat);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCoerceViaIO
- */
-static CoerceViaIO *
-_copyCoerceViaIO(const CoerceViaIO *from)
-{
-       CoerceViaIO *newnode = makeNode(CoerceViaIO);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(resulttype);
-       COPY_SCALAR_FIELD(resultcollid);
-       COPY_SCALAR_FIELD(coerceformat);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyArrayCoerceExpr
- */
-static ArrayCoerceExpr *
-_copyArrayCoerceExpr(const ArrayCoerceExpr *from)
-{
-       ArrayCoerceExpr *newnode = makeNode(ArrayCoerceExpr);
-
-       COPY_NODE_FIELD(arg);
-       COPY_NODE_FIELD(elemexpr);
-       COPY_SCALAR_FIELD(resulttype);
-       COPY_SCALAR_FIELD(resulttypmod);
-       COPY_SCALAR_FIELD(resultcollid);
-       COPY_SCALAR_FIELD(coerceformat);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyConvertRowtypeExpr
- */
-static ConvertRowtypeExpr *
-_copyConvertRowtypeExpr(const ConvertRowtypeExpr *from)
-{
-       ConvertRowtypeExpr *newnode = makeNode(ConvertRowtypeExpr);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(resulttype);
-       COPY_SCALAR_FIELD(convertformat);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCollateExpr
- */
-static CollateExpr *
-_copyCollateExpr(const CollateExpr *from)
-{
-       CollateExpr *newnode = makeNode(CollateExpr);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(collOid);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCaseExpr
- */
-static CaseExpr *
-_copyCaseExpr(const CaseExpr *from)
-{
-       CaseExpr   *newnode = makeNode(CaseExpr);
-
-       COPY_SCALAR_FIELD(casetype);
-       COPY_SCALAR_FIELD(casecollid);
-       COPY_NODE_FIELD(arg);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(defresult);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCaseWhen
- */
-static CaseWhen *
-_copyCaseWhen(const CaseWhen *from)
-{
-       CaseWhen   *newnode = makeNode(CaseWhen);
-
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(result);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCaseTestExpr
- */
-static CaseTestExpr *
-_copyCaseTestExpr(const CaseTestExpr *from)
-{
-       CaseTestExpr *newnode = makeNode(CaseTestExpr);
-
-       COPY_SCALAR_FIELD(typeId);
-       COPY_SCALAR_FIELD(typeMod);
-       COPY_SCALAR_FIELD(collation);
-
-       return newnode;
-}
-
-/*
- * _copyArrayExpr
- */
-static ArrayExpr *
-_copyArrayExpr(const ArrayExpr *from)
-{
-       ArrayExpr  *newnode = makeNode(ArrayExpr);
-
-       COPY_SCALAR_FIELD(array_typeid);
-       COPY_SCALAR_FIELD(array_collid);
-       COPY_SCALAR_FIELD(element_typeid);
-       COPY_NODE_FIELD(elements);
-       COPY_SCALAR_FIELD(multidims);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyRowExpr
- */
-static RowExpr *
-_copyRowExpr(const RowExpr *from)
-{
-       RowExpr    *newnode = makeNode(RowExpr);
-
-       COPY_NODE_FIELD(args);
-       COPY_SCALAR_FIELD(row_typeid);
-       COPY_SCALAR_FIELD(row_format);
-       COPY_NODE_FIELD(colnames);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyRowCompareExpr
- */
-static RowCompareExpr *
-_copyRowCompareExpr(const RowCompareExpr *from)
-{
-       RowCompareExpr *newnode = makeNode(RowCompareExpr);
-
-       COPY_SCALAR_FIELD(rctype);
-       COPY_NODE_FIELD(opnos);
-       COPY_NODE_FIELD(opfamilies);
-       COPY_NODE_FIELD(inputcollids);
-       COPY_NODE_FIELD(largs);
-       COPY_NODE_FIELD(rargs);
-
-       return newnode;
-}
-
-/*
- * _copyCoalesceExpr
- */
-static CoalesceExpr *
-_copyCoalesceExpr(const CoalesceExpr *from)
-{
-       CoalesceExpr *newnode = makeNode(CoalesceExpr);
-
-       COPY_SCALAR_FIELD(coalescetype);
-       COPY_SCALAR_FIELD(coalescecollid);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyMinMaxExpr
- */
-static MinMaxExpr *
-_copyMinMaxExpr(const MinMaxExpr *from)
-{
-       MinMaxExpr *newnode = makeNode(MinMaxExpr);
-
-       COPY_SCALAR_FIELD(minmaxtype);
-       COPY_SCALAR_FIELD(minmaxcollid);
-       COPY_SCALAR_FIELD(inputcollid);
-       COPY_SCALAR_FIELD(op);
-       COPY_NODE_FIELD(args);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copySQLValueFunction
- */
-static SQLValueFunction *
-_copySQLValueFunction(const SQLValueFunction *from)
-{
-       SQLValueFunction *newnode = makeNode(SQLValueFunction);
-
-       COPY_SCALAR_FIELD(op);
-       COPY_SCALAR_FIELD(type);
-       COPY_SCALAR_FIELD(typmod);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyXmlExpr
- */
-static XmlExpr *
-_copyXmlExpr(const XmlExpr *from)
-{
-       XmlExpr    *newnode = makeNode(XmlExpr);
-
-       COPY_SCALAR_FIELD(op);
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(named_args);
-       COPY_NODE_FIELD(arg_names);
-       COPY_NODE_FIELD(args);
-       COPY_SCALAR_FIELD(xmloption);
-       COPY_SCALAR_FIELD(type);
-       COPY_SCALAR_FIELD(typmod);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyNullTest
- */
-static NullTest *
-_copyNullTest(const NullTest *from)
-{
-       NullTest   *newnode = makeNode(NullTest);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(nulltesttype);
-       COPY_SCALAR_FIELD(argisrow);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyBooleanTest
- */
-static BooleanTest *
-_copyBooleanTest(const BooleanTest *from)
-{
-       BooleanTest *newnode = makeNode(BooleanTest);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(booltesttype);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCoerceToDomain
- */
-static CoerceToDomain *
-_copyCoerceToDomain(const CoerceToDomain *from)
-{
-       CoerceToDomain *newnode = makeNode(CoerceToDomain);
-
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(resulttype);
-       COPY_SCALAR_FIELD(resulttypmod);
-       COPY_SCALAR_FIELD(resultcollid);
-       COPY_SCALAR_FIELD(coercionformat);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCoerceToDomainValue
- */
-static CoerceToDomainValue *
-_copyCoerceToDomainValue(const CoerceToDomainValue *from)
-{
-       CoerceToDomainValue *newnode = makeNode(CoerceToDomainValue);
-
-       COPY_SCALAR_FIELD(typeId);
-       COPY_SCALAR_FIELD(typeMod);
-       COPY_SCALAR_FIELD(collation);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copySetToDefault
- */
-static SetToDefault *
-_copySetToDefault(const SetToDefault *from)
-{
-       SetToDefault *newnode = makeNode(SetToDefault);
-
-       COPY_SCALAR_FIELD(typeId);
-       COPY_SCALAR_FIELD(typeMod);
-       COPY_SCALAR_FIELD(collation);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyCurrentOfExpr
- */
-static CurrentOfExpr *
-_copyCurrentOfExpr(const CurrentOfExpr *from)
-{
-       CurrentOfExpr *newnode = makeNode(CurrentOfExpr);
-
-       COPY_SCALAR_FIELD(cvarno);
-       COPY_STRING_FIELD(cursor_name);
-       COPY_SCALAR_FIELD(cursor_param);
-
-       return newnode;
-}
-
- /*
-  * _copyNextValueExpr
-  */
-static NextValueExpr *
-_copyNextValueExpr(const NextValueExpr *from)
-{
-       NextValueExpr *newnode = makeNode(NextValueExpr);
-
-       COPY_SCALAR_FIELD(seqid);
-       COPY_SCALAR_FIELD(typeId);
-
-       return newnode;
-}
-
-/*
- * _copyInferenceElem
- */
-static InferenceElem *
-_copyInferenceElem(const InferenceElem *from)
-{
-       InferenceElem *newnode = makeNode(InferenceElem);
-
-       COPY_NODE_FIELD(expr);
-       COPY_SCALAR_FIELD(infercollid);
-       COPY_SCALAR_FIELD(inferopclass);
-
-       return newnode;
-}
-
-/*
- * _copyTargetEntry
- */
-static TargetEntry *
-_copyTargetEntry(const TargetEntry *from)
-{
-       TargetEntry *newnode = makeNode(TargetEntry);
-
-       COPY_NODE_FIELD(expr);
-       COPY_SCALAR_FIELD(resno);
-       COPY_STRING_FIELD(resname);
-       COPY_SCALAR_FIELD(ressortgroupref);
-       COPY_SCALAR_FIELD(resorigtbl);
-       COPY_SCALAR_FIELD(resorigcol);
-       COPY_SCALAR_FIELD(resjunk);
-
-       return newnode;
-}
-
-/*
- * _copyRangeTblRef
- */
-static RangeTblRef *
-_copyRangeTblRef(const RangeTblRef *from)
-{
-       RangeTblRef *newnode = makeNode(RangeTblRef);
-
-       COPY_SCALAR_FIELD(rtindex);
-
-       return newnode;
-}
-
-/*
- * _copyJoinExpr
- */
-static JoinExpr *
-_copyJoinExpr(const JoinExpr *from)
-{
-       JoinExpr   *newnode = makeNode(JoinExpr);
-
-       COPY_SCALAR_FIELD(jointype);
-       COPY_SCALAR_FIELD(isNatural);
-       COPY_NODE_FIELD(larg);
-       COPY_NODE_FIELD(rarg);
-       COPY_NODE_FIELD(usingClause);
-       COPY_NODE_FIELD(join_using_alias);
-       COPY_NODE_FIELD(quals);
-       COPY_NODE_FIELD(alias);
-       COPY_SCALAR_FIELD(rtindex);
-
-       return newnode;
-}
-
-/*
- * _copyFromExpr
- */
-static FromExpr *
-_copyFromExpr(const FromExpr *from)
-{
-       FromExpr   *newnode = makeNode(FromExpr);
-
-       COPY_NODE_FIELD(fromlist);
-       COPY_NODE_FIELD(quals);
-
-       return newnode;
-}
-
-/*
- * _copyOnConflictExpr
- */
-static OnConflictExpr *
-_copyOnConflictExpr(const OnConflictExpr *from)
-{
-       OnConflictExpr *newnode = makeNode(OnConflictExpr);
-
-       COPY_SCALAR_FIELD(action);
-       COPY_NODE_FIELD(arbiterElems);
-       COPY_NODE_FIELD(arbiterWhere);
-       COPY_SCALAR_FIELD(constraint);
-       COPY_NODE_FIELD(onConflictSet);
-       COPY_NODE_FIELD(onConflictWhere);
-       COPY_SCALAR_FIELD(exclRelIndex);
-       COPY_NODE_FIELD(exclRelTlist);
-
-       return newnode;
-}
-
-
-/*
- * _copyJsonFormat
- */
-static JsonFormat *
-_copyJsonFormat(const JsonFormat *from)
-{
-       JsonFormat *newnode = makeNode(JsonFormat);
-
-       COPY_SCALAR_FIELD(format_type);
-       COPY_SCALAR_FIELD(encoding);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonReturning
- */
-static JsonReturning *
-_copyJsonReturning(const JsonReturning *from)
-{
-       JsonReturning *newnode = makeNode(JsonReturning);
-
-       COPY_NODE_FIELD(format);
-       COPY_SCALAR_FIELD(typid);
-       COPY_SCALAR_FIELD(typmod);
-
-       return newnode;
-}
-
-/*
- * _copyJsonValueExpr
- */
-static JsonValueExpr *
-_copyJsonValueExpr(const JsonValueExpr *from)
-{
-       JsonValueExpr *newnode = makeNode(JsonValueExpr);
-
-       COPY_NODE_FIELD(raw_expr);
-       COPY_NODE_FIELD(formatted_expr);
-       COPY_NODE_FIELD(format);
-
-       return newnode;
-}
-
-/*
- * _copyJsonParseExpr
- */
-static JsonParseExpr *
-_copyJsonParseExpr(const JsonParseExpr *from)
-{
-       JsonParseExpr *newnode = makeNode(JsonParseExpr);
-
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(output);
-       COPY_SCALAR_FIELD(unique_keys);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonScalarExpr
- */
-static JsonScalarExpr *
-_copyJsonScalarExpr(const JsonScalarExpr *from)
-{
-       JsonScalarExpr *newnode = makeNode(JsonScalarExpr);
-
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(output);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonSerializeExpr
- */
-static JsonSerializeExpr *
-_copyJsonSerializeExpr(const JsonSerializeExpr *from)
-{
-       JsonSerializeExpr *newnode = makeNode(JsonSerializeExpr);
-
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(output);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonConstructorExpr
- */
-static JsonConstructorExpr *
-_copyJsonConstructorExpr(const JsonConstructorExpr *from)
-{
-       JsonConstructorExpr *newnode = makeNode(JsonConstructorExpr);
-
-       COPY_SCALAR_FIELD(type);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(func);
-       COPY_NODE_FIELD(coercion);
-       COPY_NODE_FIELD(returning);
-       COPY_SCALAR_FIELD(absent_on_null);
-       COPY_SCALAR_FIELD(unique);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonKeyValue
- */
-static JsonKeyValue *
-_copyJsonKeyValue(const JsonKeyValue *from)
-{
-       JsonKeyValue *newnode = makeNode(JsonKeyValue);
-
-       COPY_NODE_FIELD(key);
-       COPY_NODE_FIELD(value);
-
-       return newnode;
-}
-
-/*
- * _copyJsonObjectConstructor
- */
-static JsonObjectConstructor *
-_copyJsonObjectConstructor(const JsonObjectConstructor *from)
-{
-       JsonObjectConstructor *newnode = makeNode(JsonObjectConstructor);
-
-       COPY_NODE_FIELD(exprs);
-       COPY_NODE_FIELD(output);
-       COPY_SCALAR_FIELD(absent_on_null);
-       COPY_SCALAR_FIELD(unique);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonAggConstructor
- */
-static JsonAggConstructor *
-_copyJsonAggConstructor(const JsonAggConstructor *from)
-{
-       JsonAggConstructor *newnode = makeNode(JsonAggConstructor);
-
-       COPY_NODE_FIELD(output);
-       COPY_NODE_FIELD(agg_filter);
-       COPY_NODE_FIELD(agg_order);
-       COPY_NODE_FIELD(over);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonObjectAgg
- */
-static JsonObjectAgg *
-_copyJsonObjectAgg(const JsonObjectAgg *from)
-{
-       JsonObjectAgg *newnode = makeNode(JsonObjectAgg);
-
-       COPY_NODE_FIELD(constructor);
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(absent_on_null);
-       COPY_SCALAR_FIELD(unique);
-
-       return newnode;
-}
-
-/*
- * _copyJsonOutput
- */
-static JsonOutput *
-_copyJsonOutput(const JsonOutput *from)
-{
-       JsonOutput *newnode = makeNode(JsonOutput);
-
-       COPY_NODE_FIELD(typeName);
-       COPY_NODE_FIELD(returning);
-
-       return newnode;
-}
-
-/*
- * _copyJsonArrayConstructor
- */
-static JsonArrayConstructor *
-_copyJsonArrayConstructor(const JsonArrayConstructor *from)
-{
-       JsonArrayConstructor *newnode = makeNode(JsonArrayConstructor);
-
-       COPY_NODE_FIELD(exprs);
-       COPY_NODE_FIELD(output);
-       COPY_SCALAR_FIELD(absent_on_null);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonArrayAgg
- */
-static JsonArrayAgg *
-_copyJsonArrayAgg(const JsonArrayAgg *from)
-{
-       JsonArrayAgg *newnode = makeNode(JsonArrayAgg);
-
-       COPY_NODE_FIELD(constructor);
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(absent_on_null);
-
-       return newnode;
-}
-
-/*
- * _copyJsonArrayQueryConstructor
- */
-static JsonArrayQueryConstructor *
-_copyJsonArrayQueryConstructor(const JsonArrayQueryConstructor *from)
-{
-       JsonArrayQueryConstructor *newnode = makeNode(JsonArrayQueryConstructor);
-
-       COPY_NODE_FIELD(query);
-       COPY_NODE_FIELD(output);
-       COPY_NODE_FIELD(format);
-       COPY_SCALAR_FIELD(absent_on_null);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonExpr
- */
-static JsonExpr *
-_copyJsonExpr(const JsonExpr *from)
-{
-       JsonExpr   *newnode = makeNode(JsonExpr);
-
-       COPY_SCALAR_FIELD(op);
-       COPY_NODE_FIELD(formatted_expr);
-       COPY_NODE_FIELD(result_coercion);
-       COPY_NODE_FIELD(format);
-       COPY_NODE_FIELD(path_spec);
-       COPY_NODE_FIELD(passing_names);
-       COPY_NODE_FIELD(passing_values);
-       COPY_NODE_FIELD(returning);
-       COPY_NODE_FIELD(on_empty);
-       COPY_NODE_FIELD(on_error);
-       COPY_NODE_FIELD(coercions);
-       COPY_SCALAR_FIELD(wrapper);
-       COPY_SCALAR_FIELD(omit_quotes);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonCoercion
- */
-static JsonCoercion *
-_copyJsonCoercion(const JsonCoercion *from)
-{
-       JsonCoercion *newnode = makeNode(JsonCoercion);
-
-       COPY_NODE_FIELD(expr);
-       COPY_SCALAR_FIELD(via_populate);
-       COPY_SCALAR_FIELD(via_io);
-       COPY_SCALAR_FIELD(collation);
-
-       return newnode;
-}
-
-/*
- * _copyJsonItemCoercions
- */
-static JsonItemCoercions *
-_copyJsonItemCoercions(const JsonItemCoercions *from)
-{
-       JsonItemCoercions *newnode = makeNode(JsonItemCoercions);
-
-       COPY_NODE_FIELD(null);
-       COPY_NODE_FIELD(string);
-       COPY_NODE_FIELD(numeric);
-       COPY_NODE_FIELD(boolean);
-       COPY_NODE_FIELD(date);
-       COPY_NODE_FIELD(time);
-       COPY_NODE_FIELD(timetz);
-       COPY_NODE_FIELD(timestamp);
-       COPY_NODE_FIELD(timestamptz);
-       COPY_NODE_FIELD(composite);
-
-       return newnode;
-}
-
-/*
- * _copyJsonFuncExpr
- */
-static JsonFuncExpr *
-_copyJsonFuncExpr(const JsonFuncExpr *from)
-{
-       JsonFuncExpr *newnode = makeNode(JsonFuncExpr);
-
-       COPY_SCALAR_FIELD(op);
-       COPY_NODE_FIELD(common);
-       COPY_NODE_FIELD(output);
-       COPY_NODE_FIELD(on_empty);
-       COPY_NODE_FIELD(on_error);
-       COPY_SCALAR_FIELD(wrapper);
-       COPY_SCALAR_FIELD(omit_quotes);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonIsPredicate
- */
-static JsonIsPredicate *
-_copyJsonIsPredicate(const JsonIsPredicate *from)
-{
-       JsonIsPredicate *newnode = makeNode(JsonIsPredicate);
-
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(format);
-       COPY_SCALAR_FIELD(item_type);
-       COPY_SCALAR_FIELD(unique_keys);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonBehavior
- */
-static JsonBehavior *
-_copyJsonBehavior(const JsonBehavior *from)
-{
-       JsonBehavior *newnode = makeNode(JsonBehavior);
-
-       COPY_SCALAR_FIELD(btype);
-       COPY_NODE_FIELD(default_expr);
-
-       return newnode;
-}
-
-/*
- * _copyJsonCommon
- */
-static JsonCommon *
-_copyJsonCommon(const JsonCommon *from)
-{
-       JsonCommon *newnode = makeNode(JsonCommon);
-
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(pathspec);
-       COPY_STRING_FIELD(pathname);
-       COPY_NODE_FIELD(passing);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonArgument
- */
-static JsonArgument *
-_copyJsonArgument(const JsonArgument *from)
-{
-       JsonArgument *newnode = makeNode(JsonArgument);
-
-       COPY_NODE_FIELD(val);
-       COPY_STRING_FIELD(name);
-
-       return newnode;
-}
-
-/*
- * _copyJsonTable
- */
-static JsonTable *
-_copyJsonTable(const JsonTable *from)
-{
-       JsonTable  *newnode = makeNode(JsonTable);
-
-       COPY_NODE_FIELD(common);
-       COPY_NODE_FIELD(columns);
-       COPY_NODE_FIELD(plan);
-       COPY_NODE_FIELD(on_error);
-       COPY_NODE_FIELD(alias);
-       COPY_SCALAR_FIELD(lateral);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonTableColumn
- */
-static JsonTableColumn *
-_copyJsonTableColumn(const JsonTableColumn *from)
-{
-       JsonTableColumn *newnode = makeNode(JsonTableColumn);
-
-       COPY_SCALAR_FIELD(coltype);
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(typeName);
-       COPY_STRING_FIELD(pathspec);
-       COPY_STRING_FIELD(pathname);
-       COPY_NODE_FIELD(format);
-       COPY_SCALAR_FIELD(wrapper);
-       COPY_SCALAR_FIELD(omit_quotes);
-       COPY_NODE_FIELD(columns);
-       COPY_NODE_FIELD(on_empty);
-       COPY_NODE_FIELD(on_error);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonTablePlan
- */
-static JsonTablePlan *
-_copyJsonTablePlan(const JsonTablePlan *from)
-{
-       JsonTablePlan *newnode = makeNode(JsonTablePlan);
-
-       COPY_SCALAR_FIELD(plan_type);
-       COPY_SCALAR_FIELD(join_type);
-       COPY_NODE_FIELD(plan1);
-       COPY_NODE_FIELD(plan2);
-       COPY_STRING_FIELD(pathname);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-/*
- * _copyJsonTableParent
- */
-static JsonTableParent *
-_copyJsonTableParent(const JsonTableParent *from)
-{
-       JsonTableParent *newnode = makeNode(JsonTableParent);
-
-       COPY_NODE_FIELD(path);
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(child);
-       COPY_SCALAR_FIELD(outerJoin);
-       COPY_SCALAR_FIELD(colMin);
-       COPY_SCALAR_FIELD(colMax);
-       COPY_SCALAR_FIELD(errorOnError);
-
-       return newnode;
-}
-
-/*
- * _copyJsonTableSibling
- */
-static JsonTableSibling *
-_copyJsonTableSibling(const JsonTableSibling *from)
-{
-       JsonTableSibling *newnode = makeNode(JsonTableSibling);
-
-       COPY_NODE_FIELD(larg);
-       COPY_NODE_FIELD(rarg);
-       COPY_SCALAR_FIELD(cross);
-
-       return newnode;
-}
-
-/* ****************************************************************
- *                                             pathnodes.h copy functions
- *
- * We don't support copying RelOptInfo, IndexOptInfo, or Path nodes.
- * There are some subsidiary structs that are useful to copy, though.
- * ****************************************************************
- */
-
-/*
- * _copyPathKey
- */
-static PathKey *
-_copyPathKey(const PathKey *from)
-{
-       PathKey    *newnode = makeNode(PathKey);
-
-       /* EquivalenceClasses are never moved, so just shallow-copy the pointer */
-       COPY_SCALAR_FIELD(pk_eclass);
-       COPY_SCALAR_FIELD(pk_opfamily);
-       COPY_SCALAR_FIELD(pk_strategy);
-       COPY_SCALAR_FIELD(pk_nulls_first);
-
-       return newnode;
-}
-
-/*
- * _copyRestrictInfo
- */
-static RestrictInfo *
-_copyRestrictInfo(const RestrictInfo *from)
-{
-       RestrictInfo *newnode = makeNode(RestrictInfo);
-
-       COPY_NODE_FIELD(clause);
-       COPY_SCALAR_FIELD(is_pushed_down);
-       COPY_SCALAR_FIELD(outerjoin_delayed);
-       COPY_SCALAR_FIELD(can_join);
-       COPY_SCALAR_FIELD(pseudoconstant);
-       COPY_SCALAR_FIELD(leakproof);
-       COPY_SCALAR_FIELD(has_volatile);
-       COPY_SCALAR_FIELD(security_level);
-       COPY_BITMAPSET_FIELD(clause_relids);
-       COPY_BITMAPSET_FIELD(required_relids);
-       COPY_BITMAPSET_FIELD(outer_relids);
-       COPY_BITMAPSET_FIELD(nullable_relids);
-       COPY_BITMAPSET_FIELD(left_relids);
-       COPY_BITMAPSET_FIELD(right_relids);
-       COPY_NODE_FIELD(orclause);
-       /* EquivalenceClasses are never copied, so shallow-copy the pointers */
-       COPY_SCALAR_FIELD(parent_ec);
-       COPY_SCALAR_FIELD(eval_cost);
-       COPY_SCALAR_FIELD(norm_selec);
-       COPY_SCALAR_FIELD(outer_selec);
-       COPY_NODE_FIELD(mergeopfamilies);
-       /* EquivalenceClasses are never copied, so shallow-copy the pointers */
-       COPY_SCALAR_FIELD(left_ec);
-       COPY_SCALAR_FIELD(right_ec);
-       COPY_SCALAR_FIELD(left_em);
-       COPY_SCALAR_FIELD(right_em);
-       /* MergeScanSelCache isn't a Node, so hard to copy; just reset cache */
-       newnode->scansel_cache = NIL;
-       COPY_SCALAR_FIELD(outer_is_left);
-       COPY_SCALAR_FIELD(hashjoinoperator);
-       COPY_SCALAR_FIELD(left_bucketsize);
-       COPY_SCALAR_FIELD(right_bucketsize);
-       COPY_SCALAR_FIELD(left_mcvfreq);
-       COPY_SCALAR_FIELD(right_mcvfreq);
-       COPY_SCALAR_FIELD(left_hasheqoperator);
-       COPY_SCALAR_FIELD(right_hasheqoperator);
-
-       return newnode;
-}
-
-/*
- * _copyPlaceHolderVar
- */
-static PlaceHolderVar *
-_copyPlaceHolderVar(const PlaceHolderVar *from)
-{
-       PlaceHolderVar *newnode = makeNode(PlaceHolderVar);
-
-       COPY_NODE_FIELD(phexpr);
-       COPY_BITMAPSET_FIELD(phrels);
-       COPY_SCALAR_FIELD(phid);
-       COPY_SCALAR_FIELD(phlevelsup);
-
-       return newnode;
-}
-
-/*
- * _copySpecialJoinInfo
- */
-static SpecialJoinInfo *
-_copySpecialJoinInfo(const SpecialJoinInfo *from)
-{
-       SpecialJoinInfo *newnode = makeNode(SpecialJoinInfo);
-
-       COPY_BITMAPSET_FIELD(min_lefthand);
-       COPY_BITMAPSET_FIELD(min_righthand);
-       COPY_BITMAPSET_FIELD(syn_lefthand);
-       COPY_BITMAPSET_FIELD(syn_righthand);
-       COPY_SCALAR_FIELD(jointype);
-       COPY_SCALAR_FIELD(lhs_strict);
-       COPY_SCALAR_FIELD(delay_upper_joins);
-       COPY_SCALAR_FIELD(semi_can_btree);
-       COPY_SCALAR_FIELD(semi_can_hash);
-       COPY_NODE_FIELD(semi_operators);
-       COPY_NODE_FIELD(semi_rhs_exprs);
-
-       return newnode;
-}
-
-/*
- * _copyAppendRelInfo
- */
-static AppendRelInfo *
-_copyAppendRelInfo(const AppendRelInfo *from)
-{
-       AppendRelInfo *newnode = makeNode(AppendRelInfo);
-
-       COPY_SCALAR_FIELD(parent_relid);
-       COPY_SCALAR_FIELD(child_relid);
-       COPY_SCALAR_FIELD(parent_reltype);
-       COPY_SCALAR_FIELD(child_reltype);
-       COPY_NODE_FIELD(translated_vars);
-       COPY_SCALAR_FIELD(num_child_cols);
-       COPY_POINTER_FIELD(parent_colnos, from->num_child_cols * sizeof(AttrNumber));
-       COPY_SCALAR_FIELD(parent_reloid);
-
-       return newnode;
-}
-
-/*
- * _copyPlaceHolderInfo
- */
-static PlaceHolderInfo *
-_copyPlaceHolderInfo(const PlaceHolderInfo *from)
-{
-       PlaceHolderInfo *newnode = makeNode(PlaceHolderInfo);
-
-       COPY_SCALAR_FIELD(phid);
-       COPY_NODE_FIELD(ph_var);
-       COPY_BITMAPSET_FIELD(ph_eval_at);
-       COPY_BITMAPSET_FIELD(ph_lateral);
-       COPY_BITMAPSET_FIELD(ph_needed);
-       COPY_SCALAR_FIELD(ph_width);
-
-       return newnode;
-}
-
-/* ****************************************************************
- *                                     parsenodes.h copy functions
- * ****************************************************************
- */
-
-static RangeTblEntry *
-_copyRangeTblEntry(const RangeTblEntry *from)
-{
-       RangeTblEntry *newnode = makeNode(RangeTblEntry);
-
-       COPY_SCALAR_FIELD(rtekind);
-       COPY_SCALAR_FIELD(relid);
-       COPY_SCALAR_FIELD(relkind);
-       COPY_SCALAR_FIELD(rellockmode);
-       COPY_NODE_FIELD(tablesample);
-       COPY_NODE_FIELD(subquery);
-       COPY_SCALAR_FIELD(security_barrier);
-       COPY_SCALAR_FIELD(jointype);
-       COPY_SCALAR_FIELD(joinmergedcols);
-       COPY_NODE_FIELD(joinaliasvars);
-       COPY_NODE_FIELD(joinleftcols);
-       COPY_NODE_FIELD(joinrightcols);
-       COPY_NODE_FIELD(join_using_alias);
-       COPY_NODE_FIELD(functions);
-       COPY_SCALAR_FIELD(funcordinality);
-       COPY_NODE_FIELD(tablefunc);
-       COPY_NODE_FIELD(values_lists);
-       COPY_STRING_FIELD(ctename);
-       COPY_SCALAR_FIELD(ctelevelsup);
-       COPY_SCALAR_FIELD(self_reference);
-       COPY_NODE_FIELD(coltypes);
-       COPY_NODE_FIELD(coltypmods);
-       COPY_NODE_FIELD(colcollations);
-       COPY_STRING_FIELD(enrname);
-       COPY_SCALAR_FIELD(enrtuples);
-       COPY_NODE_FIELD(alias);
-       COPY_NODE_FIELD(eref);
-       COPY_SCALAR_FIELD(lateral);
-       COPY_SCALAR_FIELD(inh);
-       COPY_SCALAR_FIELD(inFromCl);
-       COPY_SCALAR_FIELD(requiredPerms);
-       COPY_SCALAR_FIELD(checkAsUser);
-       COPY_BITMAPSET_FIELD(selectedCols);
-       COPY_BITMAPSET_FIELD(insertedCols);
-       COPY_BITMAPSET_FIELD(updatedCols);
-       COPY_BITMAPSET_FIELD(extraUpdatedCols);
-       COPY_NODE_FIELD(securityQuals);
-
-       return newnode;
-}
-
-static RangeTblFunction *
-_copyRangeTblFunction(const RangeTblFunction *from)
-{
-       RangeTblFunction *newnode = makeNode(RangeTblFunction);
-
-       COPY_NODE_FIELD(funcexpr);
-       COPY_SCALAR_FIELD(funccolcount);
-       COPY_NODE_FIELD(funccolnames);
-       COPY_NODE_FIELD(funccoltypes);
-       COPY_NODE_FIELD(funccoltypmods);
-       COPY_NODE_FIELD(funccolcollations);
-       COPY_BITMAPSET_FIELD(funcparams);
-
-       return newnode;
-}
-
-static TableSampleClause *
-_copyTableSampleClause(const TableSampleClause *from)
-{
-       TableSampleClause *newnode = makeNode(TableSampleClause);
-
-       COPY_SCALAR_FIELD(tsmhandler);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(repeatable);
-
-       return newnode;
-}
-
-static WithCheckOption *
-_copyWithCheckOption(const WithCheckOption *from)
-{
-       WithCheckOption *newnode = makeNode(WithCheckOption);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_STRING_FIELD(relname);
-       COPY_STRING_FIELD(polname);
-       COPY_NODE_FIELD(qual);
-       COPY_SCALAR_FIELD(cascaded);
-
-       return newnode;
-}
-
-static SortGroupClause *
-_copySortGroupClause(const SortGroupClause *from)
-{
-       SortGroupClause *newnode = makeNode(SortGroupClause);
-
-       COPY_SCALAR_FIELD(tleSortGroupRef);
-       COPY_SCALAR_FIELD(eqop);
-       COPY_SCALAR_FIELD(sortop);
-       COPY_SCALAR_FIELD(nulls_first);
-       COPY_SCALAR_FIELD(hashable);
-
-       return newnode;
-}
-
-static GroupingSet *
-_copyGroupingSet(const GroupingSet *from)
-{
-       GroupingSet *newnode = makeNode(GroupingSet);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_NODE_FIELD(content);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static WindowClause *
-_copyWindowClause(const WindowClause *from)
-{
-       WindowClause *newnode = makeNode(WindowClause);
-
-       COPY_STRING_FIELD(name);
-       COPY_STRING_FIELD(refname);
-       COPY_NODE_FIELD(partitionClause);
-       COPY_NODE_FIELD(orderClause);
-       COPY_SCALAR_FIELD(frameOptions);
-       COPY_NODE_FIELD(startOffset);
-       COPY_NODE_FIELD(endOffset);
-       COPY_NODE_FIELD(runCondition);
-       COPY_SCALAR_FIELD(startInRangeFunc);
-       COPY_SCALAR_FIELD(endInRangeFunc);
-       COPY_SCALAR_FIELD(inRangeColl);
-       COPY_SCALAR_FIELD(inRangeAsc);
-       COPY_SCALAR_FIELD(inRangeNullsFirst);
-       COPY_SCALAR_FIELD(winref);
-       COPY_SCALAR_FIELD(copiedOrder);
-
-       return newnode;
-}
-
-static RowMarkClause *
-_copyRowMarkClause(const RowMarkClause *from)
-{
-       RowMarkClause *newnode = makeNode(RowMarkClause);
-
-       COPY_SCALAR_FIELD(rti);
-       COPY_SCALAR_FIELD(strength);
-       COPY_SCALAR_FIELD(waitPolicy);
-       COPY_SCALAR_FIELD(pushedDown);
-
-       return newnode;
-}
-
-static WithClause *
-_copyWithClause(const WithClause *from)
-{
-       WithClause *newnode = makeNode(WithClause);
-
-       COPY_NODE_FIELD(ctes);
-       COPY_SCALAR_FIELD(recursive);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static InferClause *
-_copyInferClause(const InferClause *from)
-{
-       InferClause *newnode = makeNode(InferClause);
-
-       COPY_NODE_FIELD(indexElems);
-       COPY_NODE_FIELD(whereClause);
-       COPY_STRING_FIELD(conname);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static OnConflictClause *
-_copyOnConflictClause(const OnConflictClause *from)
-{
-       OnConflictClause *newnode = makeNode(OnConflictClause);
-
-       COPY_SCALAR_FIELD(action);
-       COPY_NODE_FIELD(infer);
-       COPY_NODE_FIELD(targetList);
-       COPY_NODE_FIELD(whereClause);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static CTESearchClause *
-_copyCTESearchClause(const CTESearchClause *from)
-{
-       CTESearchClause *newnode = makeNode(CTESearchClause);
-
-       COPY_NODE_FIELD(search_col_list);
-       COPY_SCALAR_FIELD(search_breadth_first);
-       COPY_STRING_FIELD(search_seq_column);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static CTECycleClause *
-_copyCTECycleClause(const CTECycleClause *from)
-{
-       CTECycleClause *newnode = makeNode(CTECycleClause);
-
-       COPY_NODE_FIELD(cycle_col_list);
-       COPY_STRING_FIELD(cycle_mark_column);
-       COPY_NODE_FIELD(cycle_mark_value);
-       COPY_NODE_FIELD(cycle_mark_default);
-       COPY_STRING_FIELD(cycle_path_column);
-       COPY_LOCATION_FIELD(location);
-       COPY_SCALAR_FIELD(cycle_mark_type);
-       COPY_SCALAR_FIELD(cycle_mark_typmod);
-       COPY_SCALAR_FIELD(cycle_mark_collation);
-       COPY_SCALAR_FIELD(cycle_mark_neop);
-
-       return newnode;
-}
-
-static CommonTableExpr *
-_copyCommonTableExpr(const CommonTableExpr *from)
-{
-       CommonTableExpr *newnode = makeNode(CommonTableExpr);
-
-       COPY_STRING_FIELD(ctename);
-       COPY_NODE_FIELD(aliascolnames);
-       COPY_SCALAR_FIELD(ctematerialized);
-       COPY_NODE_FIELD(ctequery);
-       COPY_NODE_FIELD(search_clause);
-       COPY_NODE_FIELD(cycle_clause);
-       COPY_LOCATION_FIELD(location);
-       COPY_SCALAR_FIELD(cterecursive);
-       COPY_SCALAR_FIELD(cterefcount);
-       COPY_NODE_FIELD(ctecolnames);
-       COPY_NODE_FIELD(ctecoltypes);
-       COPY_NODE_FIELD(ctecoltypmods);
-       COPY_NODE_FIELD(ctecolcollations);
-
-       return newnode;
-}
-
-static MergeWhenClause *
-_copyMergeWhenClause(const MergeWhenClause *from)
-{
-       MergeWhenClause *newnode = makeNode(MergeWhenClause);
-
-       COPY_SCALAR_FIELD(matched);
-       COPY_SCALAR_FIELD(commandType);
-       COPY_SCALAR_FIELD(override);
-       COPY_NODE_FIELD(condition);
-       COPY_NODE_FIELD(targetList);
-       COPY_NODE_FIELD(values);
-       return newnode;
-}
-
-static MergeAction *
-_copyMergeAction(const MergeAction *from)
-{
-       MergeAction *newnode = makeNode(MergeAction);
-
-       COPY_SCALAR_FIELD(matched);
-       COPY_SCALAR_FIELD(commandType);
-       COPY_SCALAR_FIELD(override);
-       COPY_NODE_FIELD(qual);
-       COPY_NODE_FIELD(targetList);
-       COPY_NODE_FIELD(updateColnos);
-
-       return newnode;
-}
-
-static A_Expr *
-_copyA_Expr(const A_Expr *from)
-{
-       A_Expr     *newnode = makeNode(A_Expr);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_NODE_FIELD(name);
-       COPY_NODE_FIELD(lexpr);
-       COPY_NODE_FIELD(rexpr);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static ColumnRef *
-_copyColumnRef(const ColumnRef *from)
-{
-       ColumnRef  *newnode = makeNode(ColumnRef);
-
-       COPY_NODE_FIELD(fields);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static ParamRef *
-_copyParamRef(const ParamRef *from)
-{
-       ParamRef   *newnode = makeNode(ParamRef);
-
-       COPY_SCALAR_FIELD(number);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-#endif                                                 /* OBSOLETE */
-
-static A_Const *
-_copyA_Const(const A_Const *from)
-{
-       A_Const    *newnode = makeNode(A_Const);
-
-       COPY_SCALAR_FIELD(isnull);
-       if (!from->isnull)
-       {
-               /* This part must duplicate other _copy*() functions. */
-               COPY_SCALAR_FIELD(val.node.type);
-               switch (nodeTag(&from->val))
-               {
-                       case T_Integer:
-                               COPY_SCALAR_FIELD(val.ival.ival);
-                               break;
-                       case T_Float:
-                               COPY_STRING_FIELD(val.fval.fval);
-                               break;
-                       case T_Boolean:
-                               COPY_SCALAR_FIELD(val.boolval.boolval);
-                               break;
-                       case T_String:
-                               COPY_STRING_FIELD(val.sval.sval);
-                               break;
-                       case T_BitString:
-                               COPY_STRING_FIELD(val.bsval.bsval);
-                               break;
-                       default:
-                               elog(ERROR, "unrecognized node type: %d",
-                                        (int) nodeTag(&from->val));
-                               break;
-               }
-       }
-
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-#ifdef OBSOLETE
-static FuncCall *
-_copyFuncCall(const FuncCall *from)
-{
-       FuncCall   *newnode = makeNode(FuncCall);
-
-       COPY_NODE_FIELD(funcname);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(agg_order);
-       COPY_NODE_FIELD(agg_filter);
-       COPY_NODE_FIELD(over);
-       COPY_SCALAR_FIELD(agg_within_group);
-       COPY_SCALAR_FIELD(agg_star);
-       COPY_SCALAR_FIELD(agg_distinct);
-       COPY_SCALAR_FIELD(func_variadic);
-       COPY_SCALAR_FIELD(funcformat);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static A_Star *
-_copyA_Star(const A_Star *from)
-{
-       A_Star     *newnode = makeNode(A_Star);
-
-       return newnode;
-}
-
-static A_Indices *
-_copyA_Indices(const A_Indices *from)
-{
-       A_Indices  *newnode = makeNode(A_Indices);
-
-       COPY_SCALAR_FIELD(is_slice);
-       COPY_NODE_FIELD(lidx);
-       COPY_NODE_FIELD(uidx);
-
-       return newnode;
-}
-
-static A_Indirection *
-_copyA_Indirection(const A_Indirection *from)
-{
-       A_Indirection *newnode = makeNode(A_Indirection);
-
-       COPY_NODE_FIELD(arg);
-       COPY_NODE_FIELD(indirection);
-
-       return newnode;
-}
-
-static A_ArrayExpr *
-_copyA_ArrayExpr(const A_ArrayExpr *from)
-{
-       A_ArrayExpr *newnode = makeNode(A_ArrayExpr);
-
-       COPY_NODE_FIELD(elements);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static ResTarget *
-_copyResTarget(const ResTarget *from)
-{
-       ResTarget  *newnode = makeNode(ResTarget);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(indirection);
-       COPY_NODE_FIELD(val);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static MultiAssignRef *
-_copyMultiAssignRef(const MultiAssignRef *from)
-{
-       MultiAssignRef *newnode = makeNode(MultiAssignRef);
-
-       COPY_NODE_FIELD(source);
-       COPY_SCALAR_FIELD(colno);
-       COPY_SCALAR_FIELD(ncolumns);
-
-       return newnode;
-}
-
-static TypeName *
-_copyTypeName(const TypeName *from)
-{
-       TypeName   *newnode = makeNode(TypeName);
-
-       COPY_NODE_FIELD(names);
-       COPY_SCALAR_FIELD(typeOid);
-       COPY_SCALAR_FIELD(setof);
-       COPY_SCALAR_FIELD(pct_type);
-       COPY_NODE_FIELD(typmods);
-       COPY_SCALAR_FIELD(typemod);
-       COPY_NODE_FIELD(arrayBounds);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static SortBy *
-_copySortBy(const SortBy *from)
-{
-       SortBy     *newnode = makeNode(SortBy);
-
-       COPY_NODE_FIELD(node);
-       COPY_SCALAR_FIELD(sortby_dir);
-       COPY_SCALAR_FIELD(sortby_nulls);
-       COPY_NODE_FIELD(useOp);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static WindowDef *
-_copyWindowDef(const WindowDef *from)
-{
-       WindowDef  *newnode = makeNode(WindowDef);
-
-       COPY_STRING_FIELD(name);
-       COPY_STRING_FIELD(refname);
-       COPY_NODE_FIELD(partitionClause);
-       COPY_NODE_FIELD(orderClause);
-       COPY_SCALAR_FIELD(frameOptions);
-       COPY_NODE_FIELD(startOffset);
-       COPY_NODE_FIELD(endOffset);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static RangeSubselect *
-_copyRangeSubselect(const RangeSubselect *from)
-{
-       RangeSubselect *newnode = makeNode(RangeSubselect);
-
-       COPY_SCALAR_FIELD(lateral);
-       COPY_NODE_FIELD(subquery);
-       COPY_NODE_FIELD(alias);
-
-       return newnode;
-}
-
-static RangeFunction *
-_copyRangeFunction(const RangeFunction *from)
-{
-       RangeFunction *newnode = makeNode(RangeFunction);
-
-       COPY_SCALAR_FIELD(lateral);
-       COPY_SCALAR_FIELD(ordinality);
-       COPY_SCALAR_FIELD(is_rowsfrom);
-       COPY_NODE_FIELD(functions);
-       COPY_NODE_FIELD(alias);
-       COPY_NODE_FIELD(coldeflist);
-
-       return newnode;
-}
-
-static RangeTableSample *
-_copyRangeTableSample(const RangeTableSample *from)
-{
-       RangeTableSample *newnode = makeNode(RangeTableSample);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(method);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(repeatable);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static RangeTableFunc *
-_copyRangeTableFunc(const RangeTableFunc *from)
-{
-       RangeTableFunc *newnode = makeNode(RangeTableFunc);
-
-       COPY_SCALAR_FIELD(lateral);
-       COPY_NODE_FIELD(docexpr);
-       COPY_NODE_FIELD(rowexpr);
-       COPY_NODE_FIELD(namespaces);
-       COPY_NODE_FIELD(columns);
-       COPY_NODE_FIELD(alias);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static RangeTableFuncCol *
-_copyRangeTableFuncCol(const RangeTableFuncCol *from)
-{
-       RangeTableFuncCol *newnode = makeNode(RangeTableFuncCol);
-
-       COPY_STRING_FIELD(colname);
-       COPY_NODE_FIELD(typeName);
-       COPY_SCALAR_FIELD(for_ordinality);
-       COPY_SCALAR_FIELD(is_not_null);
-       COPY_NODE_FIELD(colexpr);
-       COPY_NODE_FIELD(coldefexpr);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static TypeCast *
-_copyTypeCast(const TypeCast *from)
-{
-       TypeCast   *newnode = makeNode(TypeCast);
-
-       COPY_NODE_FIELD(arg);
-       COPY_NODE_FIELD(typeName);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static CollateClause *
-_copyCollateClause(const CollateClause *from)
-{
-       CollateClause *newnode = makeNode(CollateClause);
-
-       COPY_NODE_FIELD(arg);
-       COPY_NODE_FIELD(collname);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static IndexElem *
-_copyIndexElem(const IndexElem *from)
-{
-       IndexElem  *newnode = makeNode(IndexElem);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(expr);
-       COPY_STRING_FIELD(indexcolname);
-       COPY_NODE_FIELD(collation);
-       COPY_NODE_FIELD(opclass);
-       COPY_NODE_FIELD(opclassopts);
-       COPY_SCALAR_FIELD(ordering);
-       COPY_SCALAR_FIELD(nulls_ordering);
-
-       return newnode;
-}
-
-static StatsElem *
-_copyStatsElem(const StatsElem *from)
-{
-       StatsElem  *newnode = makeNode(StatsElem);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(expr);
-
-       return newnode;
-}
-
-static ColumnDef *
-_copyColumnDef(const ColumnDef *from)
-{
-       ColumnDef  *newnode = makeNode(ColumnDef);
-
-       COPY_STRING_FIELD(colname);
-       COPY_NODE_FIELD(typeName);
-       COPY_STRING_FIELD(compression);
-       COPY_SCALAR_FIELD(inhcount);
-       COPY_SCALAR_FIELD(is_local);
-       COPY_SCALAR_FIELD(is_not_null);
-       COPY_SCALAR_FIELD(is_from_type);
-       COPY_SCALAR_FIELD(storage);
-       COPY_NODE_FIELD(raw_default);
-       COPY_NODE_FIELD(cooked_default);
-       COPY_SCALAR_FIELD(identity);
-       COPY_NODE_FIELD(identitySequence);
-       COPY_SCALAR_FIELD(generated);
-       COPY_NODE_FIELD(collClause);
-       COPY_SCALAR_FIELD(collOid);
-       COPY_NODE_FIELD(constraints);
-       COPY_NODE_FIELD(fdwoptions);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static Constraint *
-_copyConstraint(const Constraint *from)
-{
-       Constraint *newnode = makeNode(Constraint);
-
-       COPY_SCALAR_FIELD(contype);
-       COPY_STRING_FIELD(conname);
-       COPY_SCALAR_FIELD(deferrable);
-       COPY_SCALAR_FIELD(initdeferred);
-       COPY_LOCATION_FIELD(location);
-       COPY_SCALAR_FIELD(is_no_inherit);
-       COPY_NODE_FIELD(raw_expr);
-       COPY_STRING_FIELD(cooked_expr);
-       COPY_SCALAR_FIELD(generated_when);
-       COPY_SCALAR_FIELD(nulls_not_distinct);
-       COPY_NODE_FIELD(keys);
-       COPY_NODE_FIELD(including);
-       COPY_NODE_FIELD(exclusions);
-       COPY_NODE_FIELD(options);
-       COPY_STRING_FIELD(indexname);
-       COPY_STRING_FIELD(indexspace);
-       COPY_SCALAR_FIELD(reset_default_tblspc);
-       COPY_STRING_FIELD(access_method);
-       COPY_NODE_FIELD(where_clause);
-       COPY_NODE_FIELD(pktable);
-       COPY_NODE_FIELD(fk_attrs);
-       COPY_NODE_FIELD(pk_attrs);
-       COPY_SCALAR_FIELD(fk_matchtype);
-       COPY_SCALAR_FIELD(fk_upd_action);
-       COPY_SCALAR_FIELD(fk_del_action);
-       COPY_NODE_FIELD(fk_del_set_cols);
-       COPY_NODE_FIELD(old_conpfeqop);
-       COPY_SCALAR_FIELD(old_pktable_oid);
-       COPY_SCALAR_FIELD(skip_validation);
-       COPY_SCALAR_FIELD(initially_valid);
-
-       return newnode;
-}
-
-static DefElem *
-_copyDefElem(const DefElem *from)
-{
-       DefElem    *newnode = makeNode(DefElem);
-
-       COPY_STRING_FIELD(defnamespace);
-       COPY_STRING_FIELD(defname);
-       COPY_NODE_FIELD(arg);
-       COPY_SCALAR_FIELD(defaction);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static LockingClause *
-_copyLockingClause(const LockingClause *from)
-{
-       LockingClause *newnode = makeNode(LockingClause);
-
-       COPY_NODE_FIELD(lockedRels);
-       COPY_SCALAR_FIELD(strength);
-       COPY_SCALAR_FIELD(waitPolicy);
-
-       return newnode;
-}
-
-static XmlSerialize *
-_copyXmlSerialize(const XmlSerialize *from)
-{
-       XmlSerialize *newnode = makeNode(XmlSerialize);
-
-       COPY_SCALAR_FIELD(xmloption);
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(typeName);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static RoleSpec *
-_copyRoleSpec(const RoleSpec *from)
-{
-       RoleSpec   *newnode = makeNode(RoleSpec);
-
-       COPY_SCALAR_FIELD(roletype);
-       COPY_STRING_FIELD(rolename);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static TriggerTransition *
-_copyTriggerTransition(const TriggerTransition *from)
-{
-       TriggerTransition *newnode = makeNode(TriggerTransition);
-
-       COPY_STRING_FIELD(name);
-       COPY_SCALAR_FIELD(isNew);
-       COPY_SCALAR_FIELD(isTable);
-
-       return newnode;
-}
-
-static Query *
-_copyQuery(const Query *from)
-{
-       Query      *newnode = makeNode(Query);
-
-       COPY_SCALAR_FIELD(commandType);
-       COPY_SCALAR_FIELD(querySource);
-       COPY_SCALAR_FIELD(queryId);
-       COPY_SCALAR_FIELD(canSetTag);
-       COPY_NODE_FIELD(utilityStmt);
-       COPY_SCALAR_FIELD(resultRelation);
-       COPY_SCALAR_FIELD(hasAggs);
-       COPY_SCALAR_FIELD(hasWindowFuncs);
-       COPY_SCALAR_FIELD(hasTargetSRFs);
-       COPY_SCALAR_FIELD(hasSubLinks);
-       COPY_SCALAR_FIELD(hasDistinctOn);
-       COPY_SCALAR_FIELD(hasRecursive);
-       COPY_SCALAR_FIELD(hasModifyingCTE);
-       COPY_SCALAR_FIELD(hasForUpdate);
-       COPY_SCALAR_FIELD(hasRowSecurity);
-       COPY_SCALAR_FIELD(isReturn);
-       COPY_NODE_FIELD(cteList);
-       COPY_NODE_FIELD(rtable);
-       COPY_NODE_FIELD(jointree);
-       COPY_NODE_FIELD(targetList);
-       COPY_SCALAR_FIELD(override);
-       COPY_NODE_FIELD(onConflict);
-       COPY_NODE_FIELD(returningList);
-       COPY_NODE_FIELD(groupClause);
-       COPY_SCALAR_FIELD(groupDistinct);
-       COPY_NODE_FIELD(groupingSets);
-       COPY_NODE_FIELD(havingQual);
-       COPY_NODE_FIELD(windowClause);
-       COPY_NODE_FIELD(distinctClause);
-       COPY_NODE_FIELD(sortClause);
-       COPY_NODE_FIELD(limitOffset);
-       COPY_NODE_FIELD(limitCount);
-       COPY_SCALAR_FIELD(limitOption);
-       COPY_NODE_FIELD(rowMarks);
-       COPY_NODE_FIELD(setOperations);
-       COPY_NODE_FIELD(constraintDeps);
-       COPY_NODE_FIELD(withCheckOptions);
-       COPY_NODE_FIELD(mergeActionList);
-       COPY_SCALAR_FIELD(mergeUseOuterJoin);
-       COPY_LOCATION_FIELD(stmt_location);
-       COPY_SCALAR_FIELD(stmt_len);
-
-       return newnode;
-}
-
-static RawStmt *
-_copyRawStmt(const RawStmt *from)
-{
-       RawStmt    *newnode = makeNode(RawStmt);
-
-       COPY_NODE_FIELD(stmt);
-       COPY_LOCATION_FIELD(stmt_location);
-       COPY_SCALAR_FIELD(stmt_len);
-
-       return newnode;
-}
-
-static InsertStmt *
-_copyInsertStmt(const InsertStmt *from)
-{
-       InsertStmt *newnode = makeNode(InsertStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(cols);
-       COPY_NODE_FIELD(selectStmt);
-       COPY_NODE_FIELD(onConflictClause);
-       COPY_NODE_FIELD(returningList);
-       COPY_NODE_FIELD(withClause);
-       COPY_SCALAR_FIELD(override);
-
-       return newnode;
-}
-
-static DeleteStmt *
-_copyDeleteStmt(const DeleteStmt *from)
-{
-       DeleteStmt *newnode = makeNode(DeleteStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(usingClause);
-       COPY_NODE_FIELD(whereClause);
-       COPY_NODE_FIELD(returningList);
-       COPY_NODE_FIELD(withClause);
-
-       return newnode;
-}
-
-static UpdateStmt *
-_copyUpdateStmt(const UpdateStmt *from)
-{
-       UpdateStmt *newnode = makeNode(UpdateStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(targetList);
-       COPY_NODE_FIELD(whereClause);
-       COPY_NODE_FIELD(fromClause);
-       COPY_NODE_FIELD(returningList);
-       COPY_NODE_FIELD(withClause);
-
-       return newnode;
-}
-
-static MergeStmt *
-_copyMergeStmt(const MergeStmt *from)
-{
-       MergeStmt  *newnode = makeNode(MergeStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(sourceRelation);
-       COPY_NODE_FIELD(joinCondition);
-       COPY_NODE_FIELD(mergeWhenClauses);
-       COPY_NODE_FIELD(withClause);
-
-       return newnode;
-}
-
-static SelectStmt *
-_copySelectStmt(const SelectStmt *from)
-{
-       SelectStmt *newnode = makeNode(SelectStmt);
-
-       COPY_NODE_FIELD(distinctClause);
-       COPY_NODE_FIELD(intoClause);
-       COPY_NODE_FIELD(targetList);
-       COPY_NODE_FIELD(fromClause);
-       COPY_NODE_FIELD(whereClause);
-       COPY_NODE_FIELD(groupClause);
-       COPY_SCALAR_FIELD(groupDistinct);
-       COPY_NODE_FIELD(havingClause);
-       COPY_NODE_FIELD(windowClause);
-       COPY_NODE_FIELD(valuesLists);
-       COPY_NODE_FIELD(sortClause);
-       COPY_NODE_FIELD(limitOffset);
-       COPY_NODE_FIELD(limitCount);
-       COPY_SCALAR_FIELD(limitOption);
-       COPY_NODE_FIELD(lockingClause);
-       COPY_NODE_FIELD(withClause);
-       COPY_SCALAR_FIELD(op);
-       COPY_SCALAR_FIELD(all);
-       COPY_NODE_FIELD(larg);
-       COPY_NODE_FIELD(rarg);
-
-       return newnode;
-}
-
-static SetOperationStmt *
-_copySetOperationStmt(const SetOperationStmt *from)
-{
-       SetOperationStmt *newnode = makeNode(SetOperationStmt);
-
-       COPY_SCALAR_FIELD(op);
-       COPY_SCALAR_FIELD(all);
-       COPY_NODE_FIELD(larg);
-       COPY_NODE_FIELD(rarg);
-       COPY_NODE_FIELD(colTypes);
-       COPY_NODE_FIELD(colTypmods);
-       COPY_NODE_FIELD(colCollations);
-       COPY_NODE_FIELD(groupClauses);
-
-       return newnode;
-}
-
-static ReturnStmt *
-_copyReturnStmt(const ReturnStmt *from)
-{
-       ReturnStmt *newnode = makeNode(ReturnStmt);
-
-       COPY_NODE_FIELD(returnval);
-
-       return newnode;
-}
-
-static PLAssignStmt *
-_copyPLAssignStmt(const PLAssignStmt *from)
-{
-       PLAssignStmt *newnode = makeNode(PLAssignStmt);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(indirection);
-       COPY_SCALAR_FIELD(nnames);
-       COPY_NODE_FIELD(val);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static AlterTableStmt *
-_copyAlterTableStmt(const AlterTableStmt *from)
-{
-       AlterTableStmt *newnode = makeNode(AlterTableStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(cmds);
-       COPY_SCALAR_FIELD(objtype);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static AlterTableCmd *
-_copyAlterTableCmd(const AlterTableCmd *from)
-{
-       AlterTableCmd *newnode = makeNode(AlterTableCmd);
-
-       COPY_SCALAR_FIELD(subtype);
-       COPY_STRING_FIELD(name);
-       COPY_SCALAR_FIELD(num);
-       COPY_NODE_FIELD(newowner);
-       COPY_NODE_FIELD(def);
-       COPY_SCALAR_FIELD(behavior);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static AlterCollationStmt *
-_copyAlterCollationStmt(const AlterCollationStmt *from)
-{
-       AlterCollationStmt *newnode = makeNode(AlterCollationStmt);
-
-       COPY_NODE_FIELD(collname);
-
-       return newnode;
-}
-
-static AlterDomainStmt *
-_copyAlterDomainStmt(const AlterDomainStmt *from)
-{
-       AlterDomainStmt *newnode = makeNode(AlterDomainStmt);
-
-       COPY_SCALAR_FIELD(subtype);
-       COPY_NODE_FIELD(typeName);
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(def);
-       COPY_SCALAR_FIELD(behavior);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static GrantStmt *
-_copyGrantStmt(const GrantStmt *from)
-{
-       GrantStmt  *newnode = makeNode(GrantStmt);
-
-       COPY_SCALAR_FIELD(is_grant);
-       COPY_SCALAR_FIELD(targtype);
-       COPY_SCALAR_FIELD(objtype);
-       COPY_NODE_FIELD(objects);
-       COPY_NODE_FIELD(privileges);
-       COPY_NODE_FIELD(grantees);
-       COPY_SCALAR_FIELD(grant_option);
-       COPY_NODE_FIELD(grantor);
-       COPY_SCALAR_FIELD(behavior);
-
-       return newnode;
-}
-
-static ObjectWithArgs *
-_copyObjectWithArgs(const ObjectWithArgs *from)
-{
-       ObjectWithArgs *newnode = makeNode(ObjectWithArgs);
-
-       COPY_NODE_FIELD(objname);
-       COPY_NODE_FIELD(objargs);
-       COPY_NODE_FIELD(objfuncargs);
-       COPY_SCALAR_FIELD(args_unspecified);
-
-       return newnode;
-}
-
-static AccessPriv *
-_copyAccessPriv(const AccessPriv *from)
-{
-       AccessPriv *newnode = makeNode(AccessPriv);
-
-       COPY_STRING_FIELD(priv_name);
-       COPY_NODE_FIELD(cols);
-
-       return newnode;
-}
-
-static GrantRoleStmt *
-_copyGrantRoleStmt(const GrantRoleStmt *from)
-{
-       GrantRoleStmt *newnode = makeNode(GrantRoleStmt);
-
-       COPY_NODE_FIELD(granted_roles);
-       COPY_NODE_FIELD(grantee_roles);
-       COPY_SCALAR_FIELD(is_grant);
-       COPY_SCALAR_FIELD(admin_opt);
-       COPY_NODE_FIELD(grantor);
-       COPY_SCALAR_FIELD(behavior);
-
-       return newnode;
-}
-
-static AlterDefaultPrivilegesStmt *
-_copyAlterDefaultPrivilegesStmt(const AlterDefaultPrivilegesStmt *from)
-{
-       AlterDefaultPrivilegesStmt *newnode = makeNode(AlterDefaultPrivilegesStmt);
-
-       COPY_NODE_FIELD(options);
-       COPY_NODE_FIELD(action);
-
-       return newnode;
-}
-
-static DeclareCursorStmt *
-_copyDeclareCursorStmt(const DeclareCursorStmt *from)
-{
-       DeclareCursorStmt *newnode = makeNode(DeclareCursorStmt);
-
-       COPY_STRING_FIELD(portalname);
-       COPY_SCALAR_FIELD(options);
-       COPY_NODE_FIELD(query);
-
-       return newnode;
-}
-
-static ClosePortalStmt *
-_copyClosePortalStmt(const ClosePortalStmt *from)
-{
-       ClosePortalStmt *newnode = makeNode(ClosePortalStmt);
-
-       COPY_STRING_FIELD(portalname);
-
-       return newnode;
-}
-
-static CallStmt *
-_copyCallStmt(const CallStmt *from)
-{
-       CallStmt   *newnode = makeNode(CallStmt);
-
-       COPY_NODE_FIELD(funccall);
-       COPY_NODE_FIELD(funcexpr);
-       COPY_NODE_FIELD(outargs);
-
-       return newnode;
-}
-
-static ClusterStmt *
-_copyClusterStmt(const ClusterStmt *from)
-{
-       ClusterStmt *newnode = makeNode(ClusterStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_STRING_FIELD(indexname);
-       COPY_NODE_FIELD(params);
-
-       return newnode;
-}
-
-static CopyStmt *
-_copyCopyStmt(const CopyStmt *from)
-{
-       CopyStmt   *newnode = makeNode(CopyStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(query);
-       COPY_NODE_FIELD(attlist);
-       COPY_SCALAR_FIELD(is_from);
-       COPY_SCALAR_FIELD(is_program);
-       COPY_STRING_FIELD(filename);
-       COPY_NODE_FIELD(options);
-       COPY_NODE_FIELD(whereClause);
-
-       return newnode;
-}
-
-/*
- * CopyCreateStmtFields
- *
- *             This function copies the fields of the CreateStmt node.  It is used by
- *             copy functions for classes which inherit from CreateStmt.
- */
-static void
-CopyCreateStmtFields(const CreateStmt *from, CreateStmt *newnode)
-{
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(tableElts);
-       COPY_NODE_FIELD(inhRelations);
-       COPY_NODE_FIELD(partspec);
-       COPY_NODE_FIELD(partbound);
-       COPY_NODE_FIELD(ofTypename);
-       COPY_NODE_FIELD(constraints);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(oncommit);
-       COPY_STRING_FIELD(tablespacename);
-       COPY_STRING_FIELD(accessMethod);
-       COPY_SCALAR_FIELD(if_not_exists);
-}
-
-static CreateStmt *
-_copyCreateStmt(const CreateStmt *from)
-{
-       CreateStmt *newnode = makeNode(CreateStmt);
-
-       CopyCreateStmtFields(from, newnode);
-
-       return newnode;
-}
-
-static TableLikeClause *
-_copyTableLikeClause(const TableLikeClause *from)
-{
-       TableLikeClause *newnode = makeNode(TableLikeClause);
-
-       COPY_NODE_FIELD(relation);
-       COPY_SCALAR_FIELD(options);
-       COPY_SCALAR_FIELD(relationOid);
-
-       return newnode;
-}
-
-static DefineStmt *
-_copyDefineStmt(const DefineStmt *from)
-{
-       DefineStmt *newnode = makeNode(DefineStmt);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_SCALAR_FIELD(oldstyle);
-       COPY_NODE_FIELD(defnames);
-       COPY_NODE_FIELD(args);
-       COPY_NODE_FIELD(definition);
-       COPY_SCALAR_FIELD(if_not_exists);
-       COPY_SCALAR_FIELD(replace);
-
-       return newnode;
-}
-
-static DropStmt *
-_copyDropStmt(const DropStmt *from)
-{
-       DropStmt   *newnode = makeNode(DropStmt);
-
-       COPY_NODE_FIELD(objects);
-       COPY_SCALAR_FIELD(removeType);
-       COPY_SCALAR_FIELD(behavior);
-       COPY_SCALAR_FIELD(missing_ok);
-       COPY_SCALAR_FIELD(concurrent);
-
-       return newnode;
-}
-
-static TruncateStmt *
-_copyTruncateStmt(const TruncateStmt *from)
-{
-       TruncateStmt *newnode = makeNode(TruncateStmt);
-
-       COPY_NODE_FIELD(relations);
-       COPY_SCALAR_FIELD(restart_seqs);
-       COPY_SCALAR_FIELD(behavior);
-
-       return newnode;
-}
-
-static CommentStmt *
-_copyCommentStmt(const CommentStmt *from)
-{
-       CommentStmt *newnode = makeNode(CommentStmt);
-
-       COPY_SCALAR_FIELD(objtype);
-       COPY_NODE_FIELD(object);
-       COPY_STRING_FIELD(comment);
-
-       return newnode;
-}
-
-static SecLabelStmt *
-_copySecLabelStmt(const SecLabelStmt *from)
-{
-       SecLabelStmt *newnode = makeNode(SecLabelStmt);
-
-       COPY_SCALAR_FIELD(objtype);
-       COPY_NODE_FIELD(object);
-       COPY_STRING_FIELD(provider);
-       COPY_STRING_FIELD(label);
-
-       return newnode;
-}
-
-static FetchStmt *
-_copyFetchStmt(const FetchStmt *from)
-{
-       FetchStmt  *newnode = makeNode(FetchStmt);
-
-       COPY_SCALAR_FIELD(direction);
-       COPY_SCALAR_FIELD(howMany);
-       COPY_STRING_FIELD(portalname);
-       COPY_SCALAR_FIELD(ismove);
-
-       return newnode;
-}
-
-static IndexStmt *
-_copyIndexStmt(const IndexStmt *from)
-{
-       IndexStmt  *newnode = makeNode(IndexStmt);
-
-       COPY_STRING_FIELD(idxname);
-       COPY_NODE_FIELD(relation);
-       COPY_STRING_FIELD(accessMethod);
-       COPY_STRING_FIELD(tableSpace);
-       COPY_NODE_FIELD(indexParams);
-       COPY_NODE_FIELD(indexIncludingParams);
-       COPY_NODE_FIELD(options);
-       COPY_NODE_FIELD(whereClause);
-       COPY_NODE_FIELD(excludeOpNames);
-       COPY_STRING_FIELD(idxcomment);
-       COPY_SCALAR_FIELD(indexOid);
-       COPY_SCALAR_FIELD(oldNumber);
-       COPY_SCALAR_FIELD(oldCreateSubid);
-       COPY_SCALAR_FIELD(oldFirstRelfilelocatorSubid);
-       COPY_SCALAR_FIELD(unique);
-       COPY_SCALAR_FIELD(nulls_not_distinct);
-       COPY_SCALAR_FIELD(primary);
-       COPY_SCALAR_FIELD(isconstraint);
-       COPY_SCALAR_FIELD(deferrable);
-       COPY_SCALAR_FIELD(initdeferred);
-       COPY_SCALAR_FIELD(transformed);
-       COPY_SCALAR_FIELD(concurrent);
-       COPY_SCALAR_FIELD(if_not_exists);
-       COPY_SCALAR_FIELD(reset_default_tblspc);
-
-       return newnode;
-}
-
-static CreateStatsStmt *
-_copyCreateStatsStmt(const CreateStatsStmt *from)
-{
-       CreateStatsStmt *newnode = makeNode(CreateStatsStmt);
-
-       COPY_NODE_FIELD(defnames);
-       COPY_NODE_FIELD(stat_types);
-       COPY_NODE_FIELD(exprs);
-       COPY_NODE_FIELD(relations);
-       COPY_STRING_FIELD(stxcomment);
-       COPY_SCALAR_FIELD(transformed);
-       COPY_SCALAR_FIELD(if_not_exists);
-
-       return newnode;
-}
-
-static AlterStatsStmt *
-_copyAlterStatsStmt(const AlterStatsStmt *from)
-{
-       AlterStatsStmt *newnode = makeNode(AlterStatsStmt);
-
-       COPY_NODE_FIELD(defnames);
-       COPY_SCALAR_FIELD(stxstattarget);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static CreateFunctionStmt *
-_copyCreateFunctionStmt(const CreateFunctionStmt *from)
-{
-       CreateFunctionStmt *newnode = makeNode(CreateFunctionStmt);
-
-       COPY_SCALAR_FIELD(is_procedure);
-       COPY_SCALAR_FIELD(replace);
-       COPY_NODE_FIELD(funcname);
-       COPY_NODE_FIELD(parameters);
-       COPY_NODE_FIELD(returnType);
-       COPY_NODE_FIELD(options);
-       COPY_NODE_FIELD(sql_body);
-
-       return newnode;
-}
-
-static FunctionParameter *
-_copyFunctionParameter(const FunctionParameter *from)
-{
-       FunctionParameter *newnode = makeNode(FunctionParameter);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(argType);
-       COPY_SCALAR_FIELD(mode);
-       COPY_NODE_FIELD(defexpr);
-
-       return newnode;
-}
-
-static AlterFunctionStmt *
-_copyAlterFunctionStmt(const AlterFunctionStmt *from)
-{
-       AlterFunctionStmt *newnode = makeNode(AlterFunctionStmt);
-
-       COPY_SCALAR_FIELD(objtype);
-       COPY_NODE_FIELD(func);
-       COPY_NODE_FIELD(actions);
-
-       return newnode;
-}
-
-static DoStmt *
-_copyDoStmt(const DoStmt *from)
-{
-       DoStmt     *newnode = makeNode(DoStmt);
-
-       COPY_NODE_FIELD(args);
-
-       return newnode;
-}
-
-static RenameStmt *
-_copyRenameStmt(const RenameStmt *from)
-{
-       RenameStmt *newnode = makeNode(RenameStmt);
-
-       COPY_SCALAR_FIELD(renameType);
-       COPY_SCALAR_FIELD(relationType);
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(object);
-       COPY_STRING_FIELD(subname);
-       COPY_STRING_FIELD(newname);
-       COPY_SCALAR_FIELD(behavior);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static AlterObjectDependsStmt *
-_copyAlterObjectDependsStmt(const AlterObjectDependsStmt *from)
-{
-       AlterObjectDependsStmt *newnode = makeNode(AlterObjectDependsStmt);
-
-       COPY_SCALAR_FIELD(objectType);
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(object);
-       COPY_NODE_FIELD(extname);
-       COPY_SCALAR_FIELD(remove);
-
-       return newnode;
-}
-
-static AlterObjectSchemaStmt *
-_copyAlterObjectSchemaStmt(const AlterObjectSchemaStmt *from)
-{
-       AlterObjectSchemaStmt *newnode = makeNode(AlterObjectSchemaStmt);
-
-       COPY_SCALAR_FIELD(objectType);
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(object);
-       COPY_STRING_FIELD(newschema);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static AlterOwnerStmt *
-_copyAlterOwnerStmt(const AlterOwnerStmt *from)
-{
-       AlterOwnerStmt *newnode = makeNode(AlterOwnerStmt);
-
-       COPY_SCALAR_FIELD(objectType);
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(object);
-       COPY_NODE_FIELD(newowner);
-
-       return newnode;
-}
-
-static AlterOperatorStmt *
-_copyAlterOperatorStmt(const AlterOperatorStmt *from)
-{
-       AlterOperatorStmt *newnode = makeNode(AlterOperatorStmt);
-
-       COPY_NODE_FIELD(opername);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterTypeStmt *
-_copyAlterTypeStmt(const AlterTypeStmt *from)
-{
-       AlterTypeStmt *newnode = makeNode(AlterTypeStmt);
-
-       COPY_NODE_FIELD(typeName);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static RuleStmt *
-_copyRuleStmt(const RuleStmt *from)
-{
-       RuleStmt   *newnode = makeNode(RuleStmt);
-
-       COPY_NODE_FIELD(relation);
-       COPY_STRING_FIELD(rulename);
-       COPY_NODE_FIELD(whereClause);
-       COPY_SCALAR_FIELD(event);
-       COPY_SCALAR_FIELD(instead);
-       COPY_NODE_FIELD(actions);
-       COPY_SCALAR_FIELD(replace);
-
-       return newnode;
-}
-
-static NotifyStmt *
-_copyNotifyStmt(const NotifyStmt *from)
-{
-       NotifyStmt *newnode = makeNode(NotifyStmt);
-
-       COPY_STRING_FIELD(conditionname);
-       COPY_STRING_FIELD(payload);
-
-       return newnode;
-}
-
-static ListenStmt *
-_copyListenStmt(const ListenStmt *from)
-{
-       ListenStmt *newnode = makeNode(ListenStmt);
-
-       COPY_STRING_FIELD(conditionname);
-
-       return newnode;
-}
-
-static UnlistenStmt *
-_copyUnlistenStmt(const UnlistenStmt *from)
-{
-       UnlistenStmt *newnode = makeNode(UnlistenStmt);
-
-       COPY_STRING_FIELD(conditionname);
-
-       return newnode;
-}
-
-static TransactionStmt *
-_copyTransactionStmt(const TransactionStmt *from)
-{
-       TransactionStmt *newnode = makeNode(TransactionStmt);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_NODE_FIELD(options);
-       COPY_STRING_FIELD(savepoint_name);
-       COPY_STRING_FIELD(gid);
-       COPY_SCALAR_FIELD(chain);
-
-       return newnode;
-}
-
-static CompositeTypeStmt *
-_copyCompositeTypeStmt(const CompositeTypeStmt *from)
-{
-       CompositeTypeStmt *newnode = makeNode(CompositeTypeStmt);
-
-       COPY_NODE_FIELD(typevar);
-       COPY_NODE_FIELD(coldeflist);
-
-       return newnode;
-}
-
-static CreateEnumStmt *
-_copyCreateEnumStmt(const CreateEnumStmt *from)
-{
-       CreateEnumStmt *newnode = makeNode(CreateEnumStmt);
-
-       COPY_NODE_FIELD(typeName);
-       COPY_NODE_FIELD(vals);
-
-       return newnode;
-}
-
-static CreateRangeStmt *
-_copyCreateRangeStmt(const CreateRangeStmt *from)
-{
-       CreateRangeStmt *newnode = makeNode(CreateRangeStmt);
-
-       COPY_NODE_FIELD(typeName);
-       COPY_NODE_FIELD(params);
-
-       return newnode;
-}
-
-static AlterEnumStmt *
-_copyAlterEnumStmt(const AlterEnumStmt *from)
-{
-       AlterEnumStmt *newnode = makeNode(AlterEnumStmt);
-
-       COPY_NODE_FIELD(typeName);
-       COPY_STRING_FIELD(oldVal);
-       COPY_STRING_FIELD(newVal);
-       COPY_STRING_FIELD(newValNeighbor);
-       COPY_SCALAR_FIELD(newValIsAfter);
-       COPY_SCALAR_FIELD(skipIfNewValExists);
-
-       return newnode;
-}
-
-static ViewStmt *
-_copyViewStmt(const ViewStmt *from)
-{
-       ViewStmt   *newnode = makeNode(ViewStmt);
-
-       COPY_NODE_FIELD(view);
-       COPY_NODE_FIELD(aliases);
-       COPY_NODE_FIELD(query);
-       COPY_SCALAR_FIELD(replace);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(withCheckOption);
-
-       return newnode;
-}
-
-static LoadStmt *
-_copyLoadStmt(const LoadStmt *from)
-{
-       LoadStmt   *newnode = makeNode(LoadStmt);
-
-       COPY_STRING_FIELD(filename);
-
-       return newnode;
-}
-
-static CreateDomainStmt *
-_copyCreateDomainStmt(const CreateDomainStmt *from)
-{
-       CreateDomainStmt *newnode = makeNode(CreateDomainStmt);
-
-       COPY_NODE_FIELD(domainname);
-       COPY_NODE_FIELD(typeName);
-       COPY_NODE_FIELD(collClause);
-       COPY_NODE_FIELD(constraints);
-
-       return newnode;
-}
-
-static CreateOpClassStmt *
-_copyCreateOpClassStmt(const CreateOpClassStmt *from)
-{
-       CreateOpClassStmt *newnode = makeNode(CreateOpClassStmt);
-
-       COPY_NODE_FIELD(opclassname);
-       COPY_NODE_FIELD(opfamilyname);
-       COPY_STRING_FIELD(amname);
-       COPY_NODE_FIELD(datatype);
-       COPY_NODE_FIELD(items);
-       COPY_SCALAR_FIELD(isDefault);
-
-       return newnode;
-}
-
-static CreateOpClassItem *
-_copyCreateOpClassItem(const CreateOpClassItem *from)
-{
-       CreateOpClassItem *newnode = makeNode(CreateOpClassItem);
-
-       COPY_SCALAR_FIELD(itemtype);
-       COPY_NODE_FIELD(name);
-       COPY_SCALAR_FIELD(number);
-       COPY_NODE_FIELD(order_family);
-       COPY_NODE_FIELD(class_args);
-       COPY_NODE_FIELD(storedtype);
-
-       return newnode;
-}
-
-static CreateOpFamilyStmt *
-_copyCreateOpFamilyStmt(const CreateOpFamilyStmt *from)
-{
-       CreateOpFamilyStmt *newnode = makeNode(CreateOpFamilyStmt);
-
-       COPY_NODE_FIELD(opfamilyname);
-       COPY_STRING_FIELD(amname);
-
-       return newnode;
-}
-
-static AlterOpFamilyStmt *
-_copyAlterOpFamilyStmt(const AlterOpFamilyStmt *from)
-{
-       AlterOpFamilyStmt *newnode = makeNode(AlterOpFamilyStmt);
-
-       COPY_NODE_FIELD(opfamilyname);
-       COPY_STRING_FIELD(amname);
-       COPY_SCALAR_FIELD(isDrop);
-       COPY_NODE_FIELD(items);
-
-       return newnode;
-}
-
-static CreatedbStmt *
-_copyCreatedbStmt(const CreatedbStmt *from)
-{
-       CreatedbStmt *newnode = makeNode(CreatedbStmt);
-
-       COPY_STRING_FIELD(dbname);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterDatabaseStmt *
-_copyAlterDatabaseStmt(const AlterDatabaseStmt *from)
-{
-       AlterDatabaseStmt *newnode = makeNode(AlterDatabaseStmt);
-
-       COPY_STRING_FIELD(dbname);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterDatabaseRefreshCollStmt *
-_copyAlterDatabaseRefreshCollStmt(const AlterDatabaseRefreshCollStmt *from)
-{
-       AlterDatabaseRefreshCollStmt *newnode = makeNode(AlterDatabaseRefreshCollStmt);
-
-       COPY_STRING_FIELD(dbname);
-
-       return newnode;
-}
-
-static AlterDatabaseSetStmt *
-_copyAlterDatabaseSetStmt(const AlterDatabaseSetStmt *from)
-{
-       AlterDatabaseSetStmt *newnode = makeNode(AlterDatabaseSetStmt);
-
-       COPY_STRING_FIELD(dbname);
-       COPY_NODE_FIELD(setstmt);
-
-       return newnode;
-}
-
-static DropdbStmt *
-_copyDropdbStmt(const DropdbStmt *from)
-{
-       DropdbStmt *newnode = makeNode(DropdbStmt);
-
-       COPY_STRING_FIELD(dbname);
-       COPY_SCALAR_FIELD(missing_ok);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static VacuumStmt *
-_copyVacuumStmt(const VacuumStmt *from)
-{
-       VacuumStmt *newnode = makeNode(VacuumStmt);
-
-       COPY_NODE_FIELD(options);
-       COPY_NODE_FIELD(rels);
-       COPY_SCALAR_FIELD(is_vacuumcmd);
-
-       return newnode;
-}
-
-static VacuumRelation *
-_copyVacuumRelation(const VacuumRelation *from)
-{
-       VacuumRelation *newnode = makeNode(VacuumRelation);
-
-       COPY_NODE_FIELD(relation);
-       COPY_SCALAR_FIELD(oid);
-       COPY_NODE_FIELD(va_cols);
-
-       return newnode;
-}
-
-static ExplainStmt *
-_copyExplainStmt(const ExplainStmt *from)
-{
-       ExplainStmt *newnode = makeNode(ExplainStmt);
-
-       COPY_NODE_FIELD(query);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static CreateTableAsStmt *
-_copyCreateTableAsStmt(const CreateTableAsStmt *from)
-{
-       CreateTableAsStmt *newnode = makeNode(CreateTableAsStmt);
-
-       COPY_NODE_FIELD(query);
-       COPY_NODE_FIELD(into);
-       COPY_SCALAR_FIELD(objtype);
-       COPY_SCALAR_FIELD(is_select_into);
-       COPY_SCALAR_FIELD(if_not_exists);
-
-       return newnode;
-}
-
-static RefreshMatViewStmt *
-_copyRefreshMatViewStmt(const RefreshMatViewStmt *from)
-{
-       RefreshMatViewStmt *newnode = makeNode(RefreshMatViewStmt);
-
-       COPY_SCALAR_FIELD(concurrent);
-       COPY_SCALAR_FIELD(skipData);
-       COPY_NODE_FIELD(relation);
-
-       return newnode;
-}
-
-static ReplicaIdentityStmt *
-_copyReplicaIdentityStmt(const ReplicaIdentityStmt *from)
-{
-       ReplicaIdentityStmt *newnode = makeNode(ReplicaIdentityStmt);
-
-       COPY_SCALAR_FIELD(identity_type);
-       COPY_STRING_FIELD(name);
-
-       return newnode;
-}
-
-static AlterSystemStmt *
-_copyAlterSystemStmt(const AlterSystemStmt *from)
-{
-       AlterSystemStmt *newnode = makeNode(AlterSystemStmt);
-
-       COPY_NODE_FIELD(setstmt);
-
-       return newnode;
-}
-
-static CreateSeqStmt *
-_copyCreateSeqStmt(const CreateSeqStmt *from)
-{
-       CreateSeqStmt *newnode = makeNode(CreateSeqStmt);
-
-       COPY_NODE_FIELD(sequence);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(ownerId);
-       COPY_SCALAR_FIELD(for_identity);
-       COPY_SCALAR_FIELD(if_not_exists);
-
-       return newnode;
-}
-
-static AlterSeqStmt *
-_copyAlterSeqStmt(const AlterSeqStmt *from)
-{
-       AlterSeqStmt *newnode = makeNode(AlterSeqStmt);
-
-       COPY_NODE_FIELD(sequence);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(for_identity);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static VariableSetStmt *
-_copyVariableSetStmt(const VariableSetStmt *from)
-{
-       VariableSetStmt *newnode = makeNode(VariableSetStmt);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(args);
-       COPY_SCALAR_FIELD(is_local);
-
-       return newnode;
-}
-
-static VariableShowStmt *
-_copyVariableShowStmt(const VariableShowStmt *from)
-{
-       VariableShowStmt *newnode = makeNode(VariableShowStmt);
-
-       COPY_STRING_FIELD(name);
-
-       return newnode;
-}
-
-static DiscardStmt *
-_copyDiscardStmt(const DiscardStmt *from)
-{
-       DiscardStmt *newnode = makeNode(DiscardStmt);
-
-       COPY_SCALAR_FIELD(target);
-
-       return newnode;
-}
-
-static CreateTableSpaceStmt *
-_copyCreateTableSpaceStmt(const CreateTableSpaceStmt *from)
-{
-       CreateTableSpaceStmt *newnode = makeNode(CreateTableSpaceStmt);
-
-       COPY_STRING_FIELD(tablespacename);
-       COPY_NODE_FIELD(owner);
-       COPY_STRING_FIELD(location);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static DropTableSpaceStmt *
-_copyDropTableSpaceStmt(const DropTableSpaceStmt *from)
-{
-       DropTableSpaceStmt *newnode = makeNode(DropTableSpaceStmt);
-
-       COPY_STRING_FIELD(tablespacename);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static AlterTableSpaceOptionsStmt *
-_copyAlterTableSpaceOptionsStmt(const AlterTableSpaceOptionsStmt *from)
-{
-       AlterTableSpaceOptionsStmt *newnode = makeNode(AlterTableSpaceOptionsStmt);
-
-       COPY_STRING_FIELD(tablespacename);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(isReset);
-
-       return newnode;
-}
-
-static AlterTableMoveAllStmt *
-_copyAlterTableMoveAllStmt(const AlterTableMoveAllStmt *from)
-{
-       AlterTableMoveAllStmt *newnode = makeNode(AlterTableMoveAllStmt);
-
-       COPY_STRING_FIELD(orig_tablespacename);
-       COPY_SCALAR_FIELD(objtype);
-       COPY_NODE_FIELD(roles);
-       COPY_STRING_FIELD(new_tablespacename);
-       COPY_SCALAR_FIELD(nowait);
-
-       return newnode;
-}
-
-static CreateExtensionStmt *
-_copyCreateExtensionStmt(const CreateExtensionStmt *from)
-{
-       CreateExtensionStmt *newnode = makeNode(CreateExtensionStmt);
-
-       COPY_STRING_FIELD(extname);
-       COPY_SCALAR_FIELD(if_not_exists);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterExtensionStmt *
-_copyAlterExtensionStmt(const AlterExtensionStmt *from)
-{
-       AlterExtensionStmt *newnode = makeNode(AlterExtensionStmt);
-
-       COPY_STRING_FIELD(extname);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterExtensionContentsStmt *
-_copyAlterExtensionContentsStmt(const AlterExtensionContentsStmt *from)
-{
-       AlterExtensionContentsStmt *newnode = makeNode(AlterExtensionContentsStmt);
-
-       COPY_STRING_FIELD(extname);
-       COPY_SCALAR_FIELD(action);
-       COPY_SCALAR_FIELD(objtype);
-       COPY_NODE_FIELD(object);
-
-       return newnode;
-}
-
-static CreateFdwStmt *
-_copyCreateFdwStmt(const CreateFdwStmt *from)
-{
-       CreateFdwStmt *newnode = makeNode(CreateFdwStmt);
-
-       COPY_STRING_FIELD(fdwname);
-       COPY_NODE_FIELD(func_options);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterFdwStmt *
-_copyAlterFdwStmt(const AlterFdwStmt *from)
-{
-       AlterFdwStmt *newnode = makeNode(AlterFdwStmt);
-
-       COPY_STRING_FIELD(fdwname);
-       COPY_NODE_FIELD(func_options);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static CreateForeignServerStmt *
-_copyCreateForeignServerStmt(const CreateForeignServerStmt *from)
-{
-       CreateForeignServerStmt *newnode = makeNode(CreateForeignServerStmt);
-
-       COPY_STRING_FIELD(servername);
-       COPY_STRING_FIELD(servertype);
-       COPY_STRING_FIELD(version);
-       COPY_STRING_FIELD(fdwname);
-       COPY_SCALAR_FIELD(if_not_exists);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterForeignServerStmt *
-_copyAlterForeignServerStmt(const AlterForeignServerStmt *from)
-{
-       AlterForeignServerStmt *newnode = makeNode(AlterForeignServerStmt);
-
-       COPY_STRING_FIELD(servername);
-       COPY_STRING_FIELD(version);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(has_version);
-
-       return newnode;
-}
-
-static CreateUserMappingStmt *
-_copyCreateUserMappingStmt(const CreateUserMappingStmt *from)
-{
-       CreateUserMappingStmt *newnode = makeNode(CreateUserMappingStmt);
-
-       COPY_NODE_FIELD(user);
-       COPY_STRING_FIELD(servername);
-       COPY_SCALAR_FIELD(if_not_exists);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterUserMappingStmt *
-_copyAlterUserMappingStmt(const AlterUserMappingStmt *from)
-{
-       AlterUserMappingStmt *newnode = makeNode(AlterUserMappingStmt);
-
-       COPY_NODE_FIELD(user);
-       COPY_STRING_FIELD(servername);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static DropUserMappingStmt *
-_copyDropUserMappingStmt(const DropUserMappingStmt *from)
-{
-       DropUserMappingStmt *newnode = makeNode(DropUserMappingStmt);
-
-       COPY_NODE_FIELD(user);
-       COPY_STRING_FIELD(servername);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static CreateForeignTableStmt *
-_copyCreateForeignTableStmt(const CreateForeignTableStmt *from)
-{
-       CreateForeignTableStmt *newnode = makeNode(CreateForeignTableStmt);
-
-       CopyCreateStmtFields((const CreateStmt *) from, (CreateStmt *) newnode);
-
-       COPY_STRING_FIELD(servername);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static ImportForeignSchemaStmt *
-_copyImportForeignSchemaStmt(const ImportForeignSchemaStmt *from)
-{
-       ImportForeignSchemaStmt *newnode = makeNode(ImportForeignSchemaStmt);
-
-       COPY_STRING_FIELD(server_name);
-       COPY_STRING_FIELD(remote_schema);
-       COPY_STRING_FIELD(local_schema);
-       COPY_SCALAR_FIELD(list_type);
-       COPY_NODE_FIELD(table_list);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static CreateTransformStmt *
-_copyCreateTransformStmt(const CreateTransformStmt *from)
-{
-       CreateTransformStmt *newnode = makeNode(CreateTransformStmt);
-
-       COPY_SCALAR_FIELD(replace);
-       COPY_NODE_FIELD(type_name);
-       COPY_STRING_FIELD(lang);
-       COPY_NODE_FIELD(fromsql);
-       COPY_NODE_FIELD(tosql);
-
-       return newnode;
-}
-
-static CreateAmStmt *
-_copyCreateAmStmt(const CreateAmStmt *from)
-{
-       CreateAmStmt *newnode = makeNode(CreateAmStmt);
-
-       COPY_STRING_FIELD(amname);
-       COPY_NODE_FIELD(handler_name);
-       COPY_SCALAR_FIELD(amtype);
-
-       return newnode;
-}
-
-static CreateTrigStmt *
-_copyCreateTrigStmt(const CreateTrigStmt *from)
-{
-       CreateTrigStmt *newnode = makeNode(CreateTrigStmt);
-
-       COPY_SCALAR_FIELD(replace);
-       COPY_SCALAR_FIELD(isconstraint);
-       COPY_STRING_FIELD(trigname);
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(funcname);
-       COPY_NODE_FIELD(args);
-       COPY_SCALAR_FIELD(row);
-       COPY_SCALAR_FIELD(timing);
-       COPY_SCALAR_FIELD(events);
-       COPY_NODE_FIELD(columns);
-       COPY_NODE_FIELD(whenClause);
-       COPY_NODE_FIELD(transitionRels);
-       COPY_SCALAR_FIELD(deferrable);
-       COPY_SCALAR_FIELD(initdeferred);
-       COPY_NODE_FIELD(constrrel);
-
-       return newnode;
-}
-
-static CreateEventTrigStmt *
-_copyCreateEventTrigStmt(const CreateEventTrigStmt *from)
-{
-       CreateEventTrigStmt *newnode = makeNode(CreateEventTrigStmt);
-
-       COPY_STRING_FIELD(trigname);
-       COPY_STRING_FIELD(eventname);
-       COPY_NODE_FIELD(whenclause);
-       COPY_NODE_FIELD(funcname);
-
-       return newnode;
-}
-
-static AlterEventTrigStmt *
-_copyAlterEventTrigStmt(const AlterEventTrigStmt *from)
-{
-       AlterEventTrigStmt *newnode = makeNode(AlterEventTrigStmt);
-
-       COPY_STRING_FIELD(trigname);
-       COPY_SCALAR_FIELD(tgenabled);
-
-       return newnode;
-}
-
-static CreatePLangStmt *
-_copyCreatePLangStmt(const CreatePLangStmt *from)
-{
-       CreatePLangStmt *newnode = makeNode(CreatePLangStmt);
-
-       COPY_SCALAR_FIELD(replace);
-       COPY_STRING_FIELD(plname);
-       COPY_NODE_FIELD(plhandler);
-       COPY_NODE_FIELD(plinline);
-       COPY_NODE_FIELD(plvalidator);
-       COPY_SCALAR_FIELD(pltrusted);
-
-       return newnode;
-}
-
-static CreateRoleStmt *
-_copyCreateRoleStmt(const CreateRoleStmt *from)
-{
-       CreateRoleStmt *newnode = makeNode(CreateRoleStmt);
-
-       COPY_SCALAR_FIELD(stmt_type);
-       COPY_STRING_FIELD(role);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterRoleStmt *
-_copyAlterRoleStmt(const AlterRoleStmt *from)
-{
-       AlterRoleStmt *newnode = makeNode(AlterRoleStmt);
-
-       COPY_NODE_FIELD(role);
-       COPY_NODE_FIELD(options);
-       COPY_SCALAR_FIELD(action);
-
-       return newnode;
-}
-
-static AlterRoleSetStmt *
-_copyAlterRoleSetStmt(const AlterRoleSetStmt *from)
-{
-       AlterRoleSetStmt *newnode = makeNode(AlterRoleSetStmt);
-
-       COPY_NODE_FIELD(role);
-       COPY_STRING_FIELD(database);
-       COPY_NODE_FIELD(setstmt);
-
-       return newnode;
-}
-
-static DropRoleStmt *
-_copyDropRoleStmt(const DropRoleStmt *from)
-{
-       DropRoleStmt *newnode = makeNode(DropRoleStmt);
-
-       COPY_NODE_FIELD(roles);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static LockStmt *
-_copyLockStmt(const LockStmt *from)
-{
-       LockStmt   *newnode = makeNode(LockStmt);
-
-       COPY_NODE_FIELD(relations);
-       COPY_SCALAR_FIELD(mode);
-       COPY_SCALAR_FIELD(nowait);
-
-       return newnode;
-}
-
-static ConstraintsSetStmt *
-_copyConstraintsSetStmt(const ConstraintsSetStmt *from)
-{
-       ConstraintsSetStmt *newnode = makeNode(ConstraintsSetStmt);
-
-       COPY_NODE_FIELD(constraints);
-       COPY_SCALAR_FIELD(deferred);
-
-       return newnode;
-}
-
-static ReindexStmt *
-_copyReindexStmt(const ReindexStmt *from)
-{
-       ReindexStmt *newnode = makeNode(ReindexStmt);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_NODE_FIELD(relation);
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(params);
-
-       return newnode;
-}
-
-static CreateSchemaStmt *
-_copyCreateSchemaStmt(const CreateSchemaStmt *from)
-{
-       CreateSchemaStmt *newnode = makeNode(CreateSchemaStmt);
-
-       COPY_STRING_FIELD(schemaname);
-       COPY_NODE_FIELD(authrole);
-       COPY_NODE_FIELD(schemaElts);
-       COPY_SCALAR_FIELD(if_not_exists);
-
-       return newnode;
-}
-
-static CreateConversionStmt *
-_copyCreateConversionStmt(const CreateConversionStmt *from)
-{
-       CreateConversionStmt *newnode = makeNode(CreateConversionStmt);
-
-       COPY_NODE_FIELD(conversion_name);
-       COPY_STRING_FIELD(for_encoding_name);
-       COPY_STRING_FIELD(to_encoding_name);
-       COPY_NODE_FIELD(func_name);
-       COPY_SCALAR_FIELD(def);
-
-       return newnode;
-}
-
-static CreateCastStmt *
-_copyCreateCastStmt(const CreateCastStmt *from)
-{
-       CreateCastStmt *newnode = makeNode(CreateCastStmt);
-
-       COPY_NODE_FIELD(sourcetype);
-       COPY_NODE_FIELD(targettype);
-       COPY_NODE_FIELD(func);
-       COPY_SCALAR_FIELD(context);
-       COPY_SCALAR_FIELD(inout);
-
-       return newnode;
-}
-
-static PrepareStmt *
-_copyPrepareStmt(const PrepareStmt *from)
-{
-       PrepareStmt *newnode = makeNode(PrepareStmt);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(argtypes);
-       COPY_NODE_FIELD(query);
-
-       return newnode;
-}
-
-static ExecuteStmt *
-_copyExecuteStmt(const ExecuteStmt *from)
-{
-       ExecuteStmt *newnode = makeNode(ExecuteStmt);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(params);
-
-       return newnode;
-}
-
-static DeallocateStmt *
-_copyDeallocateStmt(const DeallocateStmt *from)
-{
-       DeallocateStmt *newnode = makeNode(DeallocateStmt);
-
-       COPY_STRING_FIELD(name);
-
-       return newnode;
-}
-
-static DropOwnedStmt *
-_copyDropOwnedStmt(const DropOwnedStmt *from)
-{
-       DropOwnedStmt *newnode = makeNode(DropOwnedStmt);
-
-       COPY_NODE_FIELD(roles);
-       COPY_SCALAR_FIELD(behavior);
-
-       return newnode;
-}
-
-static ReassignOwnedStmt *
-_copyReassignOwnedStmt(const ReassignOwnedStmt *from)
-{
-       ReassignOwnedStmt *newnode = makeNode(ReassignOwnedStmt);
-
-       COPY_NODE_FIELD(roles);
-       COPY_NODE_FIELD(newrole);
-
-       return newnode;
-}
-
-static AlterTSDictionaryStmt *
-_copyAlterTSDictionaryStmt(const AlterTSDictionaryStmt *from)
-{
-       AlterTSDictionaryStmt *newnode = makeNode(AlterTSDictionaryStmt);
-
-       COPY_NODE_FIELD(dictname);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterTSConfigurationStmt *
-_copyAlterTSConfigurationStmt(const AlterTSConfigurationStmt *from)
-{
-       AlterTSConfigurationStmt *newnode = makeNode(AlterTSConfigurationStmt);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_NODE_FIELD(cfgname);
-       COPY_NODE_FIELD(tokentype);
-       COPY_NODE_FIELD(dicts);
-       COPY_SCALAR_FIELD(override);
-       COPY_SCALAR_FIELD(replace);
-       COPY_SCALAR_FIELD(missing_ok);
-
-       return newnode;
-}
-
-static CreatePolicyStmt *
-_copyCreatePolicyStmt(const CreatePolicyStmt *from)
-{
-       CreatePolicyStmt *newnode = makeNode(CreatePolicyStmt);
-
-       COPY_STRING_FIELD(policy_name);
-       COPY_NODE_FIELD(table);
-       COPY_STRING_FIELD(cmd_name);
-       COPY_SCALAR_FIELD(permissive);
-       COPY_NODE_FIELD(roles);
-       COPY_NODE_FIELD(qual);
-       COPY_NODE_FIELD(with_check);
-
-       return newnode;
-}
-
-static AlterPolicyStmt *
-_copyAlterPolicyStmt(const AlterPolicyStmt *from)
-{
-       AlterPolicyStmt *newnode = makeNode(AlterPolicyStmt);
-
-       COPY_STRING_FIELD(policy_name);
-       COPY_NODE_FIELD(table);
-       COPY_NODE_FIELD(roles);
-       COPY_NODE_FIELD(qual);
-       COPY_NODE_FIELD(with_check);
-
-       return newnode;
-}
-
-static PartitionElem *
-_copyPartitionElem(const PartitionElem *from)
-{
-       PartitionElem *newnode = makeNode(PartitionElem);
-
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(expr);
-       COPY_NODE_FIELD(collation);
-       COPY_NODE_FIELD(opclass);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static PartitionSpec *
-_copyPartitionSpec(const PartitionSpec *from)
-{
-       PartitionSpec *newnode = makeNode(PartitionSpec);
-
-       COPY_STRING_FIELD(strategy);
-       COPY_NODE_FIELD(partParams);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static PartitionBoundSpec *
-_copyPartitionBoundSpec(const PartitionBoundSpec *from)
-{
-       PartitionBoundSpec *newnode = makeNode(PartitionBoundSpec);
-
-       COPY_SCALAR_FIELD(strategy);
-       COPY_SCALAR_FIELD(is_default);
-       COPY_SCALAR_FIELD(modulus);
-       COPY_SCALAR_FIELD(remainder);
-       COPY_NODE_FIELD(listdatums);
-       COPY_NODE_FIELD(lowerdatums);
-       COPY_NODE_FIELD(upperdatums);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static PartitionRangeDatum *
-_copyPartitionRangeDatum(const PartitionRangeDatum *from)
-{
-       PartitionRangeDatum *newnode = makeNode(PartitionRangeDatum);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_NODE_FIELD(value);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static PartitionCmd *
-_copyPartitionCmd(const PartitionCmd *from)
-{
-       PartitionCmd *newnode = makeNode(PartitionCmd);
-
-       COPY_NODE_FIELD(name);
-       COPY_NODE_FIELD(bound);
-       COPY_SCALAR_FIELD(concurrent);
-
-       return newnode;
-}
-
-static PublicationObjSpec *
-_copyPublicationObject(const PublicationObjSpec *from)
-{
-       PublicationObjSpec *newnode = makeNode(PublicationObjSpec);
-
-       COPY_SCALAR_FIELD(pubobjtype);
-       COPY_STRING_FIELD(name);
-       COPY_NODE_FIELD(pubtable);
-       COPY_LOCATION_FIELD(location);
-
-       return newnode;
-}
-
-static PublicationTable *
-_copyPublicationTable(const PublicationTable *from)
-{
-       PublicationTable *newnode = makeNode(PublicationTable);
-
-       COPY_NODE_FIELD(relation);
-       COPY_NODE_FIELD(whereClause);
-       COPY_NODE_FIELD(columns);
-
-       return newnode;
-}
-
-static CreatePublicationStmt *
-_copyCreatePublicationStmt(const CreatePublicationStmt *from)
-{
-       CreatePublicationStmt *newnode = makeNode(CreatePublicationStmt);
-
-       COPY_STRING_FIELD(pubname);
-       COPY_NODE_FIELD(options);
-       COPY_NODE_FIELD(pubobjects);
-       COPY_SCALAR_FIELD(for_all_tables);
-
-       return newnode;
-}
-
-static AlterPublicationStmt *
-_copyAlterPublicationStmt(const AlterPublicationStmt *from)
-{
-       AlterPublicationStmt *newnode = makeNode(AlterPublicationStmt);
-
-       COPY_STRING_FIELD(pubname);
-       COPY_NODE_FIELD(options);
-       COPY_NODE_FIELD(pubobjects);
-       COPY_SCALAR_FIELD(for_all_tables);
-       COPY_SCALAR_FIELD(action);
-
-       return newnode;
-}
-
-static CreateSubscriptionStmt *
-_copyCreateSubscriptionStmt(const CreateSubscriptionStmt *from)
-{
-       CreateSubscriptionStmt *newnode = makeNode(CreateSubscriptionStmt);
-
-       COPY_STRING_FIELD(subname);
-       COPY_STRING_FIELD(conninfo);
-       COPY_NODE_FIELD(publication);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static AlterSubscriptionStmt *
-_copyAlterSubscriptionStmt(const AlterSubscriptionStmt *from)
-{
-       AlterSubscriptionStmt *newnode = makeNode(AlterSubscriptionStmt);
-
-       COPY_SCALAR_FIELD(kind);
-       COPY_STRING_FIELD(subname);
-       COPY_STRING_FIELD(conninfo);
-       COPY_NODE_FIELD(publication);
-       COPY_NODE_FIELD(options);
-
-       return newnode;
-}
-
-static DropSubscriptionStmt *
-_copyDropSubscriptionStmt(const DropSubscriptionStmt *from)
-{
-       DropSubscriptionStmt *newnode = makeNode(DropSubscriptionStmt);
-
-       COPY_STRING_FIELD(subname);
-       COPY_SCALAR_FIELD(missing_ok);
-       COPY_SCALAR_FIELD(behavior);
-
-       return newnode;
-}
-#endif                                                 /* OBSOLETE */
-
-/* ****************************************************************
- *                                     extensible.h copy functions
- * ****************************************************************
- */
-static ExtensibleNode *
-_copyExtensibleNode(const ExtensibleNode *from)
-{
-       ExtensibleNode *newnode;
-       const ExtensibleNodeMethods *methods;
-
-       methods = GetExtensibleNodeMethods(from->extnodename, false);
-       newnode = (ExtensibleNode *) newNode(methods->node_size,
-                                                                                T_ExtensibleNode);
-       COPY_STRING_FIELD(extnodename);
-
-       /* copy the private fields */
-       methods->nodeCopy(newnode, from);
-
-       return newnode;
-}
-
-#ifdef OBSOLETE
-/* ****************************************************************
- *                                     value.h copy functions
- * ****************************************************************
- */
-static Integer *
-_copyInteger(const Integer *from)
-{
-       Integer    *newnode = makeNode(Integer);
-
-       COPY_SCALAR_FIELD(ival);
-
-       return newnode;
-}
-
-static Float *
-_copyFloat(const Float *from)
-{
-       Float      *newnode = makeNode(Float);
-
-       COPY_STRING_FIELD(fval);
-
-       return newnode;
-}
-
-static Boolean *
-_copyBoolean(const Boolean *from)
-{
-       Boolean    *newnode = makeNode(Boolean);
-
-       COPY_SCALAR_FIELD(boolval);
-
-       return newnode;
-}
-
-static String *
-_copyString(const String *from)
-{
-       String     *newnode = makeNode(String);
-
-       COPY_STRING_FIELD(sval);
-
-       return newnode;
-}
-
-static BitString *
-_copyBitString(const BitString *from)
-{
-       BitString  *newnode = makeNode(BitString);
-
-       COPY_STRING_FIELD(bsval);
-
-       return newnode;
-}
-
-
-static ForeignKeyCacheInfo *
-_copyForeignKeyCacheInfo(const ForeignKeyCacheInfo *from)
-{
-       ForeignKeyCacheInfo *newnode = makeNode(ForeignKeyCacheInfo);
-
-       COPY_SCALAR_FIELD(conoid);
-       COPY_SCALAR_FIELD(conrelid);
-       COPY_SCALAR_FIELD(confrelid);
-       COPY_SCALAR_FIELD(nkeys);
-       COPY_ARRAY_FIELD(conkey);
-       COPY_ARRAY_FIELD(confkey);
-       COPY_ARRAY_FIELD(conpfeqop);
-
-       return newnode;
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * copyObjectImpl -- implementation of copyObject(); see nodes/nodes.h
- *
- * Create a copy of a Node tree or list.  This is a "deep" copy: all
- * substructure is copied too, recursively.
- */
-void *
-copyObjectImpl(const void *from)
-{
-       void       *retval;
-
-       if (from == NULL)
-               return NULL;
-
-       /* Guard against stack overflow due to overly complex expressions */
-       check_stack_depth();
-
-       switch (nodeTag(from))
-       {
-#include "copyfuncs.switch.c"
-#ifdef OBSOLETE
-                       /*
-                        * PLAN NODES
-                        */
-               case T_PlannedStmt:
-                       retval = _copyPlannedStmt(from);
-                       break;
-               case T_Result:
-                       retval = _copyResult(from);
-                       break;
-               case T_ProjectSet:
-                       retval = _copyProjectSet(from);
-                       break;
-               case T_ModifyTable:
-                       retval = _copyModifyTable(from);
-                       break;
-               case T_Append:
-                       retval = _copyAppend(from);
-                       break;
-               case T_MergeAppend:
-                       retval = _copyMergeAppend(from);
-                       break;
-               case T_RecursiveUnion:
-                       retval = _copyRecursiveUnion(from);
-                       break;
-               case T_BitmapAnd:
-                       retval = _copyBitmapAnd(from);
-                       break;
-               case T_BitmapOr:
-                       retval = _copyBitmapOr(from);
-                       break;
-               case T_Scan:
-                       retval = _copyScan(from);
-                       break;
-               case T_Gather:
-                       retval = _copyGather(from);
-                       break;
-               case T_GatherMerge:
-                       retval = _copyGatherMerge(from);
-                       break;
-               case T_SeqScan:
-                       retval = _copySeqScan(from);
-                       break;
-               case T_SampleScan:
-                       retval = _copySampleScan(from);
-                       break;
-               case T_IndexScan:
-                       retval = _copyIndexScan(from);
-                       break;
-               case T_IndexOnlyScan:
-                       retval = _copyIndexOnlyScan(from);
-                       break;
-               case T_BitmapIndexScan:
-                       retval = _copyBitmapIndexScan(from);
-                       break;
-               case T_BitmapHeapScan:
-                       retval = _copyBitmapHeapScan(from);
-                       break;
-               case T_TidScan:
-                       retval = _copyTidScan(from);
-                       break;
-               case T_TidRangeScan:
-                       retval = _copyTidRangeScan(from);
-                       break;
-               case T_SubqueryScan:
-                       retval = _copySubqueryScan(from);
-                       break;
-               case T_FunctionScan:
-                       retval = _copyFunctionScan(from);
-                       break;
-               case T_TableFuncScan:
-                       retval = _copyTableFuncScan(from);
-                       break;
-               case T_ValuesScan:
-                       retval = _copyValuesScan(from);
-                       break;
-               case T_CteScan:
-                       retval = _copyCteScan(from);
-                       break;
-               case T_NamedTuplestoreScan:
-                       retval = _copyNamedTuplestoreScan(from);
-                       break;
-               case T_WorkTableScan:
-                       retval = _copyWorkTableScan(from);
-                       break;
-               case T_ForeignScan:
-                       retval = _copyForeignScan(from);
-                       break;
-               case T_CustomScan:
-                       retval = _copyCustomScan(from);
-                       break;
-               case T_NestLoop:
-                       retval = _copyNestLoop(from);
-                       break;
-               case T_MergeJoin:
-                       retval = _copyMergeJoin(from);
-                       break;
-               case T_HashJoin:
-                       retval = _copyHashJoin(from);
-                       break;
-               case T_Material:
-                       retval = _copyMaterial(from);
-                       break;
-               case T_Memoize:
-                       retval = _copyMemoize(from);
-                       break;
-               case T_Sort:
-                       retval = _copySort(from);
-                       break;
-               case T_IncrementalSort:
-                       retval = _copyIncrementalSort(from);
-                       break;
-               case T_Group:
-                       retval = _copyGroup(from);
-                       break;
-               case T_Agg:
-                       retval = _copyAgg(from);
-                       break;
-               case T_WindowAgg:
-                       retval = _copyWindowAgg(from);
-                       break;
-               case T_Unique:
-                       retval = _copyUnique(from);
-                       break;
-               case T_Hash:
-                       retval = _copyHash(from);
-                       break;
-               case T_SetOp:
-                       retval = _copySetOp(from);
-                       break;
-               case T_LockRows:
-                       retval = _copyLockRows(from);
-                       break;
-               case T_Limit:
-                       retval = _copyLimit(from);
-                       break;
-               case T_NestLoopParam:
-                       retval = _copyNestLoopParam(from);
-                       break;
-               case T_PlanRowMark:
-                       retval = _copyPlanRowMark(from);
-                       break;
-               case T_PartitionPruneInfo:
-                       retval = _copyPartitionPruneInfo(from);
-                       break;
-               case T_PartitionedRelPruneInfo:
-                       retval = _copyPartitionedRelPruneInfo(from);
-                       break;
-               case T_PartitionPruneStepOp:
-                       retval = _copyPartitionPruneStepOp(from);
-                       break;
-               case T_PartitionPruneStepCombine:
-                       retval = _copyPartitionPruneStepCombine(from);
-                       break;
-               case T_PlanInvalItem:
-                       retval = _copyPlanInvalItem(from);
-                       break;
-
-                       /*
-                        * PRIMITIVE NODES
-                        */
-               case T_Alias:
-                       retval = _copyAlias(from);
-                       break;
-               case T_RangeVar:
-                       retval = _copyRangeVar(from);
-                       break;
-               case T_TableFunc:
-                       retval = _copyTableFunc(from);
-                       break;
-               case T_IntoClause:
-                       retval = _copyIntoClause(from);
-                       break;
-               case T_Var:
-                       retval = _copyVar(from);
-                       break;
-               case T_Const:
-                       retval = _copyConst(from);
-                       break;
-               case T_Param:
-                       retval = _copyParam(from);
-                       break;
-               case T_Aggref:
-                       retval = _copyAggref(from);
-                       break;
-               case T_GroupingFunc:
-                       retval = _copyGroupingFunc(from);
-                       break;
-               case T_WindowFunc:
-                       retval = _copyWindowFunc(from);
-                       break;
-               case T_SubscriptingRef:
-                       retval = _copySubscriptingRef(from);
-                       break;
-               case T_FuncExpr:
-                       retval = _copyFuncExpr(from);
-                       break;
-               case T_NamedArgExpr:
-                       retval = _copyNamedArgExpr(from);
-                       break;
-               case T_OpExpr:
-                       retval = _copyOpExpr(from);
-                       break;
-               case T_DistinctExpr:
-                       retval = _copyDistinctExpr(from);
-                       break;
-               case T_NullIfExpr:
-                       retval = _copyNullIfExpr(from);
-                       break;
-               case T_ScalarArrayOpExpr:
-                       retval = _copyScalarArrayOpExpr(from);
-                       break;
-               case T_BoolExpr:
-                       retval = _copyBoolExpr(from);
-                       break;
-               case T_SubLink:
-                       retval = _copySubLink(from);
-                       break;
-               case T_SubPlan:
-                       retval = _copySubPlan(from);
-                       break;
-               case T_AlternativeSubPlan:
-                       retval = _copyAlternativeSubPlan(from);
-                       break;
-               case T_FieldSelect:
-                       retval = _copyFieldSelect(from);
-                       break;
-               case T_FieldStore:
-                       retval = _copyFieldStore(from);
-                       break;
-               case T_RelabelType:
-                       retval = _copyRelabelType(from);
-                       break;
-               case T_CoerceViaIO:
-                       retval = _copyCoerceViaIO(from);
-                       break;
-               case T_ArrayCoerceExpr:
-                       retval = _copyArrayCoerceExpr(from);
-                       break;
-               case T_ConvertRowtypeExpr:
-                       retval = _copyConvertRowtypeExpr(from);
-                       break;
-               case T_CollateExpr:
-                       retval = _copyCollateExpr(from);
-                       break;
-               case T_CaseExpr:
-                       retval = _copyCaseExpr(from);
-                       break;
-               case T_CaseWhen:
-                       retval = _copyCaseWhen(from);
-                       break;
-               case T_CaseTestExpr:
-                       retval = _copyCaseTestExpr(from);
-                       break;
-               case T_ArrayExpr:
-                       retval = _copyArrayExpr(from);
-                       break;
-               case T_RowExpr:
-                       retval = _copyRowExpr(from);
-                       break;
-               case T_RowCompareExpr:
-                       retval = _copyRowCompareExpr(from);
-                       break;
-               case T_CoalesceExpr:
-                       retval = _copyCoalesceExpr(from);
-                       break;
-               case T_MinMaxExpr:
-                       retval = _copyMinMaxExpr(from);
-                       break;
-               case T_SQLValueFunction:
-                       retval = _copySQLValueFunction(from);
-                       break;
-               case T_XmlExpr:
-                       retval = _copyXmlExpr(from);
-                       break;
-               case T_NullTest:
-                       retval = _copyNullTest(from);
-                       break;
-               case T_BooleanTest:
-                       retval = _copyBooleanTest(from);
-                       break;
-               case T_CoerceToDomain:
-                       retval = _copyCoerceToDomain(from);
-                       break;
-               case T_CoerceToDomainValue:
-                       retval = _copyCoerceToDomainValue(from);
-                       break;
-               case T_SetToDefault:
-                       retval = _copySetToDefault(from);
-                       break;
-               case T_CurrentOfExpr:
-                       retval = _copyCurrentOfExpr(from);
-                       break;
-               case T_NextValueExpr:
-                       retval = _copyNextValueExpr(from);
-                       break;
-               case T_InferenceElem:
-                       retval = _copyInferenceElem(from);
-                       break;
-               case T_TargetEntry:
-                       retval = _copyTargetEntry(from);
-                       break;
-               case T_RangeTblRef:
-                       retval = _copyRangeTblRef(from);
-                       break;
-               case T_JoinExpr:
-                       retval = _copyJoinExpr(from);
-                       break;
-               case T_FromExpr:
-                       retval = _copyFromExpr(from);
-                       break;
-               case T_OnConflictExpr:
-                       retval = _copyOnConflictExpr(from);
-                       break;
-               case T_JsonFormat:
-                       retval = _copyJsonFormat(from);
-                       break;
-               case T_JsonReturning:
-                       retval = _copyJsonReturning(from);
-                       break;
-               case T_JsonValueExpr:
-                       retval = _copyJsonValueExpr(from);
-                       break;
-               case T_JsonParseExpr:
-                       retval = _copyJsonParseExpr(from);
-                       break;
-               case T_JsonScalarExpr:
-                       retval = _copyJsonScalarExpr(from);
-                       break;
-               case T_JsonSerializeExpr:
-                       retval = _copyJsonSerializeExpr(from);
-                       break;
-               case T_JsonKeyValue:
-                       retval = _copyJsonKeyValue(from);
-                       break;
-               case T_JsonConstructorExpr:
-                       retval = _copyJsonConstructorExpr(from);
-                       break;
-               case T_JsonObjectConstructor:
-                       retval = _copyJsonObjectConstructor(from);
-                       break;
-               case T_JsonAggConstructor:
-                       retval = _copyJsonAggConstructor(from);
-                       break;
-               case T_JsonObjectAgg:
-                       retval = _copyJsonObjectAgg(from);
-                       break;
-               case T_JsonOutput:
-                       retval = _copyJsonOutput(from);
-                       break;
-               case T_JsonArrayConstructor:
-                       retval = _copyJsonArrayConstructor(from);
-                       break;
-               case T_JsonArrayQueryConstructor:
-                       retval = _copyJsonArrayQueryConstructor(from);
-                       break;
-               case T_JsonArrayAgg:
-                       retval = _copyJsonArrayAgg(from);
-                       break;
-               case T_JsonIsPredicate:
-                       retval = _copyJsonIsPredicate(from);
-                       break;
-               case T_JsonFuncExpr:
-                       retval = _copyJsonFuncExpr(from);
-                       break;
-               case T_JsonExpr:
-                       retval = _copyJsonExpr(from);
-                       break;
-               case T_JsonCommon:
-                       retval = _copyJsonCommon(from);
-                       break;
-               case T_JsonBehavior:
-                       retval = _copyJsonBehavior(from);
-                       break;
-               case T_JsonArgument:
-                       retval = _copyJsonArgument(from);
-                       break;
-               case T_JsonCoercion:
-                       retval = _copyJsonCoercion(from);
-                       break;
-               case T_JsonItemCoercions:
-                       retval = _copyJsonItemCoercions(from);
-                       break;
-               case T_JsonTable:
-                       retval = _copyJsonTable(from);
-                       break;
-               case T_JsonTableColumn:
-                       retval = _copyJsonTableColumn(from);
-                       break;
-               case T_JsonTablePlan:
-                       retval = _copyJsonTablePlan(from);
-                       break;
-               case T_JsonTableParent:
-                       retval = _copyJsonTableParent(from);
-                       break;
-               case T_JsonTableSibling:
-                       retval = _copyJsonTableSibling(from);
-                       break;
-
-                       /*
-                        * RELATION NODES
-                        */
-               case T_PathKey:
-                       retval = _copyPathKey(from);
-                       break;
-               case T_RestrictInfo:
-                       retval = _copyRestrictInfo(from);
-                       break;
-               case T_PlaceHolderVar:
-                       retval = _copyPlaceHolderVar(from);
-                       break;
-               case T_SpecialJoinInfo:
-                       retval = _copySpecialJoinInfo(from);
-                       break;
-               case T_AppendRelInfo:
-                       retval = _copyAppendRelInfo(from);
-                       break;
-               case T_PlaceHolderInfo:
-                       retval = _copyPlaceHolderInfo(from);
-                       break;
-
-                       /*
-                        * VALUE NODES
-                        */
-               case T_Integer:
-                       retval = _copyInteger(from);
-                       break;
-               case T_Float:
-                       retval = _copyFloat(from);
-                       break;
-               case T_Boolean:
-                       retval = _copyBoolean(from);
-                       break;
-               case T_String:
-                       retval = _copyString(from);
-                       break;
-               case T_BitString:
-                       retval = _copyBitString(from);
-                       break;
-#endif                                                 /* OBSOLETE */
-
-                       /*
-                        * LIST NODES
-                        */
-               case T_List:
-                       retval = list_copy_deep(from);
-                       break;
+               case T_List:
+                       retval = list_copy_deep(from);
+                       break;
 
                        /*
                         * Lists of integers and OIDs don't need to be deep-copied, so we
@@ -5995,561 +195,6 @@ copyObjectImpl(const void *from)
                        retval = list_copy(from);
                        break;
 
-#ifdef OBSOLETE
-
-                       /*
-                        * EXTENSIBLE NODES
-                        */
-               case T_ExtensibleNode:
-                       retval = _copyExtensibleNode(from);
-                       break;
-
-                       /*
-                        * PARSE NODES
-                        */
-               case T_Query:
-                       retval = _copyQuery(from);
-                       break;
-               case T_RawStmt:
-                       retval = _copyRawStmt(from);
-                       break;
-               case T_InsertStmt:
-                       retval = _copyInsertStmt(from);
-                       break;
-               case T_DeleteStmt:
-                       retval = _copyDeleteStmt(from);
-                       break;
-               case T_UpdateStmt:
-                       retval = _copyUpdateStmt(from);
-                       break;
-               case T_MergeStmt:
-                       retval = _copyMergeStmt(from);
-                       break;
-               case T_SelectStmt:
-                       retval = _copySelectStmt(from);
-                       break;
-               case T_SetOperationStmt:
-                       retval = _copySetOperationStmt(from);
-                       break;
-               case T_ReturnStmt:
-                       retval = _copyReturnStmt(from);
-                       break;
-               case T_PLAssignStmt:
-                       retval = _copyPLAssignStmt(from);
-                       break;
-               case T_AlterTableStmt:
-                       retval = _copyAlterTableStmt(from);
-                       break;
-               case T_AlterTableCmd:
-                       retval = _copyAlterTableCmd(from);
-                       break;
-               case T_AlterCollationStmt:
-                       retval = _copyAlterCollationStmt(from);
-                       break;
-               case T_AlterDomainStmt:
-                       retval = _copyAlterDomainStmt(from);
-                       break;
-               case T_GrantStmt:
-                       retval = _copyGrantStmt(from);
-                       break;
-               case T_GrantRoleStmt:
-                       retval = _copyGrantRoleStmt(from);
-                       break;
-               case T_AlterDefaultPrivilegesStmt:
-                       retval = _copyAlterDefaultPrivilegesStmt(from);
-                       break;
-               case T_DeclareCursorStmt:
-                       retval = _copyDeclareCursorStmt(from);
-                       break;
-               case T_ClosePortalStmt:
-                       retval = _copyClosePortalStmt(from);
-                       break;
-               case T_CallStmt:
-                       retval = _copyCallStmt(from);
-                       break;
-               case T_ClusterStmt:
-                       retval = _copyClusterStmt(from);
-                       break;
-               case T_CopyStmt:
-                       retval = _copyCopyStmt(from);
-                       break;
-               case T_CreateStmt:
-                       retval = _copyCreateStmt(from);
-                       break;
-               case T_TableLikeClause:
-                       retval = _copyTableLikeClause(from);
-                       break;
-               case T_DefineStmt:
-                       retval = _copyDefineStmt(from);
-                       break;
-               case T_DropStmt:
-                       retval = _copyDropStmt(from);
-                       break;
-               case T_TruncateStmt:
-                       retval = _copyTruncateStmt(from);
-                       break;
-               case T_CommentStmt:
-                       retval = _copyCommentStmt(from);
-                       break;
-               case T_SecLabelStmt:
-                       retval = _copySecLabelStmt(from);
-                       break;
-               case T_FetchStmt:
-                       retval = _copyFetchStmt(from);
-                       break;
-               case T_IndexStmt:
-                       retval = _copyIndexStmt(from);
-                       break;
-               case T_CreateStatsStmt:
-                       retval = _copyCreateStatsStmt(from);
-                       break;
-               case T_AlterStatsStmt:
-                       retval = _copyAlterStatsStmt(from);
-                       break;
-               case T_CreateFunctionStmt:
-                       retval = _copyCreateFunctionStmt(from);
-                       break;
-               case T_FunctionParameter:
-                       retval = _copyFunctionParameter(from);
-                       break;
-               case T_AlterFunctionStmt:
-                       retval = _copyAlterFunctionStmt(from);
-                       break;
-               case T_DoStmt:
-                       retval = _copyDoStmt(from);
-                       break;
-               case T_RenameStmt:
-                       retval = _copyRenameStmt(from);
-                       break;
-               case T_AlterObjectDependsStmt:
-                       retval = _copyAlterObjectDependsStmt(from);
-                       break;
-               case T_AlterObjectSchemaStmt:
-                       retval = _copyAlterObjectSchemaStmt(from);
-                       break;
-               case T_AlterOwnerStmt:
-                       retval = _copyAlterOwnerStmt(from);
-                       break;
-               case T_AlterOperatorStmt:
-                       retval = _copyAlterOperatorStmt(from);
-                       break;
-               case T_AlterTypeStmt:
-                       retval = _copyAlterTypeStmt(from);
-                       break;
-               case T_RuleStmt:
-                       retval = _copyRuleStmt(from);
-                       break;
-               case T_NotifyStmt:
-                       retval = _copyNotifyStmt(from);
-                       break;
-               case T_ListenStmt:
-                       retval = _copyListenStmt(from);
-                       break;
-               case T_UnlistenStmt:
-                       retval = _copyUnlistenStmt(from);
-                       break;
-               case T_TransactionStmt:
-                       retval = _copyTransactionStmt(from);
-                       break;
-               case T_CompositeTypeStmt:
-                       retval = _copyCompositeTypeStmt(from);
-                       break;
-               case T_CreateEnumStmt:
-                       retval = _copyCreateEnumStmt(from);
-                       break;
-               case T_CreateRangeStmt:
-                       retval = _copyCreateRangeStmt(from);
-                       break;
-               case T_AlterEnumStmt:
-                       retval = _copyAlterEnumStmt(from);
-                       break;
-               case T_ViewStmt:
-                       retval = _copyViewStmt(from);
-                       break;
-               case T_LoadStmt:
-                       retval = _copyLoadStmt(from);
-                       break;
-               case T_CreateDomainStmt:
-                       retval = _copyCreateDomainStmt(from);
-                       break;
-               case T_CreateOpClassStmt:
-                       retval = _copyCreateOpClassStmt(from);
-                       break;
-               case T_CreateOpClassItem:
-                       retval = _copyCreateOpClassItem(from);
-                       break;
-               case T_CreateOpFamilyStmt:
-                       retval = _copyCreateOpFamilyStmt(from);
-                       break;
-               case T_AlterOpFamilyStmt:
-                       retval = _copyAlterOpFamilyStmt(from);
-                       break;
-               case T_CreatedbStmt:
-                       retval = _copyCreatedbStmt(from);
-                       break;
-               case T_AlterDatabaseStmt:
-                       retval = _copyAlterDatabaseStmt(from);
-                       break;
-               case T_AlterDatabaseRefreshCollStmt:
-                       retval = _copyAlterDatabaseRefreshCollStmt(from);
-                       break;
-               case T_AlterDatabaseSetStmt:
-                       retval = _copyAlterDatabaseSetStmt(from);
-                       break;
-               case T_DropdbStmt:
-                       retval = _copyDropdbStmt(from);
-                       break;
-               case T_VacuumStmt:
-                       retval = _copyVacuumStmt(from);
-                       break;
-               case T_VacuumRelation:
-                       retval = _copyVacuumRelation(from);
-                       break;
-               case T_ExplainStmt:
-                       retval = _copyExplainStmt(from);
-                       break;
-               case T_CreateTableAsStmt:
-                       retval = _copyCreateTableAsStmt(from);
-                       break;
-               case T_RefreshMatViewStmt:
-                       retval = _copyRefreshMatViewStmt(from);
-                       break;
-               case T_ReplicaIdentityStmt:
-                       retval = _copyReplicaIdentityStmt(from);
-                       break;
-               case T_AlterSystemStmt:
-                       retval = _copyAlterSystemStmt(from);
-                       break;
-               case T_CreateSeqStmt:
-                       retval = _copyCreateSeqStmt(from);
-                       break;
-               case T_AlterSeqStmt:
-                       retval = _copyAlterSeqStmt(from);
-                       break;
-               case T_VariableSetStmt:
-                       retval = _copyVariableSetStmt(from);
-                       break;
-               case T_VariableShowStmt:
-                       retval = _copyVariableShowStmt(from);
-                       break;
-               case T_DiscardStmt:
-                       retval = _copyDiscardStmt(from);
-                       break;
-               case T_CreateTableSpaceStmt:
-                       retval = _copyCreateTableSpaceStmt(from);
-                       break;
-               case T_DropTableSpaceStmt:
-                       retval = _copyDropTableSpaceStmt(from);
-                       break;
-               case T_AlterTableSpaceOptionsStmt:
-                       retval = _copyAlterTableSpaceOptionsStmt(from);
-                       break;
-               case T_AlterTableMoveAllStmt:
-                       retval = _copyAlterTableMoveAllStmt(from);
-                       break;
-               case T_CreateExtensionStmt:
-                       retval = _copyCreateExtensionStmt(from);
-                       break;
-               case T_AlterExtensionStmt:
-                       retval = _copyAlterExtensionStmt(from);
-                       break;
-               case T_AlterExtensionContentsStmt:
-                       retval = _copyAlterExtensionContentsStmt(from);
-                       break;
-               case T_CreateFdwStmt:
-                       retval = _copyCreateFdwStmt(from);
-                       break;
-               case T_AlterFdwStmt:
-                       retval = _copyAlterFdwStmt(from);
-                       break;
-               case T_CreateForeignServerStmt:
-                       retval = _copyCreateForeignServerStmt(from);
-                       break;
-               case T_AlterForeignServerStmt:
-                       retval = _copyAlterForeignServerStmt(from);
-                       break;
-               case T_CreateUserMappingStmt:
-                       retval = _copyCreateUserMappingStmt(from);
-                       break;
-               case T_AlterUserMappingStmt:
-                       retval = _copyAlterUserMappingStmt(from);
-                       break;
-               case T_DropUserMappingStmt:
-                       retval = _copyDropUserMappingStmt(from);
-                       break;
-               case T_CreateForeignTableStmt:
-                       retval = _copyCreateForeignTableStmt(from);
-                       break;
-               case T_ImportForeignSchemaStmt:
-                       retval = _copyImportForeignSchemaStmt(from);
-                       break;
-               case T_CreateTransformStmt:
-                       retval = _copyCreateTransformStmt(from);
-                       break;
-               case T_CreateAmStmt:
-                       retval = _copyCreateAmStmt(from);
-                       break;
-               case T_CreateTrigStmt:
-                       retval = _copyCreateTrigStmt(from);
-                       break;
-               case T_CreateEventTrigStmt:
-                       retval = _copyCreateEventTrigStmt(from);
-                       break;
-               case T_AlterEventTrigStmt:
-                       retval = _copyAlterEventTrigStmt(from);
-                       break;
-               case T_CreatePLangStmt:
-                       retval = _copyCreatePLangStmt(from);
-                       break;
-               case T_CreateRoleStmt:
-                       retval = _copyCreateRoleStmt(from);
-                       break;
-               case T_AlterRoleStmt:
-                       retval = _copyAlterRoleStmt(from);
-                       break;
-               case T_AlterRoleSetStmt:
-                       retval = _copyAlterRoleSetStmt(from);
-                       break;
-               case T_DropRoleStmt:
-                       retval = _copyDropRoleStmt(from);
-                       break;
-               case T_LockStmt:
-                       retval = _copyLockStmt(from);
-                       break;
-               case T_ConstraintsSetStmt:
-                       retval = _copyConstraintsSetStmt(from);
-                       break;
-               case T_ReindexStmt:
-                       retval = _copyReindexStmt(from);
-                       break;
-               case T_CheckPointStmt:
-                       retval = (void *) makeNode(CheckPointStmt);
-                       break;
-               case T_CreateSchemaStmt:
-                       retval = _copyCreateSchemaStmt(from);
-                       break;
-               case T_CreateConversionStmt:
-                       retval = _copyCreateConversionStmt(from);
-                       break;
-               case T_CreateCastStmt:
-                       retval = _copyCreateCastStmt(from);
-                       break;
-               case T_PrepareStmt:
-                       retval = _copyPrepareStmt(from);
-                       break;
-               case T_ExecuteStmt:
-                       retval = _copyExecuteStmt(from);
-                       break;
-               case T_DeallocateStmt:
-                       retval = _copyDeallocateStmt(from);
-                       break;
-               case T_DropOwnedStmt:
-                       retval = _copyDropOwnedStmt(from);
-                       break;
-               case T_ReassignOwnedStmt:
-                       retval = _copyReassignOwnedStmt(from);
-                       break;
-               case T_AlterTSDictionaryStmt:
-                       retval = _copyAlterTSDictionaryStmt(from);
-                       break;
-               case T_AlterTSConfigurationStmt:
-                       retval = _copyAlterTSConfigurationStmt(from);
-                       break;
-               case T_CreatePolicyStmt:
-                       retval = _copyCreatePolicyStmt(from);
-                       break;
-               case T_AlterPolicyStmt:
-                       retval = _copyAlterPolicyStmt(from);
-                       break;
-               case T_CreatePublicationStmt:
-                       retval = _copyCreatePublicationStmt(from);
-                       break;
-               case T_AlterPublicationStmt:
-                       retval = _copyAlterPublicationStmt(from);
-                       break;
-               case T_CreateSubscriptionStmt:
-                       retval = _copyCreateSubscriptionStmt(from);
-                       break;
-               case T_AlterSubscriptionStmt:
-                       retval = _copyAlterSubscriptionStmt(from);
-                       break;
-               case T_DropSubscriptionStmt:
-                       retval = _copyDropSubscriptionStmt(from);
-                       break;
-               case T_A_Expr:
-                       retval = _copyA_Expr(from);
-                       break;
-               case T_ColumnRef:
-                       retval = _copyColumnRef(from);
-                       break;
-               case T_ParamRef:
-                       retval = _copyParamRef(from);
-                       break;
-               case T_A_Const:
-                       retval = _copyA_Const(from);
-                       break;
-               case T_FuncCall:
-                       retval = _copyFuncCall(from);
-                       break;
-               case T_A_Star:
-                       retval = _copyA_Star(from);
-                       break;
-               case T_A_Indices:
-                       retval = _copyA_Indices(from);
-                       break;
-               case T_A_Indirection:
-                       retval = _copyA_Indirection(from);
-                       break;
-               case T_A_ArrayExpr:
-                       retval = _copyA_ArrayExpr(from);
-                       break;
-               case T_ResTarget:
-                       retval = _copyResTarget(from);
-                       break;
-               case T_MultiAssignRef:
-                       retval = _copyMultiAssignRef(from);
-                       break;
-               case T_TypeCast:
-                       retval = _copyTypeCast(from);
-                       break;
-               case T_CollateClause:
-                       retval = _copyCollateClause(from);
-                       break;
-               case T_SortBy:
-                       retval = _copySortBy(from);
-                       break;
-               case T_WindowDef:
-                       retval = _copyWindowDef(from);
-                       break;
-               case T_RangeSubselect:
-                       retval = _copyRangeSubselect(from);
-                       break;
-               case T_RangeFunction:
-                       retval = _copyRangeFunction(from);
-                       break;
-               case T_RangeTableSample:
-                       retval = _copyRangeTableSample(from);
-                       break;
-               case T_RangeTableFunc:
-                       retval = _copyRangeTableFunc(from);
-                       break;
-               case T_RangeTableFuncCol:
-                       retval = _copyRangeTableFuncCol(from);
-                       break;
-               case T_TypeName:
-                       retval = _copyTypeName(from);
-                       break;
-               case T_IndexElem:
-                       retval = _copyIndexElem(from);
-                       break;
-               case T_StatsElem:
-                       retval = _copyStatsElem(from);
-                       break;
-               case T_ColumnDef:
-                       retval = _copyColumnDef(from);
-                       break;
-               case T_Constraint:
-                       retval = _copyConstraint(from);
-                       break;
-               case T_DefElem:
-                       retval = _copyDefElem(from);
-                       break;
-               case T_LockingClause:
-                       retval = _copyLockingClause(from);
-                       break;
-               case T_RangeTblEntry:
-                       retval = _copyRangeTblEntry(from);
-                       break;
-               case T_RangeTblFunction:
-                       retval = _copyRangeTblFunction(from);
-                       break;
-               case T_TableSampleClause:
-                       retval = _copyTableSampleClause(from);
-                       break;
-               case T_WithCheckOption:
-                       retval = _copyWithCheckOption(from);
-                       break;
-               case T_SortGroupClause:
-                       retval = _copySortGroupClause(from);
-                       break;
-               case T_GroupingSet:
-                       retval = _copyGroupingSet(from);
-                       break;
-               case T_WindowClause:
-                       retval = _copyWindowClause(from);
-                       break;
-               case T_RowMarkClause:
-                       retval = _copyRowMarkClause(from);
-                       break;
-               case T_WithClause:
-                       retval = _copyWithClause(from);
-                       break;
-               case T_InferClause:
-                       retval = _copyInferClause(from);
-                       break;
-               case T_OnConflictClause:
-                       retval = _copyOnConflictClause(from);
-                       break;
-               case T_CTESearchClause:
-                       retval = _copyCTESearchClause(from);
-                       break;
-               case T_CTECycleClause:
-                       retval = _copyCTECycleClause(from);
-                       break;
-               case T_CommonTableExpr:
-                       retval = _copyCommonTableExpr(from);
-                       break;
-               case T_MergeWhenClause:
-                       retval = _copyMergeWhenClause(from);
-                       break;
-               case T_MergeAction:
-                       retval = _copyMergeAction(from);
-                       break;
-               case T_ObjectWithArgs:
-                       retval = _copyObjectWithArgs(from);
-                       break;
-               case T_AccessPriv:
-                       retval = _copyAccessPriv(from);
-                       break;
-               case T_XmlSerialize:
-                       retval = _copyXmlSerialize(from);
-                       break;
-               case T_RoleSpec:
-                       retval = _copyRoleSpec(from);
-                       break;
-               case T_TriggerTransition:
-                       retval = _copyTriggerTransition(from);
-                       break;
-               case T_PartitionElem:
-                       retval = _copyPartitionElem(from);
-                       break;
-               case T_PartitionSpec:
-                       retval = _copyPartitionSpec(from);
-                       break;
-               case T_PartitionBoundSpec:
-                       retval = _copyPartitionBoundSpec(from);
-                       break;
-               case T_PartitionRangeDatum:
-                       retval = _copyPartitionRangeDatum(from);
-                       break;
-               case T_PartitionCmd:
-                       retval = _copyPartitionCmd(from);
-                       break;
-               case T_PublicationObjSpec:
-                       retval = _copyPublicationObject(from);
-                       break;
-               case T_PublicationTable:
-                       retval = _copyPublicationTable(from);
-                       break;
-
-                       /*
-                        * MISCELLANEOUS NODES
-                        */
-               case T_ForeignKeyCacheInfo:
-                       retval = _copyForeignKeyCacheInfo(from);
-                       break;
-#endif                                                 /* OBSOLETE */
-
                default:
                        elog(ERROR, "unrecognized node type: %d", (int) nodeTag(from));
                        retval = 0;                     /* keep compiler quiet */
index 8d18548adee2031d76f4e7b3dfffb4de0d5cf9d6..8d54e1a4866800b27372fa439eb5142bed42eab7 100644 (file)
@@ -3,13 +3,6 @@
  * equalfuncs.c
  *       Equality functions to compare node trees.
  *
- * NOTE: we currently support comparing all node types found in parse
- * trees.  We do not support comparing executor state trees; there
- * is no need for that, and no point in maintaining all the code that
- * would be needed.  We also do not support comparing Path trees, mainly
- * because the circular linkages between RelOptInfo and Path nodes can't
- * be handled easily in a simple depth-first traversal.
- *
  * NOTE: it is intentional that parse location fields (in nodes that have
  * one) are not compared.  This is because we want, for example, a variable
  * "x" to be considered equal() to another reference to "x" in the query.
 
 #include "equalfuncs.funcs.c"
 
-#ifdef OBSOLETE
-/*
- *     Stuff from primnodes.h
- */
-
-static bool
-_equalAlias(const Alias *a, const Alias *b)
-{
-       COMPARE_STRING_FIELD(aliasname);
-       COMPARE_NODE_FIELD(colnames);
-
-       return true;
-}
-
-static bool
-_equalRangeVar(const RangeVar *a, const RangeVar *b)
-{
-       COMPARE_STRING_FIELD(catalogname);
-       COMPARE_STRING_FIELD(schemaname);
-       COMPARE_STRING_FIELD(relname);
-       COMPARE_SCALAR_FIELD(inh);
-       COMPARE_SCALAR_FIELD(relpersistence);
-       COMPARE_NODE_FIELD(alias);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalTableFunc(const TableFunc *a, const TableFunc *b)
-{
-       COMPARE_SCALAR_FIELD(functype);
-       COMPARE_NODE_FIELD(ns_uris);
-       COMPARE_NODE_FIELD(ns_names);
-       COMPARE_NODE_FIELD(docexpr);
-       COMPARE_NODE_FIELD(rowexpr);
-       COMPARE_NODE_FIELD(colnames);
-       COMPARE_NODE_FIELD(coltypes);
-       COMPARE_NODE_FIELD(coltypmods);
-       COMPARE_NODE_FIELD(colcollations);
-       COMPARE_NODE_FIELD(colexprs);
-       COMPARE_NODE_FIELD(coldefexprs);
-       COMPARE_NODE_FIELD(colvalexprs);
-       COMPARE_BITMAPSET_FIELD(notnulls);
-       COMPARE_NODE_FIELD(plan);
-       COMPARE_SCALAR_FIELD(ordinalitycol);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonTablePlan(const JsonTablePlan *a, const JsonTablePlan *b)
-{
-       COMPARE_SCALAR_FIELD(plan_type);
-       COMPARE_SCALAR_FIELD(join_type);
-       COMPARE_NODE_FIELD(plan1);
-       COMPARE_NODE_FIELD(plan2);
-       COMPARE_STRING_FIELD(pathname);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonTable(const JsonTable *a, const JsonTable *b)
-{
-       COMPARE_NODE_FIELD(common);
-       COMPARE_NODE_FIELD(columns);
-       COMPARE_NODE_FIELD(plan);
-       COMPARE_NODE_FIELD(on_error);
-       COMPARE_NODE_FIELD(alias);
-       COMPARE_SCALAR_FIELD(lateral);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonTableColumn(const JsonTableColumn *a, const JsonTableColumn *b)
-{
-       COMPARE_SCALAR_FIELD(coltype);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_STRING_FIELD(pathspec);
-       COMPARE_STRING_FIELD(pathname);
-       COMPARE_NODE_FIELD(format);
-       COMPARE_SCALAR_FIELD(wrapper);
-       COMPARE_SCALAR_FIELD(omit_quotes);
-       COMPARE_NODE_FIELD(columns);
-       COMPARE_NODE_FIELD(on_empty);
-       COMPARE_NODE_FIELD(on_error);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonTableParent(const JsonTableParent *a, const JsonTableParent *b)
-{
-       COMPARE_NODE_FIELD(path);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(child);
-       COMPARE_SCALAR_FIELD(outerJoin);
-       COMPARE_SCALAR_FIELD(colMin);
-       COMPARE_SCALAR_FIELD(colMax);
-       COMPARE_SCALAR_FIELD(errorOnError);
-
-       return true;
-}
-
-static bool
-_equalJsonTableSibling(const JsonTableSibling *a, const JsonTableSibling *b)
-{
-       COMPARE_NODE_FIELD(larg);
-       COMPARE_NODE_FIELD(rarg);
-       COMPARE_SCALAR_FIELD(cross);
-
-       return true;
-}
-
-static bool
-_equalIntoClause(const IntoClause *a, const IntoClause *b)
-{
-       COMPARE_NODE_FIELD(rel);
-       COMPARE_NODE_FIELD(colNames);
-       COMPARE_STRING_FIELD(accessMethod);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(onCommit);
-       COMPARE_STRING_FIELD(tableSpaceName);
-       COMPARE_NODE_FIELD(viewQuery);
-       COMPARE_SCALAR_FIELD(skipData);
-
-       return true;
-}
 
 /*
- * We don't need an _equalExpr because Expr is an abstract supertype which
- * should never actually get instantiated.  Also, since it has no common
- * fields except NodeTag, there's no need for a helper routine to factor
- * out comparing the common fields...
+ * Support functions for nodes with custom_copy_equal attribute
  */
 
-static bool
-_equalVar(const Var *a, const Var *b)
-{
-       COMPARE_SCALAR_FIELD(varno);
-       COMPARE_SCALAR_FIELD(varattno);
-       COMPARE_SCALAR_FIELD(vartype);
-       COMPARE_SCALAR_FIELD(vartypmod);
-       COMPARE_SCALAR_FIELD(varcollid);
-       COMPARE_SCALAR_FIELD(varlevelsup);
-
-       /*
-        * varnosyn/varattnosyn are intentionally ignored here, because Vars with
-        * different syntactic identifiers are semantically the same as long as
-        * their varno/varattno match.
-        */
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-#endif                                                 /* OBSOLETE */
-
 static bool
 _equalConst(const Const *a, const Const *b)
 {
@@ -279,3558 +113,127 @@ _equalConst(const Const *a, const Const *b)
                                                a->constbyval, a->constlen);
 }
 
-#ifdef OBSOLETE
-static bool
-_equalParam(const Param *a, const Param *b)
-{
-       COMPARE_SCALAR_FIELD(paramkind);
-       COMPARE_SCALAR_FIELD(paramid);
-       COMPARE_SCALAR_FIELD(paramtype);
-       COMPARE_SCALAR_FIELD(paramtypmod);
-       COMPARE_SCALAR_FIELD(paramcollid);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalAggref(const Aggref *a, const Aggref *b)
-{
-       COMPARE_SCALAR_FIELD(aggfnoid);
-       COMPARE_SCALAR_FIELD(aggtype);
-       COMPARE_SCALAR_FIELD(aggcollid);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       /* ignore aggtranstype since it might not be set yet */
-       COMPARE_NODE_FIELD(aggargtypes);
-       COMPARE_NODE_FIELD(aggdirectargs);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(aggorder);
-       COMPARE_NODE_FIELD(aggdistinct);
-       COMPARE_NODE_FIELD(aggfilter);
-       COMPARE_SCALAR_FIELD(aggstar);
-       COMPARE_SCALAR_FIELD(aggvariadic);
-       COMPARE_SCALAR_FIELD(aggkind);
-       COMPARE_SCALAR_FIELD(agglevelsup);
-       COMPARE_SCALAR_FIELD(aggsplit);
-       COMPARE_SCALAR_FIELD(aggno);
-       COMPARE_SCALAR_FIELD(aggtransno);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalGroupingFunc(const GroupingFunc *a, const GroupingFunc *b)
-{
-       COMPARE_NODE_FIELD(args);
-
-       /*
-        * We must not compare the refs or cols field
-        */
-
-       COMPARE_SCALAR_FIELD(agglevelsup);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalWindowFunc(const WindowFunc *a, const WindowFunc *b)
-{
-       COMPARE_SCALAR_FIELD(winfnoid);
-       COMPARE_SCALAR_FIELD(wintype);
-       COMPARE_SCALAR_FIELD(wincollid);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(aggfilter);
-       COMPARE_SCALAR_FIELD(winref);
-       COMPARE_SCALAR_FIELD(winstar);
-       COMPARE_SCALAR_FIELD(winagg);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
 static bool
-_equalSubscriptingRef(const SubscriptingRef *a, const SubscriptingRef *b)
+_equalExtensibleNode(const ExtensibleNode *a, const ExtensibleNode *b)
 {
-       COMPARE_SCALAR_FIELD(refcontainertype);
-       COMPARE_SCALAR_FIELD(refelemtype);
-       COMPARE_SCALAR_FIELD(refrestype);
-       COMPARE_SCALAR_FIELD(reftypmod);
-       COMPARE_SCALAR_FIELD(refcollid);
-       COMPARE_NODE_FIELD(refupperindexpr);
-       COMPARE_NODE_FIELD(reflowerindexpr);
-       COMPARE_NODE_FIELD(refexpr);
-       COMPARE_NODE_FIELD(refassgnexpr);
-
-       return true;
-}
+       const ExtensibleNodeMethods *methods;
 
-static bool
-_equalFuncExpr(const FuncExpr *a, const FuncExpr *b)
-{
-       COMPARE_SCALAR_FIELD(funcid);
-       COMPARE_SCALAR_FIELD(funcresulttype);
-       COMPARE_SCALAR_FIELD(funcretset);
-       COMPARE_SCALAR_FIELD(funcvariadic);
-       COMPARE_COERCIONFORM_FIELD(funcformat);
-       COMPARE_SCALAR_FIELD(funccollid);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_LOCATION_FIELD(location);
+       COMPARE_STRING_FIELD(extnodename);
 
-       return true;
-}
+       /* At this point, we know extnodename is the same for both nodes. */
+       methods = GetExtensibleNodeMethods(a->extnodename, false);
 
-static bool
-_equalNamedArgExpr(const NamedArgExpr *a, const NamedArgExpr *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_SCALAR_FIELD(argnumber);
-       COMPARE_LOCATION_FIELD(location);
+       /* compare the private fields */
+       if (!methods->nodeEqual(a, b))
+               return false;
 
        return true;
 }
 
 static bool
-_equalOpExpr(const OpExpr *a, const OpExpr *b)
+_equalA_Const(const A_Const *a, const A_Const *b)
 {
-       COMPARE_SCALAR_FIELD(opno);
-
        /*
-        * Special-case opfuncid: it is allowable for it to differ if one node
-        * contains zero and the other doesn't.  This just means that the one node
-        * isn't as far along in the parse/plan pipeline and hasn't had the
-        * opfuncid cache filled yet.
+        * Hack for in-line val field.  Also val is not valid is isnull is true.
         */
-       if (a->opfuncid != b->opfuncid &&
-               a->opfuncid != 0 &&
-               b->opfuncid != 0)
+       if (!a->isnull && !b->isnull &&
+               !equal(&a->val, &b->val))
                return false;
-
-       COMPARE_SCALAR_FIELD(opresulttype);
-       COMPARE_SCALAR_FIELD(opretset);
-       COMPARE_SCALAR_FIELD(opcollid);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       COMPARE_NODE_FIELD(args);
+       COMPARE_SCALAR_FIELD(isnull);
        COMPARE_LOCATION_FIELD(location);
 
        return true;
 }
 
+/*
+ * Lists are handled specially
+ */
 static bool
-_equalDistinctExpr(const DistinctExpr *a, const DistinctExpr *b)
+_equalList(const List *a, const List *b)
 {
-       COMPARE_SCALAR_FIELD(opno);
+       const ListCell *item_a;
+       const ListCell *item_b;
 
        /*
-        * Special-case opfuncid: it is allowable for it to differ if one node
-        * contains zero and the other doesn't.  This just means that the one node
-        * isn't as far along in the parse/plan pipeline and hasn't had the
-        * opfuncid cache filled yet.
+        * Try to reject by simple scalar checks before grovelling through all the
+        * list elements...
         */
-       if (a->opfuncid != b->opfuncid &&
-               a->opfuncid != 0 &&
-               b->opfuncid != 0)
-               return false;
-
-       COMPARE_SCALAR_FIELD(opresulttype);
-       COMPARE_SCALAR_FIELD(opretset);
-       COMPARE_SCALAR_FIELD(opcollid);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalNullIfExpr(const NullIfExpr *a, const NullIfExpr *b)
-{
-       COMPARE_SCALAR_FIELD(opno);
+       COMPARE_SCALAR_FIELD(type);
+       COMPARE_SCALAR_FIELD(length);
 
        /*
-        * Special-case opfuncid: it is allowable for it to differ if one node
-        * contains zero and the other doesn't.  This just means that the one node
-        * isn't as far along in the parse/plan pipeline and hasn't had the
-        * opfuncid cache filled yet.
+        * We place the switch outside the loop for the sake of efficiency; this
+        * may not be worth doing...
         */
-       if (a->opfuncid != b->opfuncid &&
-               a->opfuncid != 0 &&
-               b->opfuncid != 0)
-               return false;
-
-       COMPARE_SCALAR_FIELD(opresulttype);
-       COMPARE_SCALAR_FIELD(opretset);
-       COMPARE_SCALAR_FIELD(opcollid);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalScalarArrayOpExpr(const ScalarArrayOpExpr *a, const ScalarArrayOpExpr *b)
-{
-       COMPARE_SCALAR_FIELD(opno);
+       switch (a->type)
+       {
+               case T_List:
+                       forboth(item_a, a, item_b, b)
+                       {
+                               if (!equal(lfirst(item_a), lfirst(item_b)))
+                                       return false;
+                       }
+                       break;
+               case T_IntList:
+                       forboth(item_a, a, item_b, b)
+                       {
+                               if (lfirst_int(item_a) != lfirst_int(item_b))
+                                       return false;
+                       }
+                       break;
+               case T_OidList:
+                       forboth(item_a, a, item_b, b)
+                       {
+                               if (lfirst_oid(item_a) != lfirst_oid(item_b))
+                                       return false;
+                       }
+                       break;
+               default:
+                       elog(ERROR, "unrecognized list node type: %d",
+                                (int) a->type);
+                       return false;           /* keep compiler quiet */
+       }
 
        /*
-        * Special-case opfuncid: it is allowable for it to differ if one node
-        * contains zero and the other doesn't.  This just means that the one node
-        * isn't as far along in the parse/plan pipeline and hasn't had the
-        * opfuncid cache filled yet.
+        * If we got here, we should have run out of elements of both lists
         */
-       if (a->opfuncid != b->opfuncid &&
-               a->opfuncid != 0 &&
-               b->opfuncid != 0)
-               return false;
-
-       /* As above, hashfuncid may differ too */
-       if (a->hashfuncid != b->hashfuncid &&
-               a->hashfuncid != 0 &&
-               b->hashfuncid != 0)
-               return false;
-
-       /* Likewise for the negfuncid */
-       if (a->negfuncid != b->negfuncid &&
-               a->negfuncid != 0 &&
-               b->negfuncid != 0)
-               return false;
-
-       COMPARE_SCALAR_FIELD(useOr);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalBoolExpr(const BoolExpr *a, const BoolExpr *b)
-{
-       COMPARE_SCALAR_FIELD(boolop);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalSubLink(const SubLink *a, const SubLink *b)
-{
-       COMPARE_SCALAR_FIELD(subLinkType);
-       COMPARE_SCALAR_FIELD(subLinkId);
-       COMPARE_NODE_FIELD(testexpr);
-       COMPARE_NODE_FIELD(operName);
-       COMPARE_NODE_FIELD(subselect);
-       COMPARE_LOCATION_FIELD(location);
+       Assert(item_a == NULL);
+       Assert(item_b == NULL);
 
        return true;
 }
 
-static bool
-_equalSubPlan(const SubPlan *a, const SubPlan *b)
-{
-       COMPARE_SCALAR_FIELD(subLinkType);
-       COMPARE_NODE_FIELD(testexpr);
-       COMPARE_NODE_FIELD(paramIds);
-       COMPARE_SCALAR_FIELD(plan_id);
-       COMPARE_STRING_FIELD(plan_name);
-       COMPARE_SCALAR_FIELD(firstColType);
-       COMPARE_SCALAR_FIELD(firstColTypmod);
-       COMPARE_SCALAR_FIELD(firstColCollation);
-       COMPARE_SCALAR_FIELD(useHashTable);
-       COMPARE_SCALAR_FIELD(unknownEqFalse);
-       COMPARE_SCALAR_FIELD(parallel_safe);
-       COMPARE_NODE_FIELD(setParam);
-       COMPARE_NODE_FIELD(parParam);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_SCALAR_FIELD(startup_cost);
-       COMPARE_SCALAR_FIELD(per_call_cost);
-
-       return true;
-}
 
-static bool
-_equalAlternativeSubPlan(const AlternativeSubPlan *a, const AlternativeSubPlan *b)
+/*
+ * equal
+ *       returns whether two nodes are equal
+ */
+bool
+equal(const void *a, const void *b)
 {
-       COMPARE_NODE_FIELD(subplans);
-
-       return true;
-}
+       bool            retval;
 
-static bool
-_equalFieldSelect(const FieldSelect *a, const FieldSelect *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(fieldnum);
-       COMPARE_SCALAR_FIELD(resulttype);
-       COMPARE_SCALAR_FIELD(resulttypmod);
-       COMPARE_SCALAR_FIELD(resultcollid);
+       if (a == b)
+               return true;
 
-       return true;
-}
+       /*
+        * note that a!=b, so only one of them can be NULL
+        */
+       if (a == NULL || b == NULL)
+               return false;
 
-static bool
-_equalFieldStore(const FieldStore *a, const FieldStore *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_NODE_FIELD(newvals);
-       COMPARE_NODE_FIELD(fieldnums);
-       COMPARE_SCALAR_FIELD(resulttype);
+       /*
+        * are they the same type of nodes?
+        */
+       if (nodeTag(a) != nodeTag(b))
+               return false;
 
-       return true;
-}
+       /* Guard against stack overflow due to overly complex expressions */
+       check_stack_depth();
 
-static bool
-_equalRelabelType(const RelabelType *a, const RelabelType *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(resulttype);
-       COMPARE_SCALAR_FIELD(resulttypmod);
-       COMPARE_SCALAR_FIELD(resultcollid);
-       COMPARE_COERCIONFORM_FIELD(relabelformat);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCoerceViaIO(const CoerceViaIO *a, const CoerceViaIO *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(resulttype);
-       COMPARE_SCALAR_FIELD(resultcollid);
-       COMPARE_COERCIONFORM_FIELD(coerceformat);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalArrayCoerceExpr(const ArrayCoerceExpr *a, const ArrayCoerceExpr *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_NODE_FIELD(elemexpr);
-       COMPARE_SCALAR_FIELD(resulttype);
-       COMPARE_SCALAR_FIELD(resulttypmod);
-       COMPARE_SCALAR_FIELD(resultcollid);
-       COMPARE_COERCIONFORM_FIELD(coerceformat);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalConvertRowtypeExpr(const ConvertRowtypeExpr *a, const ConvertRowtypeExpr *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(resulttype);
-       COMPARE_COERCIONFORM_FIELD(convertformat);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCollateExpr(const CollateExpr *a, const CollateExpr *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(collOid);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCaseExpr(const CaseExpr *a, const CaseExpr *b)
-{
-       COMPARE_SCALAR_FIELD(casetype);
-       COMPARE_SCALAR_FIELD(casecollid);
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(defresult);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCaseWhen(const CaseWhen *a, const CaseWhen *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(result);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCaseTestExpr(const CaseTestExpr *a, const CaseTestExpr *b)
-{
-       COMPARE_SCALAR_FIELD(typeId);
-       COMPARE_SCALAR_FIELD(typeMod);
-       COMPARE_SCALAR_FIELD(collation);
-
-       return true;
-}
-
-static bool
-_equalArrayExpr(const ArrayExpr *a, const ArrayExpr *b)
-{
-       COMPARE_SCALAR_FIELD(array_typeid);
-       COMPARE_SCALAR_FIELD(array_collid);
-       COMPARE_SCALAR_FIELD(element_typeid);
-       COMPARE_NODE_FIELD(elements);
-       COMPARE_SCALAR_FIELD(multidims);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalRowExpr(const RowExpr *a, const RowExpr *b)
-{
-       COMPARE_NODE_FIELD(args);
-       COMPARE_SCALAR_FIELD(row_typeid);
-       COMPARE_COERCIONFORM_FIELD(row_format);
-       COMPARE_NODE_FIELD(colnames);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalRowCompareExpr(const RowCompareExpr *a, const RowCompareExpr *b)
-{
-       COMPARE_SCALAR_FIELD(rctype);
-       COMPARE_NODE_FIELD(opnos);
-       COMPARE_NODE_FIELD(opfamilies);
-       COMPARE_NODE_FIELD(inputcollids);
-       COMPARE_NODE_FIELD(largs);
-       COMPARE_NODE_FIELD(rargs);
-
-       return true;
-}
-
-static bool
-_equalCoalesceExpr(const CoalesceExpr *a, const CoalesceExpr *b)
-{
-       COMPARE_SCALAR_FIELD(coalescetype);
-       COMPARE_SCALAR_FIELD(coalescecollid);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalMinMaxExpr(const MinMaxExpr *a, const MinMaxExpr *b)
-{
-       COMPARE_SCALAR_FIELD(minmaxtype);
-       COMPARE_SCALAR_FIELD(minmaxcollid);
-       COMPARE_SCALAR_FIELD(inputcollid);
-       COMPARE_SCALAR_FIELD(op);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalSQLValueFunction(const SQLValueFunction *a, const SQLValueFunction *b)
-{
-       COMPARE_SCALAR_FIELD(op);
-       COMPARE_SCALAR_FIELD(type);
-       COMPARE_SCALAR_FIELD(typmod);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalXmlExpr(const XmlExpr *a, const XmlExpr *b)
-{
-       COMPARE_SCALAR_FIELD(op);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(named_args);
-       COMPARE_NODE_FIELD(arg_names);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_SCALAR_FIELD(xmloption);
-       COMPARE_SCALAR_FIELD(type);
-       COMPARE_SCALAR_FIELD(typmod);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalNullTest(const NullTest *a, const NullTest *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(nulltesttype);
-       COMPARE_SCALAR_FIELD(argisrow);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalBooleanTest(const BooleanTest *a, const BooleanTest *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(booltesttype);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCoerceToDomain(const CoerceToDomain *a, const CoerceToDomain *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(resulttype);
-       COMPARE_SCALAR_FIELD(resulttypmod);
-       COMPARE_SCALAR_FIELD(resultcollid);
-       COMPARE_COERCIONFORM_FIELD(coercionformat);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCoerceToDomainValue(const CoerceToDomainValue *a, const CoerceToDomainValue *b)
-{
-       COMPARE_SCALAR_FIELD(typeId);
-       COMPARE_SCALAR_FIELD(typeMod);
-       COMPARE_SCALAR_FIELD(collation);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalSetToDefault(const SetToDefault *a, const SetToDefault *b)
-{
-       COMPARE_SCALAR_FIELD(typeId);
-       COMPARE_SCALAR_FIELD(typeMod);
-       COMPARE_SCALAR_FIELD(collation);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCurrentOfExpr(const CurrentOfExpr *a, const CurrentOfExpr *b)
-{
-       COMPARE_SCALAR_FIELD(cvarno);
-       COMPARE_STRING_FIELD(cursor_name);
-       COMPARE_SCALAR_FIELD(cursor_param);
-
-       return true;
-}
-
-static bool
-_equalNextValueExpr(const NextValueExpr *a, const NextValueExpr *b)
-{
-       COMPARE_SCALAR_FIELD(seqid);
-       COMPARE_SCALAR_FIELD(typeId);
-
-       return true;
-}
-
-static bool
-_equalInferenceElem(const InferenceElem *a, const InferenceElem *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_SCALAR_FIELD(infercollid);
-       COMPARE_SCALAR_FIELD(inferopclass);
-
-       return true;
-}
-
-static bool
-_equalTargetEntry(const TargetEntry *a, const TargetEntry *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_SCALAR_FIELD(resno);
-       COMPARE_STRING_FIELD(resname);
-       COMPARE_SCALAR_FIELD(ressortgroupref);
-       COMPARE_SCALAR_FIELD(resorigtbl);
-       COMPARE_SCALAR_FIELD(resorigcol);
-       COMPARE_SCALAR_FIELD(resjunk);
-
-       return true;
-}
-
-static bool
-_equalRangeTblRef(const RangeTblRef *a, const RangeTblRef *b)
-{
-       COMPARE_SCALAR_FIELD(rtindex);
-
-       return true;
-}
-
-static bool
-_equalJoinExpr(const JoinExpr *a, const JoinExpr *b)
-{
-       COMPARE_SCALAR_FIELD(jointype);
-       COMPARE_SCALAR_FIELD(isNatural);
-       COMPARE_NODE_FIELD(larg);
-       COMPARE_NODE_FIELD(rarg);
-       COMPARE_NODE_FIELD(usingClause);
-       COMPARE_NODE_FIELD(join_using_alias);
-       COMPARE_NODE_FIELD(quals);
-       COMPARE_NODE_FIELD(alias);
-       COMPARE_SCALAR_FIELD(rtindex);
-
-       return true;
-}
-
-static bool
-_equalFromExpr(const FromExpr *a, const FromExpr *b)
-{
-       COMPARE_NODE_FIELD(fromlist);
-       COMPARE_NODE_FIELD(quals);
-
-       return true;
-}
-
-static bool
-_equalOnConflictExpr(const OnConflictExpr *a, const OnConflictExpr *b)
-{
-       COMPARE_SCALAR_FIELD(action);
-       COMPARE_NODE_FIELD(arbiterElems);
-       COMPARE_NODE_FIELD(arbiterWhere);
-       COMPARE_SCALAR_FIELD(constraint);
-       COMPARE_NODE_FIELD(onConflictSet);
-       COMPARE_NODE_FIELD(onConflictWhere);
-       COMPARE_SCALAR_FIELD(exclRelIndex);
-       COMPARE_NODE_FIELD(exclRelTlist);
-
-       return true;
-}
-
-static bool
-_equalJsonFormat(const JsonFormat *a, const JsonFormat *b)
-{
-       COMPARE_SCALAR_FIELD(format_type);
-       COMPARE_SCALAR_FIELD(encoding);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonReturning(const JsonReturning *a, const JsonReturning *b)
-{
-       COMPARE_NODE_FIELD(format);
-       COMPARE_SCALAR_FIELD(typid);
-       COMPARE_SCALAR_FIELD(typmod);
-
-       return true;
-}
-
-static bool
-_equalJsonValueExpr(const JsonValueExpr *a, const JsonValueExpr *b)
-{
-       COMPARE_NODE_FIELD(raw_expr);
-       COMPARE_NODE_FIELD(formatted_expr);
-       COMPARE_NODE_FIELD(format);
-
-       return true;
-}
-
-static bool
-_equalJsonParseExpr(const JsonParseExpr *a, const JsonParseExpr *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(output);
-       COMPARE_SCALAR_FIELD(unique_keys);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonScalarExpr(const JsonScalarExpr *a, const JsonScalarExpr *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(output);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonSerializeExpr(const JsonSerializeExpr *a, const JsonSerializeExpr *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(output);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonConstructorExpr(const JsonConstructorExpr *a, const JsonConstructorExpr *b)
-{
-       COMPARE_SCALAR_FIELD(type);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(func);
-       COMPARE_NODE_FIELD(coercion);
-       COMPARE_NODE_FIELD(returning);
-       COMPARE_SCALAR_FIELD(absent_on_null);
-       COMPARE_SCALAR_FIELD(unique);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonKeyValue(const JsonKeyValue *a, const JsonKeyValue *b)
-{
-       COMPARE_NODE_FIELD(key);
-       COMPARE_NODE_FIELD(value);
-
-       return true;
-}
-
-static bool
-_equalJsonObjectConstructor(const JsonObjectConstructor *a,
-                                                       const JsonObjectConstructor *b)
-{
-       COMPARE_NODE_FIELD(exprs);
-       COMPARE_NODE_FIELD(output);
-       COMPARE_SCALAR_FIELD(absent_on_null);
-       COMPARE_SCALAR_FIELD(unique);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonAggConstructor(const JsonAggConstructor *a,
-                                                const JsonAggConstructor *b)
-{
-       COMPARE_NODE_FIELD(output);
-       COMPARE_NODE_FIELD(agg_filter);
-       COMPARE_NODE_FIELD(agg_order);
-       COMPARE_NODE_FIELD(over);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonObjectAgg(const JsonObjectAgg *a, const JsonObjectAgg *b)
-{
-       COMPARE_NODE_FIELD(constructor);
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(absent_on_null);
-       COMPARE_SCALAR_FIELD(unique);
-
-       return true;
-}
-
-static bool
-_equalJsonOutput(const JsonOutput *a, const JsonOutput *b)
-{
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_NODE_FIELD(returning);
-
-       return true;
-}
-
-static bool
-_equalJsonArrayConstructor(const JsonArrayConstructor *a,
-                                                  const JsonArrayConstructor *b)
-{
-       COMPARE_NODE_FIELD(exprs);
-       COMPARE_NODE_FIELD(output);
-       COMPARE_SCALAR_FIELD(absent_on_null);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonArrayAgg(const JsonArrayAgg *a, const JsonArrayAgg *b)
-{
-       COMPARE_NODE_FIELD(constructor);
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(absent_on_null);
-
-       return true;
-}
-
-static bool
-_equalJsonArrayQueryConstructor(const JsonArrayQueryConstructor *a,
-                                                               const JsonArrayQueryConstructor *b)
-{
-       COMPARE_NODE_FIELD(query);
-       COMPARE_NODE_FIELD(output);
-       COMPARE_NODE_FIELD(format);
-       COMPARE_SCALAR_FIELD(absent_on_null);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonFuncExpr(const JsonFuncExpr *a, const JsonFuncExpr *b)
-{
-       COMPARE_SCALAR_FIELD(op);
-       COMPARE_NODE_FIELD(common);
-       COMPARE_NODE_FIELD(output);
-       COMPARE_NODE_FIELD(on_empty);
-       COMPARE_NODE_FIELD(on_error);
-       COMPARE_SCALAR_FIELD(wrapper);
-       COMPARE_SCALAR_FIELD(omit_quotes);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonCommon(const JsonCommon *a, const JsonCommon *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(pathspec);
-       COMPARE_STRING_FIELD(pathname);
-       COMPARE_NODE_FIELD(passing);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalJsonArgument(const JsonArgument *a, const JsonArgument *b)
-{
-       COMPARE_NODE_FIELD(val);
-       COMPARE_STRING_FIELD(name);
-
-       return true;
-}
-
-static bool
-_equalJsonIsPredicate(const JsonIsPredicate *a,
-                                         const JsonIsPredicate *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(format);
-       COMPARE_SCALAR_FIELD(item_type);
-       COMPARE_SCALAR_FIELD(unique_keys);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-/*
- * _equalJsonBehavior
- */
-static bool
-_equalJsonBehavior(const JsonBehavior *a, const JsonBehavior *b)
-{
-       COMPARE_SCALAR_FIELD(btype);
-       COMPARE_NODE_FIELD(default_expr);
-
-       return true;
-}
-
-/*
- * _equalJsonExpr
- */
-static bool
-_equalJsonExpr(const JsonExpr *a, const JsonExpr *b)
-{
-       COMPARE_SCALAR_FIELD(op);
-       COMPARE_NODE_FIELD(formatted_expr);
-       COMPARE_NODE_FIELD(result_coercion);
-       COMPARE_NODE_FIELD(format);
-       COMPARE_NODE_FIELD(path_spec);
-       COMPARE_NODE_FIELD(passing_names);
-       COMPARE_NODE_FIELD(passing_values);
-       COMPARE_NODE_FIELD(returning);
-       COMPARE_NODE_FIELD(on_empty);
-       COMPARE_NODE_FIELD(on_error);
-       COMPARE_NODE_FIELD(coercions);
-       COMPARE_SCALAR_FIELD(wrapper);
-       COMPARE_SCALAR_FIELD(omit_quotes);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-/*
- * _equalJsonCoercion
- */
-static bool
-_equalJsonCoercion(const JsonCoercion *a, const JsonCoercion *b)
-{
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_SCALAR_FIELD(via_populate);
-       COMPARE_SCALAR_FIELD(via_io);
-       COMPARE_SCALAR_FIELD(collation);
-
-       return true;
-}
-
-/*
- * _equalJsonItemCoercions
- */
-static bool
-_equalJsonItemCoercions(const JsonItemCoercions *a, const JsonItemCoercions *b)
-{
-       COMPARE_NODE_FIELD(null);
-       COMPARE_NODE_FIELD(string);
-       COMPARE_NODE_FIELD(numeric);
-       COMPARE_NODE_FIELD(boolean);
-       COMPARE_NODE_FIELD(date);
-       COMPARE_NODE_FIELD(time);
-       COMPARE_NODE_FIELD(timetz);
-       COMPARE_NODE_FIELD(timestamp);
-       COMPARE_NODE_FIELD(timestamptz);
-       COMPARE_NODE_FIELD(composite);
-
-       return true;
-}
-
-/*
- * Stuff from pathnodes.h
- */
-
-static bool
-_equalPathKey(const PathKey *a, const PathKey *b)
-{
-       /* We assume pointer equality is sufficient to compare the eclasses */
-       COMPARE_SCALAR_FIELD(pk_eclass);
-       COMPARE_SCALAR_FIELD(pk_opfamily);
-       COMPARE_SCALAR_FIELD(pk_strategy);
-       COMPARE_SCALAR_FIELD(pk_nulls_first);
-
-       return true;
-}
-
-static bool
-_equalRestrictInfo(const RestrictInfo *a, const RestrictInfo *b)
-{
-       COMPARE_NODE_FIELD(clause);
-       COMPARE_SCALAR_FIELD(is_pushed_down);
-       COMPARE_SCALAR_FIELD(outerjoin_delayed);
-       COMPARE_SCALAR_FIELD(security_level);
-       COMPARE_BITMAPSET_FIELD(required_relids);
-       COMPARE_BITMAPSET_FIELD(outer_relids);
-       COMPARE_BITMAPSET_FIELD(nullable_relids);
-
-       /*
-        * We ignore all the remaining fields, since they may not be set yet, and
-        * should be derivable from the clause anyway.
-        */
-
-       return true;
-}
-
-static bool
-_equalPlaceHolderVar(const PlaceHolderVar *a, const PlaceHolderVar *b)
-{
-       /*
-        * We intentionally do not compare phexpr.  Two PlaceHolderVars with the
-        * same ID and levelsup should be considered equal even if the contained
-        * expressions have managed to mutate to different states.  This will
-        * happen during final plan construction when there are nested PHVs, since
-        * the inner PHV will get replaced by a Param in some copies of the outer
-        * PHV.  Another way in which it can happen is that initplan sublinks
-        * could get replaced by differently-numbered Params when sublink folding
-        * is done.  (The end result of such a situation would be some
-        * unreferenced initplans, which is annoying but not really a problem.) On
-        * the same reasoning, there is no need to examine phrels.
-        *
-        * COMPARE_NODE_FIELD(phexpr);
-        *
-        * COMPARE_BITMAPSET_FIELD(phrels);
-        */
-       COMPARE_SCALAR_FIELD(phid);
-       COMPARE_SCALAR_FIELD(phlevelsup);
-
-       return true;
-}
-
-static bool
-_equalSpecialJoinInfo(const SpecialJoinInfo *a, const SpecialJoinInfo *b)
-{
-       COMPARE_BITMAPSET_FIELD(min_lefthand);
-       COMPARE_BITMAPSET_FIELD(min_righthand);
-       COMPARE_BITMAPSET_FIELD(syn_lefthand);
-       COMPARE_BITMAPSET_FIELD(syn_righthand);
-       COMPARE_SCALAR_FIELD(jointype);
-       COMPARE_SCALAR_FIELD(lhs_strict);
-       COMPARE_SCALAR_FIELD(delay_upper_joins);
-       COMPARE_SCALAR_FIELD(semi_can_btree);
-       COMPARE_SCALAR_FIELD(semi_can_hash);
-       COMPARE_NODE_FIELD(semi_operators);
-       COMPARE_NODE_FIELD(semi_rhs_exprs);
-
-       return true;
-}
-
-static bool
-_equalAppendRelInfo(const AppendRelInfo *a, const AppendRelInfo *b)
-{
-       COMPARE_SCALAR_FIELD(parent_relid);
-       COMPARE_SCALAR_FIELD(child_relid);
-       COMPARE_SCALAR_FIELD(parent_reltype);
-       COMPARE_SCALAR_FIELD(child_reltype);
-       COMPARE_NODE_FIELD(translated_vars);
-       COMPARE_SCALAR_FIELD(num_child_cols);
-       COMPARE_POINTER_FIELD(parent_colnos, a->num_child_cols * sizeof(AttrNumber));
-       COMPARE_SCALAR_FIELD(parent_reloid);
-
-       return true;
-}
-
-static bool
-_equalPlaceHolderInfo(const PlaceHolderInfo *a, const PlaceHolderInfo *b)
-{
-       COMPARE_SCALAR_FIELD(phid);
-       COMPARE_NODE_FIELD(ph_var); /* should be redundant */
-       COMPARE_BITMAPSET_FIELD(ph_eval_at);
-       COMPARE_BITMAPSET_FIELD(ph_lateral);
-       COMPARE_BITMAPSET_FIELD(ph_needed);
-       COMPARE_SCALAR_FIELD(ph_width);
-
-       return true;
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * Stuff from extensible.h
- */
-static bool
-_equalExtensibleNode(const ExtensibleNode *a, const ExtensibleNode *b)
-{
-       const ExtensibleNodeMethods *methods;
-
-       COMPARE_STRING_FIELD(extnodename);
-
-       /* At this point, we know extnodename is the same for both nodes. */
-       methods = GetExtensibleNodeMethods(a->extnodename, false);
-
-       /* compare the private fields */
-       if (!methods->nodeEqual(a, b))
-               return false;
-
-       return true;
-}
-
-#ifdef OBSOLETE
-/*
- * Stuff from parsenodes.h
- */
-
-static bool
-_equalQuery(const Query *a, const Query *b)
-{
-       COMPARE_SCALAR_FIELD(commandType);
-       COMPARE_SCALAR_FIELD(querySource);
-       /* we intentionally ignore queryId, since it might not be set */
-       COMPARE_SCALAR_FIELD(canSetTag);
-       COMPARE_NODE_FIELD(utilityStmt);
-       COMPARE_SCALAR_FIELD(resultRelation);
-       COMPARE_SCALAR_FIELD(hasAggs);
-       COMPARE_SCALAR_FIELD(hasWindowFuncs);
-       COMPARE_SCALAR_FIELD(hasTargetSRFs);
-       COMPARE_SCALAR_FIELD(hasSubLinks);
-       COMPARE_SCALAR_FIELD(hasDistinctOn);
-       COMPARE_SCALAR_FIELD(hasRecursive);
-       COMPARE_SCALAR_FIELD(hasModifyingCTE);
-       COMPARE_SCALAR_FIELD(hasForUpdate);
-       COMPARE_SCALAR_FIELD(hasRowSecurity);
-       COMPARE_SCALAR_FIELD(isReturn);
-       COMPARE_NODE_FIELD(cteList);
-       COMPARE_NODE_FIELD(rtable);
-       COMPARE_NODE_FIELD(jointree);
-       COMPARE_NODE_FIELD(targetList);
-       COMPARE_SCALAR_FIELD(override);
-       COMPARE_NODE_FIELD(onConflict);
-       COMPARE_NODE_FIELD(returningList);
-       COMPARE_NODE_FIELD(groupClause);
-       COMPARE_SCALAR_FIELD(groupDistinct);
-       COMPARE_NODE_FIELD(groupingSets);
-       COMPARE_NODE_FIELD(havingQual);
-       COMPARE_NODE_FIELD(windowClause);
-       COMPARE_NODE_FIELD(distinctClause);
-       COMPARE_NODE_FIELD(sortClause);
-       COMPARE_NODE_FIELD(limitOffset);
-       COMPARE_NODE_FIELD(limitCount);
-       COMPARE_SCALAR_FIELD(limitOption);
-       COMPARE_NODE_FIELD(rowMarks);
-       COMPARE_NODE_FIELD(setOperations);
-       COMPARE_NODE_FIELD(constraintDeps);
-       COMPARE_NODE_FIELD(withCheckOptions);
-       COMPARE_NODE_FIELD(mergeActionList);
-       COMPARE_SCALAR_FIELD(mergeUseOuterJoin);
-       COMPARE_LOCATION_FIELD(stmt_location);
-       COMPARE_SCALAR_FIELD(stmt_len);
-
-       return true;
-}
-
-static bool
-_equalRawStmt(const RawStmt *a, const RawStmt *b)
-{
-       COMPARE_NODE_FIELD(stmt);
-       COMPARE_LOCATION_FIELD(stmt_location);
-       COMPARE_SCALAR_FIELD(stmt_len);
-
-       return true;
-}
-
-static bool
-_equalInsertStmt(const InsertStmt *a, const InsertStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(cols);
-       COMPARE_NODE_FIELD(selectStmt);
-       COMPARE_NODE_FIELD(onConflictClause);
-       COMPARE_NODE_FIELD(returningList);
-       COMPARE_NODE_FIELD(withClause);
-       COMPARE_SCALAR_FIELD(override);
-
-       return true;
-}
-
-static bool
-_equalDeleteStmt(const DeleteStmt *a, const DeleteStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(usingClause);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_NODE_FIELD(returningList);
-       COMPARE_NODE_FIELD(withClause);
-
-       return true;
-}
-
-static bool
-_equalUpdateStmt(const UpdateStmt *a, const UpdateStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(targetList);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_NODE_FIELD(fromClause);
-       COMPARE_NODE_FIELD(returningList);
-       COMPARE_NODE_FIELD(withClause);
-
-       return true;
-}
-
-static bool
-_equalMergeStmt(const MergeStmt *a, const MergeStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(sourceRelation);
-       COMPARE_NODE_FIELD(joinCondition);
-       COMPARE_NODE_FIELD(mergeWhenClauses);
-       COMPARE_NODE_FIELD(withClause);
-
-       return true;
-}
-
-static bool
-_equalSelectStmt(const SelectStmt *a, const SelectStmt *b)
-{
-       COMPARE_NODE_FIELD(distinctClause);
-       COMPARE_NODE_FIELD(intoClause);
-       COMPARE_NODE_FIELD(targetList);
-       COMPARE_NODE_FIELD(fromClause);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_NODE_FIELD(groupClause);
-       COMPARE_SCALAR_FIELD(groupDistinct);
-       COMPARE_NODE_FIELD(havingClause);
-       COMPARE_NODE_FIELD(windowClause);
-       COMPARE_NODE_FIELD(valuesLists);
-       COMPARE_NODE_FIELD(sortClause);
-       COMPARE_NODE_FIELD(limitOffset);
-       COMPARE_NODE_FIELD(limitCount);
-       COMPARE_SCALAR_FIELD(limitOption);
-       COMPARE_NODE_FIELD(lockingClause);
-       COMPARE_NODE_FIELD(withClause);
-       COMPARE_SCALAR_FIELD(op);
-       COMPARE_SCALAR_FIELD(all);
-       COMPARE_NODE_FIELD(larg);
-       COMPARE_NODE_FIELD(rarg);
-
-       return true;
-}
-
-static bool
-_equalSetOperationStmt(const SetOperationStmt *a, const SetOperationStmt *b)
-{
-       COMPARE_SCALAR_FIELD(op);
-       COMPARE_SCALAR_FIELD(all);
-       COMPARE_NODE_FIELD(larg);
-       COMPARE_NODE_FIELD(rarg);
-       COMPARE_NODE_FIELD(colTypes);
-       COMPARE_NODE_FIELD(colTypmods);
-       COMPARE_NODE_FIELD(colCollations);
-       COMPARE_NODE_FIELD(groupClauses);
-
-       return true;
-}
-
-static bool
-_equalReturnStmt(const ReturnStmt *a, const ReturnStmt *b)
-{
-       COMPARE_NODE_FIELD(returnval);
-
-       return true;
-}
-
-static bool
-_equalPLAssignStmt(const PLAssignStmt *a, const PLAssignStmt *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(indirection);
-       COMPARE_SCALAR_FIELD(nnames);
-       COMPARE_NODE_FIELD(val);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalAlterTableStmt(const AlterTableStmt *a, const AlterTableStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(cmds);
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalAlterTableCmd(const AlterTableCmd *a, const AlterTableCmd *b)
-{
-       COMPARE_SCALAR_FIELD(subtype);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_SCALAR_FIELD(num);
-       COMPARE_NODE_FIELD(newowner);
-       COMPARE_NODE_FIELD(def);
-       COMPARE_SCALAR_FIELD(behavior);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalAlterCollationStmt(const AlterCollationStmt *a, const AlterCollationStmt *b)
-{
-       COMPARE_NODE_FIELD(collname);
-
-       return true;
-}
-
-static bool
-_equalAlterDomainStmt(const AlterDomainStmt *a, const AlterDomainStmt *b)
-{
-       COMPARE_SCALAR_FIELD(subtype);
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(def);
-       COMPARE_SCALAR_FIELD(behavior);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalGrantStmt(const GrantStmt *a, const GrantStmt *b)
-{
-       COMPARE_SCALAR_FIELD(is_grant);
-       COMPARE_SCALAR_FIELD(targtype);
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_NODE_FIELD(objects);
-       COMPARE_NODE_FIELD(privileges);
-       COMPARE_NODE_FIELD(grantees);
-       COMPARE_SCALAR_FIELD(grant_option);
-       COMPARE_NODE_FIELD(grantor);
-       COMPARE_SCALAR_FIELD(behavior);
-
-       return true;
-}
-
-static bool
-_equalObjectWithArgs(const ObjectWithArgs *a, const ObjectWithArgs *b)
-{
-       COMPARE_NODE_FIELD(objname);
-       COMPARE_NODE_FIELD(objargs);
-       COMPARE_NODE_FIELD(objfuncargs);
-       COMPARE_SCALAR_FIELD(args_unspecified);
-
-       return true;
-}
-
-static bool
-_equalAccessPriv(const AccessPriv *a, const AccessPriv *b)
-{
-       COMPARE_STRING_FIELD(priv_name);
-       COMPARE_NODE_FIELD(cols);
-
-       return true;
-}
-
-static bool
-_equalGrantRoleStmt(const GrantRoleStmt *a, const GrantRoleStmt *b)
-{
-       COMPARE_NODE_FIELD(granted_roles);
-       COMPARE_NODE_FIELD(grantee_roles);
-       COMPARE_SCALAR_FIELD(is_grant);
-       COMPARE_SCALAR_FIELD(admin_opt);
-       COMPARE_NODE_FIELD(grantor);
-       COMPARE_SCALAR_FIELD(behavior);
-
-       return true;
-}
-
-static bool
-_equalAlterDefaultPrivilegesStmt(const AlterDefaultPrivilegesStmt *a, const AlterDefaultPrivilegesStmt *b)
-{
-       COMPARE_NODE_FIELD(options);
-       COMPARE_NODE_FIELD(action);
-
-       return true;
-}
-
-static bool
-_equalDeclareCursorStmt(const DeclareCursorStmt *a, const DeclareCursorStmt *b)
-{
-       COMPARE_STRING_FIELD(portalname);
-       COMPARE_SCALAR_FIELD(options);
-       COMPARE_NODE_FIELD(query);
-
-       return true;
-}
-
-static bool
-_equalClosePortalStmt(const ClosePortalStmt *a, const ClosePortalStmt *b)
-{
-       COMPARE_STRING_FIELD(portalname);
-
-       return true;
-}
-
-static bool
-_equalCallStmt(const CallStmt *a, const CallStmt *b)
-{
-       COMPARE_NODE_FIELD(funccall);
-       COMPARE_NODE_FIELD(funcexpr);
-       COMPARE_NODE_FIELD(outargs);
-
-       return true;
-}
-
-static bool
-_equalClusterStmt(const ClusterStmt *a, const ClusterStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_STRING_FIELD(indexname);
-       COMPARE_NODE_FIELD(params);
-
-       return true;
-}
-
-static bool
-_equalCopyStmt(const CopyStmt *a, const CopyStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(query);
-       COMPARE_NODE_FIELD(attlist);
-       COMPARE_SCALAR_FIELD(is_from);
-       COMPARE_SCALAR_FIELD(is_program);
-       COMPARE_STRING_FIELD(filename);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_NODE_FIELD(whereClause);
-
-       return true;
-}
-
-static bool
-_equalCreateStmt(const CreateStmt *a, const CreateStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(tableElts);
-       COMPARE_NODE_FIELD(inhRelations);
-       COMPARE_NODE_FIELD(partbound);
-       COMPARE_NODE_FIELD(partspec);
-       COMPARE_NODE_FIELD(ofTypename);
-       COMPARE_NODE_FIELD(constraints);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(oncommit);
-       COMPARE_STRING_FIELD(tablespacename);
-       COMPARE_STRING_FIELD(accessMethod);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-
-       return true;
-}
-
-static bool
-_equalTableLikeClause(const TableLikeClause *a, const TableLikeClause *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_SCALAR_FIELD(options);
-       COMPARE_SCALAR_FIELD(relationOid);
-
-       return true;
-}
-
-static bool
-_equalDefineStmt(const DefineStmt *a, const DefineStmt *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_SCALAR_FIELD(oldstyle);
-       COMPARE_NODE_FIELD(defnames);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(definition);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-       COMPARE_SCALAR_FIELD(replace);
-
-       return true;
-}
-
-static bool
-_equalDropStmt(const DropStmt *a, const DropStmt *b)
-{
-       COMPARE_NODE_FIELD(objects);
-       COMPARE_SCALAR_FIELD(removeType);
-       COMPARE_SCALAR_FIELD(behavior);
-       COMPARE_SCALAR_FIELD(missing_ok);
-       COMPARE_SCALAR_FIELD(concurrent);
-
-       return true;
-}
-
-static bool
-_equalTruncateStmt(const TruncateStmt *a, const TruncateStmt *b)
-{
-       COMPARE_NODE_FIELD(relations);
-       COMPARE_SCALAR_FIELD(restart_seqs);
-       COMPARE_SCALAR_FIELD(behavior);
-
-       return true;
-}
-
-static bool
-_equalCommentStmt(const CommentStmt *a, const CommentStmt *b)
-{
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_NODE_FIELD(object);
-       COMPARE_STRING_FIELD(comment);
-
-       return true;
-}
-
-static bool
-_equalSecLabelStmt(const SecLabelStmt *a, const SecLabelStmt *b)
-{
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_NODE_FIELD(object);
-       COMPARE_STRING_FIELD(provider);
-       COMPARE_STRING_FIELD(label);
-
-       return true;
-}
-
-static bool
-_equalFetchStmt(const FetchStmt *a, const FetchStmt *b)
-{
-       COMPARE_SCALAR_FIELD(direction);
-       COMPARE_SCALAR_FIELD(howMany);
-       COMPARE_STRING_FIELD(portalname);
-       COMPARE_SCALAR_FIELD(ismove);
-
-       return true;
-}
-
-static bool
-_equalIndexStmt(const IndexStmt *a, const IndexStmt *b)
-{
-       COMPARE_STRING_FIELD(idxname);
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_STRING_FIELD(accessMethod);
-       COMPARE_STRING_FIELD(tableSpace);
-       COMPARE_NODE_FIELD(indexParams);
-       COMPARE_NODE_FIELD(indexIncludingParams);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_NODE_FIELD(excludeOpNames);
-       COMPARE_STRING_FIELD(idxcomment);
-       COMPARE_SCALAR_FIELD(indexOid);
-       COMPARE_SCALAR_FIELD(oldNumber);
-       COMPARE_SCALAR_FIELD(oldCreateSubid);
-       COMPARE_SCALAR_FIELD(oldFirstRelfilelocatorSubid);
-       COMPARE_SCALAR_FIELD(unique);
-       COMPARE_SCALAR_FIELD(nulls_not_distinct);
-       COMPARE_SCALAR_FIELD(primary);
-       COMPARE_SCALAR_FIELD(isconstraint);
-       COMPARE_SCALAR_FIELD(deferrable);
-       COMPARE_SCALAR_FIELD(initdeferred);
-       COMPARE_SCALAR_FIELD(transformed);
-       COMPARE_SCALAR_FIELD(concurrent);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-       COMPARE_SCALAR_FIELD(reset_default_tblspc);
-
-       return true;
-}
-
-static bool
-_equalCreateStatsStmt(const CreateStatsStmt *a, const CreateStatsStmt *b)
-{
-       COMPARE_NODE_FIELD(defnames);
-       COMPARE_NODE_FIELD(stat_types);
-       COMPARE_NODE_FIELD(exprs);
-       COMPARE_NODE_FIELD(relations);
-       COMPARE_STRING_FIELD(stxcomment);
-       COMPARE_SCALAR_FIELD(transformed);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-
-       return true;
-}
-
-static bool
-_equalAlterStatsStmt(const AlterStatsStmt *a, const AlterStatsStmt *b)
-{
-       COMPARE_NODE_FIELD(defnames);
-       COMPARE_SCALAR_FIELD(stxstattarget);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalCreateFunctionStmt(const CreateFunctionStmt *a, const CreateFunctionStmt *b)
-{
-       COMPARE_SCALAR_FIELD(is_procedure);
-       COMPARE_SCALAR_FIELD(replace);
-       COMPARE_NODE_FIELD(funcname);
-       COMPARE_NODE_FIELD(parameters);
-       COMPARE_NODE_FIELD(returnType);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_NODE_FIELD(sql_body);
-
-       return true;
-}
-
-static bool
-_equalFunctionParameter(const FunctionParameter *a, const FunctionParameter *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(argType);
-       COMPARE_SCALAR_FIELD(mode);
-       COMPARE_NODE_FIELD(defexpr);
-
-       return true;
-}
-
-static bool
-_equalAlterFunctionStmt(const AlterFunctionStmt *a, const AlterFunctionStmt *b)
-{
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_NODE_FIELD(func);
-       COMPARE_NODE_FIELD(actions);
-
-       return true;
-}
-
-static bool
-_equalDoStmt(const DoStmt *a, const DoStmt *b)
-{
-       COMPARE_NODE_FIELD(args);
-
-       return true;
-}
-
-static bool
-_equalRenameStmt(const RenameStmt *a, const RenameStmt *b)
-{
-       COMPARE_SCALAR_FIELD(renameType);
-       COMPARE_SCALAR_FIELD(relationType);
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(object);
-       COMPARE_STRING_FIELD(subname);
-       COMPARE_STRING_FIELD(newname);
-       COMPARE_SCALAR_FIELD(behavior);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalAlterObjectDependsStmt(const AlterObjectDependsStmt *a, const AlterObjectDependsStmt *b)
-{
-       COMPARE_SCALAR_FIELD(objectType);
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(object);
-       COMPARE_NODE_FIELD(extname);
-       COMPARE_SCALAR_FIELD(remove);
-
-       return true;
-}
-
-static bool
-_equalAlterObjectSchemaStmt(const AlterObjectSchemaStmt *a, const AlterObjectSchemaStmt *b)
-{
-       COMPARE_SCALAR_FIELD(objectType);
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(object);
-       COMPARE_STRING_FIELD(newschema);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalAlterOwnerStmt(const AlterOwnerStmt *a, const AlterOwnerStmt *b)
-{
-       COMPARE_SCALAR_FIELD(objectType);
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(object);
-       COMPARE_NODE_FIELD(newowner);
-
-       return true;
-}
-
-static bool
-_equalAlterOperatorStmt(const AlterOperatorStmt *a, const AlterOperatorStmt *b)
-{
-       COMPARE_NODE_FIELD(opername);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterTypeStmt(const AlterTypeStmt *a, const AlterTypeStmt *b)
-{
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalRuleStmt(const RuleStmt *a, const RuleStmt *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_STRING_FIELD(rulename);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_SCALAR_FIELD(event);
-       COMPARE_SCALAR_FIELD(instead);
-       COMPARE_NODE_FIELD(actions);
-       COMPARE_SCALAR_FIELD(replace);
-
-       return true;
-}
-
-static bool
-_equalNotifyStmt(const NotifyStmt *a, const NotifyStmt *b)
-{
-       COMPARE_STRING_FIELD(conditionname);
-       COMPARE_STRING_FIELD(payload);
-
-       return true;
-}
-
-static bool
-_equalListenStmt(const ListenStmt *a, const ListenStmt *b)
-{
-       COMPARE_STRING_FIELD(conditionname);
-
-       return true;
-}
-
-static bool
-_equalUnlistenStmt(const UnlistenStmt *a, const UnlistenStmt *b)
-{
-       COMPARE_STRING_FIELD(conditionname);
-
-       return true;
-}
-
-static bool
-_equalTransactionStmt(const TransactionStmt *a, const TransactionStmt *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_STRING_FIELD(savepoint_name);
-       COMPARE_STRING_FIELD(gid);
-       COMPARE_SCALAR_FIELD(chain);
-
-       return true;
-}
-
-static bool
-_equalCompositeTypeStmt(const CompositeTypeStmt *a, const CompositeTypeStmt *b)
-{
-       COMPARE_NODE_FIELD(typevar);
-       COMPARE_NODE_FIELD(coldeflist);
-
-       return true;
-}
-
-static bool
-_equalCreateEnumStmt(const CreateEnumStmt *a, const CreateEnumStmt *b)
-{
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_NODE_FIELD(vals);
-
-       return true;
-}
-
-static bool
-_equalCreateRangeStmt(const CreateRangeStmt *a, const CreateRangeStmt *b)
-{
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_NODE_FIELD(params);
-
-       return true;
-}
-
-static bool
-_equalAlterEnumStmt(const AlterEnumStmt *a, const AlterEnumStmt *b)
-{
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_STRING_FIELD(oldVal);
-       COMPARE_STRING_FIELD(newVal);
-       COMPARE_STRING_FIELD(newValNeighbor);
-       COMPARE_SCALAR_FIELD(newValIsAfter);
-       COMPARE_SCALAR_FIELD(skipIfNewValExists);
-
-       return true;
-}
-
-static bool
-_equalViewStmt(const ViewStmt *a, const ViewStmt *b)
-{
-       COMPARE_NODE_FIELD(view);
-       COMPARE_NODE_FIELD(aliases);
-       COMPARE_NODE_FIELD(query);
-       COMPARE_SCALAR_FIELD(replace);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(withCheckOption);
-
-       return true;
-}
-
-static bool
-_equalLoadStmt(const LoadStmt *a, const LoadStmt *b)
-{
-       COMPARE_STRING_FIELD(filename);
-
-       return true;
-}
-
-static bool
-_equalCreateDomainStmt(const CreateDomainStmt *a, const CreateDomainStmt *b)
-{
-       COMPARE_NODE_FIELD(domainname);
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_NODE_FIELD(collClause);
-       COMPARE_NODE_FIELD(constraints);
-
-       return true;
-}
-
-static bool
-_equalCreateOpClassStmt(const CreateOpClassStmt *a, const CreateOpClassStmt *b)
-{
-       COMPARE_NODE_FIELD(opclassname);
-       COMPARE_NODE_FIELD(opfamilyname);
-       COMPARE_STRING_FIELD(amname);
-       COMPARE_NODE_FIELD(datatype);
-       COMPARE_NODE_FIELD(items);
-       COMPARE_SCALAR_FIELD(isDefault);
-
-       return true;
-}
-
-static bool
-_equalCreateOpClassItem(const CreateOpClassItem *a, const CreateOpClassItem *b)
-{
-       COMPARE_SCALAR_FIELD(itemtype);
-       COMPARE_NODE_FIELD(name);
-       COMPARE_SCALAR_FIELD(number);
-       COMPARE_NODE_FIELD(order_family);
-       COMPARE_NODE_FIELD(class_args);
-       COMPARE_NODE_FIELD(storedtype);
-
-       return true;
-}
-
-static bool
-_equalCreateOpFamilyStmt(const CreateOpFamilyStmt *a, const CreateOpFamilyStmt *b)
-{
-       COMPARE_NODE_FIELD(opfamilyname);
-       COMPARE_STRING_FIELD(amname);
-
-       return true;
-}
-
-static bool
-_equalAlterOpFamilyStmt(const AlterOpFamilyStmt *a, const AlterOpFamilyStmt *b)
-{
-       COMPARE_NODE_FIELD(opfamilyname);
-       COMPARE_STRING_FIELD(amname);
-       COMPARE_SCALAR_FIELD(isDrop);
-       COMPARE_NODE_FIELD(items);
-
-       return true;
-}
-
-static bool
-_equalCreatedbStmt(const CreatedbStmt *a, const CreatedbStmt *b)
-{
-       COMPARE_STRING_FIELD(dbname);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterDatabaseStmt(const AlterDatabaseStmt *a, const AlterDatabaseStmt *b)
-{
-       COMPARE_STRING_FIELD(dbname);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterDatabaseRefreshCollStmt(const AlterDatabaseRefreshCollStmt *a, const AlterDatabaseRefreshCollStmt *b)
-{
-       COMPARE_STRING_FIELD(dbname);
-
-       return true;
-}
-
-static bool
-_equalAlterDatabaseSetStmt(const AlterDatabaseSetStmt *a, const AlterDatabaseSetStmt *b)
-{
-       COMPARE_STRING_FIELD(dbname);
-       COMPARE_NODE_FIELD(setstmt);
-
-       return true;
-}
-
-static bool
-_equalDropdbStmt(const DropdbStmt *a, const DropdbStmt *b)
-{
-       COMPARE_STRING_FIELD(dbname);
-       COMPARE_SCALAR_FIELD(missing_ok);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalVacuumStmt(const VacuumStmt *a, const VacuumStmt *b)
-{
-       COMPARE_NODE_FIELD(options);
-       COMPARE_NODE_FIELD(rels);
-       COMPARE_SCALAR_FIELD(is_vacuumcmd);
-
-       return true;
-}
-
-static bool
-_equalVacuumRelation(const VacuumRelation *a, const VacuumRelation *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_SCALAR_FIELD(oid);
-       COMPARE_NODE_FIELD(va_cols);
-
-       return true;
-}
-
-static bool
-_equalExplainStmt(const ExplainStmt *a, const ExplainStmt *b)
-{
-       COMPARE_NODE_FIELD(query);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalCreateTableAsStmt(const CreateTableAsStmt *a, const CreateTableAsStmt *b)
-{
-       COMPARE_NODE_FIELD(query);
-       COMPARE_NODE_FIELD(into);
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_SCALAR_FIELD(is_select_into);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-
-       return true;
-}
-
-static bool
-_equalRefreshMatViewStmt(const RefreshMatViewStmt *a, const RefreshMatViewStmt *b)
-{
-       COMPARE_SCALAR_FIELD(concurrent);
-       COMPARE_SCALAR_FIELD(skipData);
-       COMPARE_NODE_FIELD(relation);
-
-       return true;
-}
-
-static bool
-_equalReplicaIdentityStmt(const ReplicaIdentityStmt *a, const ReplicaIdentityStmt *b)
-{
-       COMPARE_SCALAR_FIELD(identity_type);
-       COMPARE_STRING_FIELD(name);
-
-       return true;
-}
-
-static bool
-_equalAlterSystemStmt(const AlterSystemStmt *a, const AlterSystemStmt *b)
-{
-       COMPARE_NODE_FIELD(setstmt);
-
-       return true;
-}
-
-
-static bool
-_equalCreateSeqStmt(const CreateSeqStmt *a, const CreateSeqStmt *b)
-{
-       COMPARE_NODE_FIELD(sequence);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(ownerId);
-       COMPARE_SCALAR_FIELD(for_identity);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-
-       return true;
-}
-
-static bool
-_equalAlterSeqStmt(const AlterSeqStmt *a, const AlterSeqStmt *b)
-{
-       COMPARE_NODE_FIELD(sequence);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(for_identity);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalVariableSetStmt(const VariableSetStmt *a, const VariableSetStmt *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_SCALAR_FIELD(is_local);
-
-       return true;
-}
-
-static bool
-_equalVariableShowStmt(const VariableShowStmt *a, const VariableShowStmt *b)
-{
-       COMPARE_STRING_FIELD(name);
-
-       return true;
-}
-
-static bool
-_equalDiscardStmt(const DiscardStmt *a, const DiscardStmt *b)
-{
-       COMPARE_SCALAR_FIELD(target);
-
-       return true;
-}
-
-static bool
-_equalCreateTableSpaceStmt(const CreateTableSpaceStmt *a, const CreateTableSpaceStmt *b)
-{
-       COMPARE_STRING_FIELD(tablespacename);
-       COMPARE_NODE_FIELD(owner);
-       COMPARE_STRING_FIELD(location);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalDropTableSpaceStmt(const DropTableSpaceStmt *a, const DropTableSpaceStmt *b)
-{
-       COMPARE_STRING_FIELD(tablespacename);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalAlterTableSpaceOptionsStmt(const AlterTableSpaceOptionsStmt *a,
-                                                                const AlterTableSpaceOptionsStmt *b)
-{
-       COMPARE_STRING_FIELD(tablespacename);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(isReset);
-
-       return true;
-}
-
-static bool
-_equalAlterTableMoveAllStmt(const AlterTableMoveAllStmt *a,
-                                                       const AlterTableMoveAllStmt *b)
-{
-       COMPARE_STRING_FIELD(orig_tablespacename);
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_NODE_FIELD(roles);
-       COMPARE_STRING_FIELD(new_tablespacename);
-       COMPARE_SCALAR_FIELD(nowait);
-
-       return true;
-}
-
-static bool
-_equalCreateExtensionStmt(const CreateExtensionStmt *a, const CreateExtensionStmt *b)
-{
-       COMPARE_STRING_FIELD(extname);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterExtensionStmt(const AlterExtensionStmt *a, const AlterExtensionStmt *b)
-{
-       COMPARE_STRING_FIELD(extname);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterExtensionContentsStmt(const AlterExtensionContentsStmt *a, const AlterExtensionContentsStmt *b)
-{
-       COMPARE_STRING_FIELD(extname);
-       COMPARE_SCALAR_FIELD(action);
-       COMPARE_SCALAR_FIELD(objtype);
-       COMPARE_NODE_FIELD(object);
-
-       return true;
-}
-
-static bool
-_equalCreateFdwStmt(const CreateFdwStmt *a, const CreateFdwStmt *b)
-{
-       COMPARE_STRING_FIELD(fdwname);
-       COMPARE_NODE_FIELD(func_options);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterFdwStmt(const AlterFdwStmt *a, const AlterFdwStmt *b)
-{
-       COMPARE_STRING_FIELD(fdwname);
-       COMPARE_NODE_FIELD(func_options);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalCreateForeignServerStmt(const CreateForeignServerStmt *a, const CreateForeignServerStmt *b)
-{
-       COMPARE_STRING_FIELD(servername);
-       COMPARE_STRING_FIELD(servertype);
-       COMPARE_STRING_FIELD(version);
-       COMPARE_STRING_FIELD(fdwname);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterForeignServerStmt(const AlterForeignServerStmt *a, const AlterForeignServerStmt *b)
-{
-       COMPARE_STRING_FIELD(servername);
-       COMPARE_STRING_FIELD(version);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(has_version);
-
-       return true;
-}
-
-static bool
-_equalCreateUserMappingStmt(const CreateUserMappingStmt *a, const CreateUserMappingStmt *b)
-{
-       COMPARE_NODE_FIELD(user);
-       COMPARE_STRING_FIELD(servername);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterUserMappingStmt(const AlterUserMappingStmt *a, const AlterUserMappingStmt *b)
-{
-       COMPARE_NODE_FIELD(user);
-       COMPARE_STRING_FIELD(servername);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalDropUserMappingStmt(const DropUserMappingStmt *a, const DropUserMappingStmt *b)
-{
-       COMPARE_NODE_FIELD(user);
-       COMPARE_STRING_FIELD(servername);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalCreateForeignTableStmt(const CreateForeignTableStmt *a, const CreateForeignTableStmt *b)
-{
-       if (!_equalCreateStmt(&a->base, &b->base))
-               return false;
-
-       COMPARE_STRING_FIELD(servername);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalImportForeignSchemaStmt(const ImportForeignSchemaStmt *a, const ImportForeignSchemaStmt *b)
-{
-       COMPARE_STRING_FIELD(server_name);
-       COMPARE_STRING_FIELD(remote_schema);
-       COMPARE_STRING_FIELD(local_schema);
-       COMPARE_SCALAR_FIELD(list_type);
-       COMPARE_NODE_FIELD(table_list);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalCreateTransformStmt(const CreateTransformStmt *a, const CreateTransformStmt *b)
-{
-       COMPARE_SCALAR_FIELD(replace);
-       COMPARE_NODE_FIELD(type_name);
-       COMPARE_STRING_FIELD(lang);
-       COMPARE_NODE_FIELD(fromsql);
-       COMPARE_NODE_FIELD(tosql);
-
-       return true;
-}
-
-static bool
-_equalCreateAmStmt(const CreateAmStmt *a, const CreateAmStmt *b)
-{
-       COMPARE_STRING_FIELD(amname);
-       COMPARE_NODE_FIELD(handler_name);
-       COMPARE_SCALAR_FIELD(amtype);
-
-       return true;
-}
-
-static bool
-_equalCreateTrigStmt(const CreateTrigStmt *a, const CreateTrigStmt *b)
-{
-       COMPARE_SCALAR_FIELD(replace);
-       COMPARE_SCALAR_FIELD(isconstraint);
-       COMPARE_STRING_FIELD(trigname);
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(funcname);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_SCALAR_FIELD(row);
-       COMPARE_SCALAR_FIELD(timing);
-       COMPARE_SCALAR_FIELD(events);
-       COMPARE_NODE_FIELD(columns);
-       COMPARE_NODE_FIELD(whenClause);
-       COMPARE_NODE_FIELD(transitionRels);
-       COMPARE_SCALAR_FIELD(deferrable);
-       COMPARE_SCALAR_FIELD(initdeferred);
-       COMPARE_NODE_FIELD(constrrel);
-
-       return true;
-}
-
-static bool
-_equalCreateEventTrigStmt(const CreateEventTrigStmt *a, const CreateEventTrigStmt *b)
-{
-       COMPARE_STRING_FIELD(trigname);
-       COMPARE_STRING_FIELD(eventname);
-       COMPARE_NODE_FIELD(whenclause);
-       COMPARE_NODE_FIELD(funcname);
-
-       return true;
-}
-
-static bool
-_equalAlterEventTrigStmt(const AlterEventTrigStmt *a, const AlterEventTrigStmt *b)
-{
-       COMPARE_STRING_FIELD(trigname);
-       COMPARE_SCALAR_FIELD(tgenabled);
-
-       return true;
-}
-
-static bool
-_equalCreatePLangStmt(const CreatePLangStmt *a, const CreatePLangStmt *b)
-{
-       COMPARE_SCALAR_FIELD(replace);
-       COMPARE_STRING_FIELD(plname);
-       COMPARE_NODE_FIELD(plhandler);
-       COMPARE_NODE_FIELD(plinline);
-       COMPARE_NODE_FIELD(plvalidator);
-       COMPARE_SCALAR_FIELD(pltrusted);
-
-       return true;
-}
-
-static bool
-_equalCreateRoleStmt(const CreateRoleStmt *a, const CreateRoleStmt *b)
-{
-       COMPARE_SCALAR_FIELD(stmt_type);
-       COMPARE_STRING_FIELD(role);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterRoleStmt(const AlterRoleStmt *a, const AlterRoleStmt *b)
-{
-       COMPARE_NODE_FIELD(role);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_SCALAR_FIELD(action);
-
-       return true;
-}
-
-static bool
-_equalAlterRoleSetStmt(const AlterRoleSetStmt *a, const AlterRoleSetStmt *b)
-{
-       COMPARE_NODE_FIELD(role);
-       COMPARE_STRING_FIELD(database);
-       COMPARE_NODE_FIELD(setstmt);
-
-       return true;
-}
-
-static bool
-_equalDropRoleStmt(const DropRoleStmt *a, const DropRoleStmt *b)
-{
-       COMPARE_NODE_FIELD(roles);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalLockStmt(const LockStmt *a, const LockStmt *b)
-{
-       COMPARE_NODE_FIELD(relations);
-       COMPARE_SCALAR_FIELD(mode);
-       COMPARE_SCALAR_FIELD(nowait);
-
-       return true;
-}
-
-static bool
-_equalConstraintsSetStmt(const ConstraintsSetStmt *a, const ConstraintsSetStmt *b)
-{
-       COMPARE_NODE_FIELD(constraints);
-       COMPARE_SCALAR_FIELD(deferred);
-
-       return true;
-}
-
-static bool
-_equalReindexStmt(const ReindexStmt *a, const ReindexStmt *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(params);
-
-       return true;
-}
-
-static bool
-_equalCreateSchemaStmt(const CreateSchemaStmt *a, const CreateSchemaStmt *b)
-{
-       COMPARE_STRING_FIELD(schemaname);
-       COMPARE_NODE_FIELD(authrole);
-       COMPARE_NODE_FIELD(schemaElts);
-       COMPARE_SCALAR_FIELD(if_not_exists);
-
-       return true;
-}
-
-static bool
-_equalCreateConversionStmt(const CreateConversionStmt *a, const CreateConversionStmt *b)
-{
-       COMPARE_NODE_FIELD(conversion_name);
-       COMPARE_STRING_FIELD(for_encoding_name);
-       COMPARE_STRING_FIELD(to_encoding_name);
-       COMPARE_NODE_FIELD(func_name);
-       COMPARE_SCALAR_FIELD(def);
-
-       return true;
-}
-
-static bool
-_equalCreateCastStmt(const CreateCastStmt *a, const CreateCastStmt *b)
-{
-       COMPARE_NODE_FIELD(sourcetype);
-       COMPARE_NODE_FIELD(targettype);
-       COMPARE_NODE_FIELD(func);
-       COMPARE_SCALAR_FIELD(context);
-       COMPARE_SCALAR_FIELD(inout);
-
-       return true;
-}
-
-static bool
-_equalPrepareStmt(const PrepareStmt *a, const PrepareStmt *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(argtypes);
-       COMPARE_NODE_FIELD(query);
-
-       return true;
-}
-
-static bool
-_equalExecuteStmt(const ExecuteStmt *a, const ExecuteStmt *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(params);
-
-       return true;
-}
-
-static bool
-_equalDeallocateStmt(const DeallocateStmt *a, const DeallocateStmt *b)
-{
-       COMPARE_STRING_FIELD(name);
-
-       return true;
-}
-
-static bool
-_equalDropOwnedStmt(const DropOwnedStmt *a, const DropOwnedStmt *b)
-{
-       COMPARE_NODE_FIELD(roles);
-       COMPARE_SCALAR_FIELD(behavior);
-
-       return true;
-}
-
-static bool
-_equalReassignOwnedStmt(const ReassignOwnedStmt *a, const ReassignOwnedStmt *b)
-{
-       COMPARE_NODE_FIELD(roles);
-       COMPARE_NODE_FIELD(newrole);
-
-       return true;
-}
-
-static bool
-_equalAlterTSDictionaryStmt(const AlterTSDictionaryStmt *a, const AlterTSDictionaryStmt *b)
-{
-       COMPARE_NODE_FIELD(dictname);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterTSConfigurationStmt(const AlterTSConfigurationStmt *a,
-                                                          const AlterTSConfigurationStmt *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_NODE_FIELD(cfgname);
-       COMPARE_NODE_FIELD(tokentype);
-       COMPARE_NODE_FIELD(dicts);
-       COMPARE_SCALAR_FIELD(override);
-       COMPARE_SCALAR_FIELD(replace);
-       COMPARE_SCALAR_FIELD(missing_ok);
-
-       return true;
-}
-
-static bool
-_equalPublicationObject(const PublicationObjSpec *a,
-                                               const PublicationObjSpec *b)
-{
-       COMPARE_SCALAR_FIELD(pubobjtype);
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(pubtable);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalPublicationTable(const PublicationTable *a, const PublicationTable *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_NODE_FIELD(columns);
-
-       return true;
-}
-
-static bool
-_equalCreatePublicationStmt(const CreatePublicationStmt *a,
-                                                       const CreatePublicationStmt *b)
-{
-       COMPARE_STRING_FIELD(pubname);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_NODE_FIELD(pubobjects);
-       COMPARE_SCALAR_FIELD(for_all_tables);
-
-       return true;
-}
-
-static bool
-_equalAlterPublicationStmt(const AlterPublicationStmt *a,
-                                                  const AlterPublicationStmt *b)
-{
-       COMPARE_STRING_FIELD(pubname);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_NODE_FIELD(pubobjects);
-       COMPARE_SCALAR_FIELD(for_all_tables);
-       COMPARE_SCALAR_FIELD(action);
-
-       return true;
-}
-
-static bool
-_equalCreateSubscriptionStmt(const CreateSubscriptionStmt *a,
-                                                        const CreateSubscriptionStmt *b)
-{
-       COMPARE_STRING_FIELD(subname);
-       COMPARE_STRING_FIELD(conninfo);
-       COMPARE_NODE_FIELD(publication);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalAlterSubscriptionStmt(const AlterSubscriptionStmt *a,
-                                                       const AlterSubscriptionStmt *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_STRING_FIELD(subname);
-       COMPARE_STRING_FIELD(conninfo);
-       COMPARE_NODE_FIELD(publication);
-       COMPARE_NODE_FIELD(options);
-
-       return true;
-}
-
-static bool
-_equalDropSubscriptionStmt(const DropSubscriptionStmt *a,
-                                                  const DropSubscriptionStmt *b)
-{
-       COMPARE_STRING_FIELD(subname);
-       COMPARE_SCALAR_FIELD(missing_ok);
-       COMPARE_SCALAR_FIELD(behavior);
-
-       return true;
-}
-
-static bool
-_equalCreatePolicyStmt(const CreatePolicyStmt *a, const CreatePolicyStmt *b)
-{
-       COMPARE_STRING_FIELD(policy_name);
-       COMPARE_NODE_FIELD(table);
-       COMPARE_STRING_FIELD(cmd_name);
-       COMPARE_SCALAR_FIELD(permissive);
-       COMPARE_NODE_FIELD(roles);
-       COMPARE_NODE_FIELD(qual);
-       COMPARE_NODE_FIELD(with_check);
-
-       return true;
-}
-
-static bool
-_equalAlterPolicyStmt(const AlterPolicyStmt *a, const AlterPolicyStmt *b)
-{
-       COMPARE_STRING_FIELD(policy_name);
-       COMPARE_NODE_FIELD(table);
-       COMPARE_NODE_FIELD(roles);
-       COMPARE_NODE_FIELD(qual);
-       COMPARE_NODE_FIELD(with_check);
-
-       return true;
-}
-
-static bool
-_equalA_Expr(const A_Expr *a, const A_Expr *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_NODE_FIELD(name);
-       COMPARE_NODE_FIELD(lexpr);
-       COMPARE_NODE_FIELD(rexpr);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalColumnRef(const ColumnRef *a, const ColumnRef *b)
-{
-       COMPARE_NODE_FIELD(fields);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalParamRef(const ParamRef *a, const ParamRef *b)
-{
-       COMPARE_SCALAR_FIELD(number);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-#endif                                                 /* OBSOLETE */
-
-static bool
-_equalA_Const(const A_Const *a, const A_Const *b)
-{
-       /*
-        * Hack for in-line val field.  Also val is not valid is isnull is true.
-        */
-       if (!a->isnull && !b->isnull &&
-               !equal(&a->val, &b->val))
-               return false;
-       COMPARE_SCALAR_FIELD(isnull);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-#ifdef OBSOLETE
-static bool
-_equalFuncCall(const FuncCall *a, const FuncCall *b)
-{
-       COMPARE_NODE_FIELD(funcname);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(agg_order);
-       COMPARE_NODE_FIELD(agg_filter);
-       COMPARE_NODE_FIELD(over);
-       COMPARE_SCALAR_FIELD(agg_within_group);
-       COMPARE_SCALAR_FIELD(agg_star);
-       COMPARE_SCALAR_FIELD(agg_distinct);
-       COMPARE_SCALAR_FIELD(func_variadic);
-       COMPARE_COERCIONFORM_FIELD(funcformat);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalA_Star(const A_Star *a, const A_Star *b)
-{
-       return true;
-}
-
-static bool
-_equalA_Indices(const A_Indices *a, const A_Indices *b)
-{
-       COMPARE_SCALAR_FIELD(is_slice);
-       COMPARE_NODE_FIELD(lidx);
-       COMPARE_NODE_FIELD(uidx);
-
-       return true;
-}
-
-static bool
-_equalA_Indirection(const A_Indirection *a, const A_Indirection *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_NODE_FIELD(indirection);
-
-       return true;
-}
-
-static bool
-_equalA_ArrayExpr(const A_ArrayExpr *a, const A_ArrayExpr *b)
-{
-       COMPARE_NODE_FIELD(elements);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalResTarget(const ResTarget *a, const ResTarget *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(indirection);
-       COMPARE_NODE_FIELD(val);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalMultiAssignRef(const MultiAssignRef *a, const MultiAssignRef *b)
-{
-       COMPARE_NODE_FIELD(source);
-       COMPARE_SCALAR_FIELD(colno);
-       COMPARE_SCALAR_FIELD(ncolumns);
-
-       return true;
-}
-
-static bool
-_equalTypeName(const TypeName *a, const TypeName *b)
-{
-       COMPARE_NODE_FIELD(names);
-       COMPARE_SCALAR_FIELD(typeOid);
-       COMPARE_SCALAR_FIELD(setof);
-       COMPARE_SCALAR_FIELD(pct_type);
-       COMPARE_NODE_FIELD(typmods);
-       COMPARE_SCALAR_FIELD(typemod);
-       COMPARE_NODE_FIELD(arrayBounds);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalTypeCast(const TypeCast *a, const TypeCast *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCollateClause(const CollateClause *a, const CollateClause *b)
-{
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_NODE_FIELD(collname);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalSortBy(const SortBy *a, const SortBy *b)
-{
-       COMPARE_NODE_FIELD(node);
-       COMPARE_SCALAR_FIELD(sortby_dir);
-       COMPARE_SCALAR_FIELD(sortby_nulls);
-       COMPARE_NODE_FIELD(useOp);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalWindowDef(const WindowDef *a, const WindowDef *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_STRING_FIELD(refname);
-       COMPARE_NODE_FIELD(partitionClause);
-       COMPARE_NODE_FIELD(orderClause);
-       COMPARE_SCALAR_FIELD(frameOptions);
-       COMPARE_NODE_FIELD(startOffset);
-       COMPARE_NODE_FIELD(endOffset);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalRangeSubselect(const RangeSubselect *a, const RangeSubselect *b)
-{
-       COMPARE_SCALAR_FIELD(lateral);
-       COMPARE_NODE_FIELD(subquery);
-       COMPARE_NODE_FIELD(alias);
-
-       return true;
-}
-
-static bool
-_equalRangeFunction(const RangeFunction *a, const RangeFunction *b)
-{
-       COMPARE_SCALAR_FIELD(lateral);
-       COMPARE_SCALAR_FIELD(ordinality);
-       COMPARE_SCALAR_FIELD(is_rowsfrom);
-       COMPARE_NODE_FIELD(functions);
-       COMPARE_NODE_FIELD(alias);
-       COMPARE_NODE_FIELD(coldeflist);
-
-       return true;
-}
-
-static bool
-_equalRangeTableSample(const RangeTableSample *a, const RangeTableSample *b)
-{
-       COMPARE_NODE_FIELD(relation);
-       COMPARE_NODE_FIELD(method);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(repeatable);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalRangeTableFunc(const RangeTableFunc *a, const RangeTableFunc *b)
-{
-       COMPARE_SCALAR_FIELD(lateral);
-       COMPARE_NODE_FIELD(docexpr);
-       COMPARE_NODE_FIELD(rowexpr);
-       COMPARE_NODE_FIELD(namespaces);
-       COMPARE_NODE_FIELD(columns);
-       COMPARE_NODE_FIELD(alias);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalRangeTableFuncCol(const RangeTableFuncCol *a, const RangeTableFuncCol *b)
-{
-       COMPARE_STRING_FIELD(colname);
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_SCALAR_FIELD(for_ordinality);
-       COMPARE_SCALAR_FIELD(is_not_null);
-       COMPARE_NODE_FIELD(colexpr);
-       COMPARE_NODE_FIELD(coldefexpr);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-
-static bool
-_equalIndexElem(const IndexElem *a, const IndexElem *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_STRING_FIELD(indexcolname);
-       COMPARE_NODE_FIELD(collation);
-       COMPARE_NODE_FIELD(opclass);
-       COMPARE_NODE_FIELD(opclassopts);
-       COMPARE_SCALAR_FIELD(ordering);
-       COMPARE_SCALAR_FIELD(nulls_ordering);
-
-       return true;
-}
-
-
-static bool
-_equalStatsElem(const StatsElem *a, const StatsElem *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(expr);
-
-       return true;
-}
-
-static bool
-_equalColumnDef(const ColumnDef *a, const ColumnDef *b)
-{
-       COMPARE_STRING_FIELD(colname);
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_STRING_FIELD(compression);
-       COMPARE_SCALAR_FIELD(inhcount);
-       COMPARE_SCALAR_FIELD(is_local);
-       COMPARE_SCALAR_FIELD(is_not_null);
-       COMPARE_SCALAR_FIELD(is_from_type);
-       COMPARE_SCALAR_FIELD(storage);
-       COMPARE_NODE_FIELD(raw_default);
-       COMPARE_NODE_FIELD(cooked_default);
-       COMPARE_SCALAR_FIELD(identity);
-       COMPARE_NODE_FIELD(identitySequence);
-       COMPARE_SCALAR_FIELD(generated);
-       COMPARE_NODE_FIELD(collClause);
-       COMPARE_SCALAR_FIELD(collOid);
-       COMPARE_NODE_FIELD(constraints);
-       COMPARE_NODE_FIELD(fdwoptions);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalConstraint(const Constraint *a, const Constraint *b)
-{
-       COMPARE_SCALAR_FIELD(contype);
-       COMPARE_STRING_FIELD(conname);
-       COMPARE_SCALAR_FIELD(deferrable);
-       COMPARE_SCALAR_FIELD(initdeferred);
-       COMPARE_LOCATION_FIELD(location);
-       COMPARE_SCALAR_FIELD(is_no_inherit);
-       COMPARE_NODE_FIELD(raw_expr);
-       COMPARE_STRING_FIELD(cooked_expr);
-       COMPARE_SCALAR_FIELD(generated_when);
-       COMPARE_SCALAR_FIELD(nulls_not_distinct);
-       COMPARE_NODE_FIELD(keys);
-       COMPARE_NODE_FIELD(including);
-       COMPARE_NODE_FIELD(exclusions);
-       COMPARE_NODE_FIELD(options);
-       COMPARE_STRING_FIELD(indexname);
-       COMPARE_STRING_FIELD(indexspace);
-       COMPARE_SCALAR_FIELD(reset_default_tblspc);
-       COMPARE_STRING_FIELD(access_method);
-       COMPARE_NODE_FIELD(where_clause);
-       COMPARE_NODE_FIELD(pktable);
-       COMPARE_NODE_FIELD(fk_attrs);
-       COMPARE_NODE_FIELD(pk_attrs);
-       COMPARE_SCALAR_FIELD(fk_matchtype);
-       COMPARE_SCALAR_FIELD(fk_upd_action);
-       COMPARE_SCALAR_FIELD(fk_del_action);
-       COMPARE_NODE_FIELD(fk_del_set_cols);
-       COMPARE_NODE_FIELD(old_conpfeqop);
-       COMPARE_SCALAR_FIELD(old_pktable_oid);
-       COMPARE_SCALAR_FIELD(skip_validation);
-       COMPARE_SCALAR_FIELD(initially_valid);
-
-       return true;
-}
-
-static bool
-_equalDefElem(const DefElem *a, const DefElem *b)
-{
-       COMPARE_STRING_FIELD(defnamespace);
-       COMPARE_STRING_FIELD(defname);
-       COMPARE_NODE_FIELD(arg);
-       COMPARE_SCALAR_FIELD(defaction);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalLockingClause(const LockingClause *a, const LockingClause *b)
-{
-       COMPARE_NODE_FIELD(lockedRels);
-       COMPARE_SCALAR_FIELD(strength);
-       COMPARE_SCALAR_FIELD(waitPolicy);
-
-       return true;
-}
-
-static bool
-_equalRangeTblEntry(const RangeTblEntry *a, const RangeTblEntry *b)
-{
-       COMPARE_SCALAR_FIELD(rtekind);
-       COMPARE_SCALAR_FIELD(relid);
-       COMPARE_SCALAR_FIELD(relkind);
-       COMPARE_SCALAR_FIELD(rellockmode);
-       COMPARE_NODE_FIELD(tablesample);
-       COMPARE_NODE_FIELD(subquery);
-       COMPARE_SCALAR_FIELD(security_barrier);
-       COMPARE_SCALAR_FIELD(jointype);
-       COMPARE_SCALAR_FIELD(joinmergedcols);
-       COMPARE_NODE_FIELD(joinaliasvars);
-       COMPARE_NODE_FIELD(joinleftcols);
-       COMPARE_NODE_FIELD(joinrightcols);
-       COMPARE_NODE_FIELD(join_using_alias);
-       COMPARE_NODE_FIELD(functions);
-       COMPARE_SCALAR_FIELD(funcordinality);
-       COMPARE_NODE_FIELD(tablefunc);
-       COMPARE_NODE_FIELD(values_lists);
-       COMPARE_STRING_FIELD(ctename);
-       COMPARE_SCALAR_FIELD(ctelevelsup);
-       COMPARE_SCALAR_FIELD(self_reference);
-       COMPARE_NODE_FIELD(coltypes);
-       COMPARE_NODE_FIELD(coltypmods);
-       COMPARE_NODE_FIELD(colcollations);
-       COMPARE_STRING_FIELD(enrname);
-       COMPARE_SCALAR_FIELD(enrtuples);
-       COMPARE_NODE_FIELD(alias);
-       COMPARE_NODE_FIELD(eref);
-       COMPARE_SCALAR_FIELD(lateral);
-       COMPARE_SCALAR_FIELD(inh);
-       COMPARE_SCALAR_FIELD(inFromCl);
-       COMPARE_SCALAR_FIELD(requiredPerms);
-       COMPARE_SCALAR_FIELD(checkAsUser);
-       COMPARE_BITMAPSET_FIELD(selectedCols);
-       COMPARE_BITMAPSET_FIELD(insertedCols);
-       COMPARE_BITMAPSET_FIELD(updatedCols);
-       COMPARE_BITMAPSET_FIELD(extraUpdatedCols);
-       COMPARE_NODE_FIELD(securityQuals);
-
-       return true;
-}
-
-static bool
-_equalRangeTblFunction(const RangeTblFunction *a, const RangeTblFunction *b)
-{
-       COMPARE_NODE_FIELD(funcexpr);
-       COMPARE_SCALAR_FIELD(funccolcount);
-       COMPARE_NODE_FIELD(funccolnames);
-       COMPARE_NODE_FIELD(funccoltypes);
-       COMPARE_NODE_FIELD(funccoltypmods);
-       COMPARE_NODE_FIELD(funccolcollations);
-       COMPARE_BITMAPSET_FIELD(funcparams);
-
-       return true;
-}
-
-static bool
-_equalTableSampleClause(const TableSampleClause *a, const TableSampleClause *b)
-{
-       COMPARE_SCALAR_FIELD(tsmhandler);
-       COMPARE_NODE_FIELD(args);
-       COMPARE_NODE_FIELD(repeatable);
-
-       return true;
-}
-
-static bool
-_equalWithCheckOption(const WithCheckOption *a, const WithCheckOption *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_STRING_FIELD(relname);
-       COMPARE_STRING_FIELD(polname);
-       COMPARE_NODE_FIELD(qual);
-       COMPARE_SCALAR_FIELD(cascaded);
-
-       return true;
-}
-
-static bool
-_equalSortGroupClause(const SortGroupClause *a, const SortGroupClause *b)
-{
-       COMPARE_SCALAR_FIELD(tleSortGroupRef);
-       COMPARE_SCALAR_FIELD(eqop);
-       COMPARE_SCALAR_FIELD(sortop);
-       COMPARE_SCALAR_FIELD(nulls_first);
-       COMPARE_SCALAR_FIELD(hashable);
-
-       return true;
-}
-
-static bool
-_equalGroupingSet(const GroupingSet *a, const GroupingSet *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_NODE_FIELD(content);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalWindowClause(const WindowClause *a, const WindowClause *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_STRING_FIELD(refname);
-       COMPARE_NODE_FIELD(partitionClause);
-       COMPARE_NODE_FIELD(orderClause);
-       COMPARE_SCALAR_FIELD(frameOptions);
-       COMPARE_NODE_FIELD(startOffset);
-       COMPARE_NODE_FIELD(endOffset);
-       COMPARE_NODE_FIELD(runCondition);
-       COMPARE_SCALAR_FIELD(startInRangeFunc);
-       COMPARE_SCALAR_FIELD(endInRangeFunc);
-       COMPARE_SCALAR_FIELD(inRangeColl);
-       COMPARE_SCALAR_FIELD(inRangeAsc);
-       COMPARE_SCALAR_FIELD(inRangeNullsFirst);
-       COMPARE_SCALAR_FIELD(winref);
-       COMPARE_SCALAR_FIELD(copiedOrder);
-
-       return true;
-}
-
-static bool
-_equalRowMarkClause(const RowMarkClause *a, const RowMarkClause *b)
-{
-       COMPARE_SCALAR_FIELD(rti);
-       COMPARE_SCALAR_FIELD(strength);
-       COMPARE_SCALAR_FIELD(waitPolicy);
-       COMPARE_SCALAR_FIELD(pushedDown);
-
-       return true;
-}
-
-static bool
-_equalWithClause(const WithClause *a, const WithClause *b)
-{
-       COMPARE_NODE_FIELD(ctes);
-       COMPARE_SCALAR_FIELD(recursive);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalInferClause(const InferClause *a, const InferClause *b)
-{
-       COMPARE_NODE_FIELD(indexElems);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_STRING_FIELD(conname);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalOnConflictClause(const OnConflictClause *a, const OnConflictClause *b)
-{
-       COMPARE_SCALAR_FIELD(action);
-       COMPARE_NODE_FIELD(infer);
-       COMPARE_NODE_FIELD(targetList);
-       COMPARE_NODE_FIELD(whereClause);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCTESearchClause(const CTESearchClause *a, const CTESearchClause *b)
-{
-       COMPARE_NODE_FIELD(search_col_list);
-       COMPARE_SCALAR_FIELD(search_breadth_first);
-       COMPARE_STRING_FIELD(search_seq_column);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalCTECycleClause(const CTECycleClause *a, const CTECycleClause *b)
-{
-       COMPARE_NODE_FIELD(cycle_col_list);
-       COMPARE_STRING_FIELD(cycle_mark_column);
-       COMPARE_NODE_FIELD(cycle_mark_value);
-       COMPARE_NODE_FIELD(cycle_mark_default);
-       COMPARE_STRING_FIELD(cycle_path_column);
-       COMPARE_LOCATION_FIELD(location);
-       COMPARE_SCALAR_FIELD(cycle_mark_type);
-       COMPARE_SCALAR_FIELD(cycle_mark_typmod);
-       COMPARE_SCALAR_FIELD(cycle_mark_collation);
-       COMPARE_SCALAR_FIELD(cycle_mark_neop);
-
-       return true;
-}
-
-static bool
-_equalCommonTableExpr(const CommonTableExpr *a, const CommonTableExpr *b)
-{
-       COMPARE_STRING_FIELD(ctename);
-       COMPARE_NODE_FIELD(aliascolnames);
-       COMPARE_SCALAR_FIELD(ctematerialized);
-       COMPARE_NODE_FIELD(ctequery);
-       COMPARE_NODE_FIELD(search_clause);
-       COMPARE_NODE_FIELD(cycle_clause);
-       COMPARE_LOCATION_FIELD(location);
-       COMPARE_SCALAR_FIELD(cterecursive);
-       COMPARE_SCALAR_FIELD(cterefcount);
-       COMPARE_NODE_FIELD(ctecolnames);
-       COMPARE_NODE_FIELD(ctecoltypes);
-       COMPARE_NODE_FIELD(ctecoltypmods);
-       COMPARE_NODE_FIELD(ctecolcollations);
-
-       return true;
-}
-
-static bool
-_equalMergeWhenClause(const MergeWhenClause *a, const MergeWhenClause *b)
-{
-       COMPARE_SCALAR_FIELD(matched);
-       COMPARE_SCALAR_FIELD(commandType);
-       COMPARE_SCALAR_FIELD(override);
-       COMPARE_NODE_FIELD(condition);
-       COMPARE_NODE_FIELD(targetList);
-       COMPARE_NODE_FIELD(values);
-
-       return true;
-}
-
-static bool
-_equalMergeAction(const MergeAction *a, const MergeAction *b)
-{
-       COMPARE_SCALAR_FIELD(matched);
-       COMPARE_SCALAR_FIELD(commandType);
-       COMPARE_SCALAR_FIELD(override);
-       COMPARE_NODE_FIELD(qual);
-       COMPARE_NODE_FIELD(targetList);
-       COMPARE_NODE_FIELD(updateColnos);
-
-       return true;
-}
-
-static bool
-_equalXmlSerialize(const XmlSerialize *a, const XmlSerialize *b)
-{
-       COMPARE_SCALAR_FIELD(xmloption);
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(typeName);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalRoleSpec(const RoleSpec *a, const RoleSpec *b)
-{
-       COMPARE_SCALAR_FIELD(roletype);
-       COMPARE_STRING_FIELD(rolename);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalTriggerTransition(const TriggerTransition *a, const TriggerTransition *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_SCALAR_FIELD(isNew);
-       COMPARE_SCALAR_FIELD(isTable);
-
-       return true;
-}
-
-static bool
-_equalPartitionElem(const PartitionElem *a, const PartitionElem *b)
-{
-       COMPARE_STRING_FIELD(name);
-       COMPARE_NODE_FIELD(expr);
-       COMPARE_NODE_FIELD(collation);
-       COMPARE_NODE_FIELD(opclass);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalPartitionSpec(const PartitionSpec *a, const PartitionSpec *b)
-{
-       COMPARE_STRING_FIELD(strategy);
-       COMPARE_NODE_FIELD(partParams);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalPartitionBoundSpec(const PartitionBoundSpec *a, const PartitionBoundSpec *b)
-{
-       COMPARE_SCALAR_FIELD(strategy);
-       COMPARE_SCALAR_FIELD(is_default);
-       COMPARE_SCALAR_FIELD(modulus);
-       COMPARE_SCALAR_FIELD(remainder);
-       COMPARE_NODE_FIELD(listdatums);
-       COMPARE_NODE_FIELD(lowerdatums);
-       COMPARE_NODE_FIELD(upperdatums);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalPartitionRangeDatum(const PartitionRangeDatum *a, const PartitionRangeDatum *b)
-{
-       COMPARE_SCALAR_FIELD(kind);
-       COMPARE_NODE_FIELD(value);
-       COMPARE_LOCATION_FIELD(location);
-
-       return true;
-}
-
-static bool
-_equalPartitionCmd(const PartitionCmd *a, const PartitionCmd *b)
-{
-       COMPARE_NODE_FIELD(name);
-       COMPARE_NODE_FIELD(bound);
-       COMPARE_SCALAR_FIELD(concurrent);
-
-       return true;
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * Stuff from pg_list.h
- */
-
-static bool
-_equalList(const List *a, const List *b)
-{
-       const ListCell *item_a;
-       const ListCell *item_b;
-
-       /*
-        * Try to reject by simple scalar checks before grovelling through all the
-        * list elements...
-        */
-       COMPARE_SCALAR_FIELD(type);
-       COMPARE_SCALAR_FIELD(length);
-
-       /*
-        * We place the switch outside the loop for the sake of efficiency; this
-        * may not be worth doing...
-        */
-       switch (a->type)
-       {
-               case T_List:
-                       forboth(item_a, a, item_b, b)
-                       {
-                               if (!equal(lfirst(item_a), lfirst(item_b)))
-                                       return false;
-                       }
-                       break;
-               case T_IntList:
-                       forboth(item_a, a, item_b, b)
-                       {
-                               if (lfirst_int(item_a) != lfirst_int(item_b))
-                                       return false;
-                       }
-                       break;
-               case T_OidList:
-                       forboth(item_a, a, item_b, b)
-                       {
-                               if (lfirst_oid(item_a) != lfirst_oid(item_b))
-                                       return false;
-                       }
-                       break;
-               default:
-                       elog(ERROR, "unrecognized list node type: %d",
-                                (int) a->type);
-                       return false;           /* keep compiler quiet */
-       }
-
-       /*
-        * If we got here, we should have run out of elements of both lists
-        */
-       Assert(item_a == NULL);
-       Assert(item_b == NULL);
-
-       return true;
-}
-
-#ifdef OBSOLETE
-/*
- * Stuff from value.h
- */
-
-static bool
-_equalInteger(const Integer *a, const Integer *b)
-{
-       COMPARE_SCALAR_FIELD(ival);
-
-       return true;
-}
-
-static bool
-_equalFloat(const Float *a, const Float *b)
-{
-       COMPARE_STRING_FIELD(fval);
-
-       return true;
-}
-
-static bool
-_equalBoolean(const Boolean *a, const Boolean *b)
-{
-       COMPARE_SCALAR_FIELD(boolval);
-
-       return true;
-}
-
-static bool
-_equalString(const String *a, const String *b)
-{
-       COMPARE_STRING_FIELD(sval);
-
-       return true;
-}
-
-static bool
-_equalBitString(const BitString *a, const BitString *b)
-{
-       COMPARE_STRING_FIELD(bsval);
-
-       return true;
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * equal
- *       returns whether two nodes are equal
- */
-bool
-equal(const void *a, const void *b)
-{
-       bool            retval;
-
-       if (a == b)
-               return true;
-
-       /*
-        * note that a!=b, so only one of them can be NULL
-        */
-       if (a == NULL || b == NULL)
-               return false;
-
-       /*
-        * are they the same type of nodes?
-        */
-       if (nodeTag(a) != nodeTag(b))
-               return false;
-
-       /* Guard against stack overflow due to overly complex expressions */
-       check_stack_depth();
-
-       switch (nodeTag(a))
-       {
-#include "equalfuncs.switch.c"
-#ifdef OBSOLETE
-                       /*
-                        * PRIMITIVE NODES
-                        */
-               case T_Alias:
-                       retval = _equalAlias(a, b);
-                       break;
-               case T_RangeVar:
-                       retval = _equalRangeVar(a, b);
-                       break;
-               case T_TableFunc:
-                       retval = _equalTableFunc(a, b);
-                       break;
-               case T_IntoClause:
-                       retval = _equalIntoClause(a, b);
-                       break;
-               case T_Var:
-                       retval = _equalVar(a, b);
-                       break;
-               case T_Const:
-                       retval = _equalConst(a, b);
-                       break;
-               case T_Param:
-                       retval = _equalParam(a, b);
-                       break;
-               case T_Aggref:
-                       retval = _equalAggref(a, b);
-                       break;
-               case T_GroupingFunc:
-                       retval = _equalGroupingFunc(a, b);
-                       break;
-               case T_WindowFunc:
-                       retval = _equalWindowFunc(a, b);
-                       break;
-               case T_SubscriptingRef:
-                       retval = _equalSubscriptingRef(a, b);
-                       break;
-               case T_FuncExpr:
-                       retval = _equalFuncExpr(a, b);
-                       break;
-               case T_NamedArgExpr:
-                       retval = _equalNamedArgExpr(a, b);
-                       break;
-               case T_OpExpr:
-                       retval = _equalOpExpr(a, b);
-                       break;
-               case T_DistinctExpr:
-                       retval = _equalDistinctExpr(a, b);
-                       break;
-               case T_NullIfExpr:
-                       retval = _equalNullIfExpr(a, b);
-                       break;
-               case T_ScalarArrayOpExpr:
-                       retval = _equalScalarArrayOpExpr(a, b);
-                       break;
-               case T_BoolExpr:
-                       retval = _equalBoolExpr(a, b);
-                       break;
-               case T_SubLink:
-                       retval = _equalSubLink(a, b);
-                       break;
-               case T_SubPlan:
-                       retval = _equalSubPlan(a, b);
-                       break;
-               case T_AlternativeSubPlan:
-                       retval = _equalAlternativeSubPlan(a, b);
-                       break;
-               case T_FieldSelect:
-                       retval = _equalFieldSelect(a, b);
-                       break;
-               case T_FieldStore:
-                       retval = _equalFieldStore(a, b);
-                       break;
-               case T_RelabelType:
-                       retval = _equalRelabelType(a, b);
-                       break;
-               case T_CoerceViaIO:
-                       retval = _equalCoerceViaIO(a, b);
-                       break;
-               case T_ArrayCoerceExpr:
-                       retval = _equalArrayCoerceExpr(a, b);
-                       break;
-               case T_ConvertRowtypeExpr:
-                       retval = _equalConvertRowtypeExpr(a, b);
-                       break;
-               case T_CollateExpr:
-                       retval = _equalCollateExpr(a, b);
-                       break;
-               case T_CaseExpr:
-                       retval = _equalCaseExpr(a, b);
-                       break;
-               case T_CaseWhen:
-                       retval = _equalCaseWhen(a, b);
-                       break;
-               case T_CaseTestExpr:
-                       retval = _equalCaseTestExpr(a, b);
-                       break;
-               case T_ArrayExpr:
-                       retval = _equalArrayExpr(a, b);
-                       break;
-               case T_RowExpr:
-                       retval = _equalRowExpr(a, b);
-                       break;
-               case T_RowCompareExpr:
-                       retval = _equalRowCompareExpr(a, b);
-                       break;
-               case T_CoalesceExpr:
-                       retval = _equalCoalesceExpr(a, b);
-                       break;
-               case T_MinMaxExpr:
-                       retval = _equalMinMaxExpr(a, b);
-                       break;
-               case T_SQLValueFunction:
-                       retval = _equalSQLValueFunction(a, b);
-                       break;
-               case T_XmlExpr:
-                       retval = _equalXmlExpr(a, b);
-                       break;
-               case T_NullTest:
-                       retval = _equalNullTest(a, b);
-                       break;
-               case T_BooleanTest:
-                       retval = _equalBooleanTest(a, b);
-                       break;
-               case T_CoerceToDomain:
-                       retval = _equalCoerceToDomain(a, b);
-                       break;
-               case T_CoerceToDomainValue:
-                       retval = _equalCoerceToDomainValue(a, b);
-                       break;
-               case T_SetToDefault:
-                       retval = _equalSetToDefault(a, b);
-                       break;
-               case T_CurrentOfExpr:
-                       retval = _equalCurrentOfExpr(a, b);
-                       break;
-               case T_NextValueExpr:
-                       retval = _equalNextValueExpr(a, b);
-                       break;
-               case T_InferenceElem:
-                       retval = _equalInferenceElem(a, b);
-                       break;
-               case T_TargetEntry:
-                       retval = _equalTargetEntry(a, b);
-                       break;
-               case T_RangeTblRef:
-                       retval = _equalRangeTblRef(a, b);
-                       break;
-               case T_FromExpr:
-                       retval = _equalFromExpr(a, b);
-                       break;
-               case T_OnConflictExpr:
-                       retval = _equalOnConflictExpr(a, b);
-                       break;
-               case T_JoinExpr:
-                       retval = _equalJoinExpr(a, b);
-                       break;
-               case T_JsonFormat:
-                       retval = _equalJsonFormat(a, b);
-                       break;
-               case T_JsonReturning:
-                       retval = _equalJsonReturning(a, b);
-                       break;
-               case T_JsonValueExpr:
-                       retval = _equalJsonValueExpr(a, b);
-                       break;
-               case T_JsonParseExpr:
-                       retval = _equalJsonParseExpr(a, b);
-                       break;
-               case T_JsonScalarExpr:
-                       retval = _equalJsonScalarExpr(a, b);
-                       break;
-               case T_JsonSerializeExpr:
-                       retval = _equalJsonSerializeExpr(a, b);
-                       break;
-               case T_JsonConstructorExpr:
-                       retval = _equalJsonConstructorExpr(a, b);
-                       break;
-               case T_JsonIsPredicate:
-                       retval = _equalJsonIsPredicate(a, b);
-                       break;
-               case T_JsonBehavior:
-                       retval = _equalJsonBehavior(a, b);
-                       break;
-               case T_JsonExpr:
-                       retval = _equalJsonExpr(a, b);
-                       break;
-               case T_JsonCoercion:
-                       retval = _equalJsonCoercion(a, b);
-                       break;
-               case T_JsonItemCoercions:
-                       retval = _equalJsonItemCoercions(a, b);
-                       break;
-               case T_JsonTableParent:
-                       retval = _equalJsonTableParent(a, b);
-                       break;
-               case T_JsonTableSibling:
-                       retval = _equalJsonTableSibling(a, b);
-                       break;
-
-                       /*
-                        * RELATION NODES
-                        */
-               case T_PathKey:
-                       retval = _equalPathKey(a, b);
-                       break;
-               case T_RestrictInfo:
-                       retval = _equalRestrictInfo(a, b);
-                       break;
-               case T_PlaceHolderVar:
-                       retval = _equalPlaceHolderVar(a, b);
-                       break;
-               case T_SpecialJoinInfo:
-                       retval = _equalSpecialJoinInfo(a, b);
-                       break;
-               case T_AppendRelInfo:
-                       retval = _equalAppendRelInfo(a, b);
-                       break;
-               case T_PlaceHolderInfo:
-                       retval = _equalPlaceHolderInfo(a, b);
-                       break;
-#endif                                                 /* OBSOLETE */
+       switch (nodeTag(a))
+       {
+#include "equalfuncs.switch.c"
 
                case T_List:
                case T_IntList:
@@ -3838,611 +241,6 @@ equal(const void *a, const void *b)
                        retval = _equalList(a, b);
                        break;
 
-#ifdef OBSOLETE
-               case T_Integer:
-                       retval = _equalInteger(a, b);
-                       break;
-               case T_Float:
-                       retval = _equalFloat(a, b);
-                       break;
-               case T_Boolean:
-                       retval = _equalBoolean(a, b);
-                       break;
-               case T_String:
-                       retval = _equalString(a, b);
-                       break;
-               case T_BitString:
-                       retval = _equalBitString(a, b);
-                       break;
-
-                       /*
-                        * EXTENSIBLE NODES
-                        */
-               case T_ExtensibleNode:
-                       retval = _equalExtensibleNode(a, b);
-                       break;
-
-                       /*
-                        * PARSE NODES
-                        */
-               case T_Query:
-                       retval = _equalQuery(a, b);
-                       break;
-               case T_RawStmt:
-                       retval = _equalRawStmt(a, b);
-                       break;
-               case T_InsertStmt:
-                       retval = _equalInsertStmt(a, b);
-                       break;
-               case T_DeleteStmt:
-                       retval = _equalDeleteStmt(a, b);
-                       break;
-               case T_UpdateStmt:
-                       retval = _equalUpdateStmt(a, b);
-                       break;
-               case T_MergeStmt:
-                       retval = _equalMergeStmt(a, b);
-                       break;
-               case T_SelectStmt:
-                       retval = _equalSelectStmt(a, b);
-                       break;
-               case T_SetOperationStmt:
-                       retval = _equalSetOperationStmt(a, b);
-                       break;
-               case T_ReturnStmt:
-                       retval = _equalReturnStmt(a, b);
-                       break;
-               case T_PLAssignStmt:
-                       retval = _equalPLAssignStmt(a, b);
-                       break;
-               case T_AlterTableStmt:
-                       retval = _equalAlterTableStmt(a, b);
-                       break;
-               case T_AlterTableCmd:
-                       retval = _equalAlterTableCmd(a, b);
-                       break;
-               case T_AlterCollationStmt:
-                       retval = _equalAlterCollationStmt(a, b);
-                       break;
-               case T_AlterDomainStmt:
-                       retval = _equalAlterDomainStmt(a, b);
-                       break;
-               case T_GrantStmt:
-                       retval = _equalGrantStmt(a, b);
-                       break;
-               case T_GrantRoleStmt:
-                       retval = _equalGrantRoleStmt(a, b);
-                       break;
-               case T_AlterDefaultPrivilegesStmt:
-                       retval = _equalAlterDefaultPrivilegesStmt(a, b);
-                       break;
-               case T_DeclareCursorStmt:
-                       retval = _equalDeclareCursorStmt(a, b);
-                       break;
-               case T_ClosePortalStmt:
-                       retval = _equalClosePortalStmt(a, b);
-                       break;
-               case T_CallStmt:
-                       retval = _equalCallStmt(a, b);
-                       break;
-               case T_ClusterStmt:
-                       retval = _equalClusterStmt(a, b);
-                       break;
-               case T_CopyStmt:
-                       retval = _equalCopyStmt(a, b);
-                       break;
-               case T_CreateStmt:
-                       retval = _equalCreateStmt(a, b);
-                       break;
-               case T_TableLikeClause:
-                       retval = _equalTableLikeClause(a, b);
-                       break;
-               case T_DefineStmt:
-                       retval = _equalDefineStmt(a, b);
-                       break;
-               case T_DropStmt:
-                       retval = _equalDropStmt(a, b);
-                       break;
-               case T_TruncateStmt:
-                       retval = _equalTruncateStmt(a, b);
-                       break;
-               case T_CommentStmt:
-                       retval = _equalCommentStmt(a, b);
-                       break;
-               case T_SecLabelStmt:
-                       retval = _equalSecLabelStmt(a, b);
-                       break;
-               case T_FetchStmt:
-                       retval = _equalFetchStmt(a, b);
-                       break;
-               case T_IndexStmt:
-                       retval = _equalIndexStmt(a, b);
-                       break;
-               case T_CreateStatsStmt:
-                       retval = _equalCreateStatsStmt(a, b);
-                       break;
-               case T_AlterStatsStmt:
-                       retval = _equalAlterStatsStmt(a, b);
-                       break;
-               case T_CreateFunctionStmt:
-                       retval = _equalCreateFunctionStmt(a, b);
-                       break;
-               case T_FunctionParameter:
-                       retval = _equalFunctionParameter(a, b);
-                       break;
-               case T_AlterFunctionStmt:
-                       retval = _equalAlterFunctionStmt(a, b);
-                       break;
-               case T_DoStmt:
-                       retval = _equalDoStmt(a, b);
-                       break;
-               case T_RenameStmt:
-                       retval = _equalRenameStmt(a, b);
-                       break;
-               case T_AlterObjectDependsStmt:
-                       retval = _equalAlterObjectDependsStmt(a, b);
-                       break;
-               case T_AlterObjectSchemaStmt:
-                       retval = _equalAlterObjectSchemaStmt(a, b);
-                       break;
-               case T_AlterOwnerStmt:
-                       retval = _equalAlterOwnerStmt(a, b);
-                       break;
-               case T_AlterOperatorStmt:
-                       retval = _equalAlterOperatorStmt(a, b);
-                       break;
-               case T_AlterTypeStmt:
-                       retval = _equalAlterTypeStmt(a, b);
-                       break;
-               case T_RuleStmt:
-                       retval = _equalRuleStmt(a, b);
-                       break;
-               case T_NotifyStmt:
-                       retval = _equalNotifyStmt(a, b);
-                       break;
-               case T_ListenStmt:
-                       retval = _equalListenStmt(a, b);
-                       break;
-               case T_UnlistenStmt:
-                       retval = _equalUnlistenStmt(a, b);
-                       break;
-               case T_TransactionStmt:
-                       retval = _equalTransactionStmt(a, b);
-                       break;
-               case T_CompositeTypeStmt:
-                       retval = _equalCompositeTypeStmt(a, b);
-                       break;
-               case T_CreateEnumStmt:
-                       retval = _equalCreateEnumStmt(a, b);
-                       break;
-               case T_CreateRangeStmt:
-                       retval = _equalCreateRangeStmt(a, b);
-                       break;
-               case T_AlterEnumStmt:
-                       retval = _equalAlterEnumStmt(a, b);
-                       break;
-               case T_ViewStmt:
-                       retval = _equalViewStmt(a, b);
-                       break;
-               case T_LoadStmt:
-                       retval = _equalLoadStmt(a, b);
-                       break;
-               case T_CreateDomainStmt:
-                       retval = _equalCreateDomainStmt(a, b);
-                       break;
-               case T_CreateOpClassStmt:
-                       retval = _equalCreateOpClassStmt(a, b);
-                       break;
-               case T_CreateOpClassItem:
-                       retval = _equalCreateOpClassItem(a, b);
-                       break;
-               case T_CreateOpFamilyStmt:
-                       retval = _equalCreateOpFamilyStmt(a, b);
-                       break;
-               case T_AlterOpFamilyStmt:
-                       retval = _equalAlterOpFamilyStmt(a, b);
-                       break;
-               case T_CreatedbStmt:
-                       retval = _equalCreatedbStmt(a, b);
-                       break;
-               case T_AlterDatabaseStmt:
-                       retval = _equalAlterDatabaseStmt(a, b);
-                       break;
-               case T_AlterDatabaseRefreshCollStmt:
-                       retval = _equalAlterDatabaseRefreshCollStmt(a, b);
-                       break;
-               case T_AlterDatabaseSetStmt:
-                       retval = _equalAlterDatabaseSetStmt(a, b);
-                       break;
-               case T_DropdbStmt:
-                       retval = _equalDropdbStmt(a, b);
-                       break;
-               case T_VacuumStmt:
-                       retval = _equalVacuumStmt(a, b);
-                       break;
-               case T_VacuumRelation:
-                       retval = _equalVacuumRelation(a, b);
-                       break;
-               case T_ExplainStmt:
-                       retval = _equalExplainStmt(a, b);
-                       break;
-               case T_CreateTableAsStmt:
-                       retval = _equalCreateTableAsStmt(a, b);
-                       break;
-               case T_RefreshMatViewStmt:
-                       retval = _equalRefreshMatViewStmt(a, b);
-                       break;
-               case T_ReplicaIdentityStmt:
-                       retval = _equalReplicaIdentityStmt(a, b);
-                       break;
-               case T_AlterSystemStmt:
-                       retval = _equalAlterSystemStmt(a, b);
-                       break;
-               case T_CreateSeqStmt:
-                       retval = _equalCreateSeqStmt(a, b);
-                       break;
-               case T_AlterSeqStmt:
-                       retval = _equalAlterSeqStmt(a, b);
-                       break;
-               case T_VariableSetStmt:
-                       retval = _equalVariableSetStmt(a, b);
-                       break;
-               case T_VariableShowStmt:
-                       retval = _equalVariableShowStmt(a, b);
-                       break;
-               case T_DiscardStmt:
-                       retval = _equalDiscardStmt(a, b);
-                       break;
-               case T_CreateTableSpaceStmt:
-                       retval = _equalCreateTableSpaceStmt(a, b);
-                       break;
-               case T_DropTableSpaceStmt:
-                       retval = _equalDropTableSpaceStmt(a, b);
-                       break;
-               case T_AlterTableSpaceOptionsStmt:
-                       retval = _equalAlterTableSpaceOptionsStmt(a, b);
-                       break;
-               case T_AlterTableMoveAllStmt:
-                       retval = _equalAlterTableMoveAllStmt(a, b);
-                       break;
-               case T_CreateExtensionStmt:
-                       retval = _equalCreateExtensionStmt(a, b);
-                       break;
-               case T_AlterExtensionStmt:
-                       retval = _equalAlterExtensionStmt(a, b);
-                       break;
-               case T_AlterExtensionContentsStmt:
-                       retval = _equalAlterExtensionContentsStmt(a, b);
-                       break;
-               case T_CreateFdwStmt:
-                       retval = _equalCreateFdwStmt(a, b);
-                       break;
-               case T_AlterFdwStmt:
-                       retval = _equalAlterFdwStmt(a, b);
-                       break;
-               case T_CreateForeignServerStmt:
-                       retval = _equalCreateForeignServerStmt(a, b);
-                       break;
-               case T_AlterForeignServerStmt:
-                       retval = _equalAlterForeignServerStmt(a, b);
-                       break;
-               case T_CreateUserMappingStmt:
-                       retval = _equalCreateUserMappingStmt(a, b);
-                       break;
-               case T_AlterUserMappingStmt:
-                       retval = _equalAlterUserMappingStmt(a, b);
-                       break;
-               case T_DropUserMappingStmt:
-                       retval = _equalDropUserMappingStmt(a, b);
-                       break;
-               case T_CreateForeignTableStmt:
-                       retval = _equalCreateForeignTableStmt(a, b);
-                       break;
-               case T_ImportForeignSchemaStmt:
-                       retval = _equalImportForeignSchemaStmt(a, b);
-                       break;
-               case T_CreateTransformStmt:
-                       retval = _equalCreateTransformStmt(a, b);
-                       break;
-               case T_CreateAmStmt:
-                       retval = _equalCreateAmStmt(a, b);
-                       break;
-               case T_CreateTrigStmt:
-                       retval = _equalCreateTrigStmt(a, b);
-                       break;
-               case T_CreateEventTrigStmt:
-                       retval = _equalCreateEventTrigStmt(a, b);
-                       break;
-               case T_AlterEventTrigStmt:
-                       retval = _equalAlterEventTrigStmt(a, b);
-                       break;
-               case T_CreatePLangStmt:
-                       retval = _equalCreatePLangStmt(a, b);
-                       break;
-               case T_CreateRoleStmt:
-                       retval = _equalCreateRoleStmt(a, b);
-                       break;
-               case T_AlterRoleStmt:
-                       retval = _equalAlterRoleStmt(a, b);
-                       break;
-               case T_AlterRoleSetStmt:
-                       retval = _equalAlterRoleSetStmt(a, b);
-                       break;
-               case T_DropRoleStmt:
-                       retval = _equalDropRoleStmt(a, b);
-                       break;
-               case T_LockStmt:
-                       retval = _equalLockStmt(a, b);
-                       break;
-               case T_ConstraintsSetStmt:
-                       retval = _equalConstraintsSetStmt(a, b);
-                       break;
-               case T_ReindexStmt:
-                       retval = _equalReindexStmt(a, b);
-                       break;
-               case T_CheckPointStmt:
-                       retval = true;
-                       break;
-               case T_CreateSchemaStmt:
-                       retval = _equalCreateSchemaStmt(a, b);
-                       break;
-               case T_CreateConversionStmt:
-                       retval = _equalCreateConversionStmt(a, b);
-                       break;
-               case T_CreateCastStmt:
-                       retval = _equalCreateCastStmt(a, b);
-                       break;
-               case T_PrepareStmt:
-                       retval = _equalPrepareStmt(a, b);
-                       break;
-               case T_ExecuteStmt:
-                       retval = _equalExecuteStmt(a, b);
-                       break;
-               case T_DeallocateStmt:
-                       retval = _equalDeallocateStmt(a, b);
-                       break;
-               case T_DropOwnedStmt:
-                       retval = _equalDropOwnedStmt(a, b);
-                       break;
-               case T_ReassignOwnedStmt:
-                       retval = _equalReassignOwnedStmt(a, b);
-                       break;
-               case T_AlterTSDictionaryStmt:
-                       retval = _equalAlterTSDictionaryStmt(a, b);
-                       break;
-               case T_AlterTSConfigurationStmt:
-                       retval = _equalAlterTSConfigurationStmt(a, b);
-                       break;
-               case T_CreatePolicyStmt:
-                       retval = _equalCreatePolicyStmt(a, b);
-                       break;
-               case T_AlterPolicyStmt:
-                       retval = _equalAlterPolicyStmt(a, b);
-                       break;
-               case T_CreatePublicationStmt:
-                       retval = _equalCreatePublicationStmt(a, b);
-                       break;
-               case T_AlterPublicationStmt:
-                       retval = _equalAlterPublicationStmt(a, b);
-                       break;
-               case T_CreateSubscriptionStmt:
-                       retval = _equalCreateSubscriptionStmt(a, b);
-                       break;
-               case T_AlterSubscriptionStmt:
-                       retval = _equalAlterSubscriptionStmt(a, b);
-                       break;
-               case T_DropSubscriptionStmt:
-                       retval = _equalDropSubscriptionStmt(a, b);
-                       break;
-               case T_A_Expr:
-                       retval = _equalA_Expr(a, b);
-                       break;
-               case T_ColumnRef:
-                       retval = _equalColumnRef(a, b);
-                       break;
-               case T_ParamRef:
-                       retval = _equalParamRef(a, b);
-                       break;
-               case T_A_Const:
-                       retval = _equalA_Const(a, b);
-                       break;
-               case T_FuncCall:
-                       retval = _equalFuncCall(a, b);
-                       break;
-               case T_A_Star:
-                       retval = _equalA_Star(a, b);
-                       break;
-               case T_A_Indices:
-                       retval = _equalA_Indices(a, b);
-                       break;
-               case T_A_Indirection:
-                       retval = _equalA_Indirection(a, b);
-                       break;
-               case T_A_ArrayExpr:
-                       retval = _equalA_ArrayExpr(a, b);
-                       break;
-               case T_ResTarget:
-                       retval = _equalResTarget(a, b);
-                       break;
-               case T_MultiAssignRef:
-                       retval = _equalMultiAssignRef(a, b);
-                       break;
-               case T_TypeCast:
-                       retval = _equalTypeCast(a, b);
-                       break;
-               case T_CollateClause:
-                       retval = _equalCollateClause(a, b);
-                       break;
-               case T_SortBy:
-                       retval = _equalSortBy(a, b);
-                       break;
-               case T_WindowDef:
-                       retval = _equalWindowDef(a, b);
-                       break;
-               case T_RangeSubselect:
-                       retval = _equalRangeSubselect(a, b);
-                       break;
-               case T_RangeFunction:
-                       retval = _equalRangeFunction(a, b);
-                       break;
-               case T_RangeTableSample:
-                       retval = _equalRangeTableSample(a, b);
-                       break;
-               case T_RangeTableFunc:
-                       retval = _equalRangeTableFunc(a, b);
-                       break;
-               case T_RangeTableFuncCol:
-                       retval = _equalRangeTableFuncCol(a, b);
-                       break;
-               case T_TypeName:
-                       retval = _equalTypeName(a, b);
-                       break;
-               case T_IndexElem:
-                       retval = _equalIndexElem(a, b);
-                       break;
-               case T_StatsElem:
-                       retval = _equalStatsElem(a, b);
-                       break;
-               case T_ColumnDef:
-                       retval = _equalColumnDef(a, b);
-                       break;
-               case T_Constraint:
-                       retval = _equalConstraint(a, b);
-                       break;
-               case T_DefElem:
-                       retval = _equalDefElem(a, b);
-                       break;
-               case T_LockingClause:
-                       retval = _equalLockingClause(a, b);
-                       break;
-               case T_RangeTblEntry:
-                       retval = _equalRangeTblEntry(a, b);
-                       break;
-               case T_RangeTblFunction:
-                       retval = _equalRangeTblFunction(a, b);
-                       break;
-               case T_TableSampleClause:
-                       retval = _equalTableSampleClause(a, b);
-                       break;
-               case T_WithCheckOption:
-                       retval = _equalWithCheckOption(a, b);
-                       break;
-               case T_SortGroupClause:
-                       retval = _equalSortGroupClause(a, b);
-                       break;
-               case T_GroupingSet:
-                       retval = _equalGroupingSet(a, b);
-                       break;
-               case T_WindowClause:
-                       retval = _equalWindowClause(a, b);
-                       break;
-               case T_RowMarkClause:
-                       retval = _equalRowMarkClause(a, b);
-                       break;
-               case T_WithClause:
-                       retval = _equalWithClause(a, b);
-                       break;
-               case T_InferClause:
-                       retval = _equalInferClause(a, b);
-                       break;
-               case T_OnConflictClause:
-                       retval = _equalOnConflictClause(a, b);
-                       break;
-               case T_CTESearchClause:
-                       retval = _equalCTESearchClause(a, b);
-                       break;
-               case T_CTECycleClause:
-                       retval = _equalCTECycleClause(a, b);
-                       break;
-               case T_CommonTableExpr:
-                       retval = _equalCommonTableExpr(a, b);
-                       break;
-               case T_MergeWhenClause:
-                       retval = _equalMergeWhenClause(a, b);
-                       break;
-               case T_MergeAction:
-                       retval = _equalMergeAction(a, b);
-                       break;
-               case T_ObjectWithArgs:
-                       retval = _equalObjectWithArgs(a, b);
-                       break;
-               case T_AccessPriv:
-                       retval = _equalAccessPriv(a, b);
-                       break;
-               case T_XmlSerialize:
-                       retval = _equalXmlSerialize(a, b);
-                       break;
-               case T_RoleSpec:
-                       retval = _equalRoleSpec(a, b);
-                       break;
-               case T_TriggerTransition:
-                       retval = _equalTriggerTransition(a, b);
-                       break;
-               case T_PartitionElem:
-                       retval = _equalPartitionElem(a, b);
-                       break;
-               case T_PartitionSpec:
-                       retval = _equalPartitionSpec(a, b);
-                       break;
-               case T_PartitionBoundSpec:
-                       retval = _equalPartitionBoundSpec(a, b);
-                       break;
-               case T_PartitionRangeDatum:
-                       retval = _equalPartitionRangeDatum(a, b);
-                       break;
-               case T_PartitionCmd:
-                       retval = _equalPartitionCmd(a, b);
-                       break;
-               case T_PublicationObjSpec:
-                       retval = _equalPublicationObject(a, b);
-                       break;
-               case T_PublicationTable:
-                       retval = _equalPublicationTable(a, b);
-                       break;
-               case T_JsonKeyValue:
-                       retval = _equalJsonKeyValue(a, b);
-                       break;
-               case T_JsonObjectConstructor:
-                       retval = _equalJsonObjectConstructor(a, b);
-                       break;
-               case T_JsonAggConstructor:
-                       retval = _equalJsonAggConstructor(a, b);
-                       break;
-               case T_JsonObjectAgg:
-                       retval = _equalJsonObjectAgg(a, b);
-                       break;
-               case T_JsonOutput:
-                       retval = _equalJsonOutput(a, b);
-                       break;
-               case T_JsonArrayConstructor:
-                       retval = _equalJsonArrayConstructor(a, b);
-                       break;
-               case T_JsonArrayQueryConstructor:
-                       retval = _equalJsonArrayQueryConstructor(a, b);
-                       break;
-               case T_JsonArrayAgg:
-                       retval = _equalJsonArrayAgg(a, b);
-                       break;
-               case T_JsonFuncExpr:
-                       retval = _equalJsonFuncExpr(a, b);
-                       break;
-               case T_JsonCommon:
-                       retval = _equalJsonCommon(a, b);
-                       break;
-               case T_JsonArgument:
-                       retval = _equalJsonArgument(a, b);
-                       break;
-               case T_JsonTablePlan:
-                       retval = _equalJsonTablePlan(a, b);
-                       break;
-               case T_JsonTable:
-                       retval = _equalJsonTable(a, b);
-                       break;
-               case T_JsonTableColumn:
-                       retval = _equalJsonTableColumn(a, b);
-                       break;
-#endif                                                 /* OBSOLETE */
-
                default:
                        elog(ERROR, "unrecognized node type: %d",
                                 (int) nodeTag(a));
index f26c129d596b353d581036c6d5fc70162c9282f2..9e70bbb4d6977ebd7bdd39ac55802457f1728fa1 100644 (file)
@@ -307,3739 +307,542 @@ outDatum(StringInfo str, Datum value, int typlen, bool typbyval)
 
 #include "outfuncs.funcs.c"
 
-#ifdef OBSOLETE
+
 /*
- *     Stuff from plannodes.h
+ * Support functions for nodes with custom_read_write attribute or
+ * special_read_write attribute
  */
 
 static void
-_outPlannedStmt(StringInfo str, const PlannedStmt *node)
+_outConst(StringInfo str, const Const *node)
 {
-       WRITE_NODE_TYPE("PLANNEDSTMT");
+       WRITE_NODE_TYPE("CONST");
 
-       WRITE_ENUM_FIELD(commandType, CmdType);
-       WRITE_UINT64_FIELD(queryId);
-       WRITE_BOOL_FIELD(hasReturning);
-       WRITE_BOOL_FIELD(hasModifyingCTE);
-       WRITE_BOOL_FIELD(canSetTag);
-       WRITE_BOOL_FIELD(transientPlan);
-       WRITE_BOOL_FIELD(dependsOnRole);
-       WRITE_BOOL_FIELD(parallelModeNeeded);
-       WRITE_INT_FIELD(jitFlags);
-       WRITE_NODE_FIELD(planTree);
-       WRITE_NODE_FIELD(rtable);
-       WRITE_NODE_FIELD(resultRelations);
-       WRITE_NODE_FIELD(appendRelations);
-       WRITE_NODE_FIELD(subplans);
-       WRITE_BITMAPSET_FIELD(rewindPlanIDs);
-       WRITE_NODE_FIELD(rowMarks);
-       WRITE_NODE_FIELD(relationOids);
-       WRITE_NODE_FIELD(invalItems);
-       WRITE_NODE_FIELD(paramExecTypes);
-       WRITE_NODE_FIELD(utilityStmt);
-       WRITE_LOCATION_FIELD(stmt_location);
-       WRITE_INT_FIELD(stmt_len);
-}
+       WRITE_OID_FIELD(consttype);
+       WRITE_INT_FIELD(consttypmod);
+       WRITE_OID_FIELD(constcollid);
+       WRITE_INT_FIELD(constlen);
+       WRITE_BOOL_FIELD(constbyval);
+       WRITE_BOOL_FIELD(constisnull);
+       WRITE_LOCATION_FIELD(location);
 
-/*
- * print the basic stuff of all nodes that inherit from Plan
- */
-static void
-_outPlanInfo(StringInfo str, const Plan *node)
-{
-       WRITE_FLOAT_FIELD(startup_cost, "%.2f");
-       WRITE_FLOAT_FIELD(total_cost, "%.2f");
-       WRITE_FLOAT_FIELD(plan_rows, "%.0f");
-       WRITE_INT_FIELD(plan_width);
-       WRITE_BOOL_FIELD(parallel_aware);
-       WRITE_BOOL_FIELD(parallel_safe);
-       WRITE_BOOL_FIELD(async_capable);
-       WRITE_INT_FIELD(plan_node_id);
-       WRITE_NODE_FIELD(targetlist);
-       WRITE_NODE_FIELD(qual);
-       WRITE_NODE_FIELD(lefttree);
-       WRITE_NODE_FIELD(righttree);
-       WRITE_NODE_FIELD(initPlan);
-       WRITE_BITMAPSET_FIELD(extParam);
-       WRITE_BITMAPSET_FIELD(allParam);
+       appendStringInfoString(str, " :constvalue ");
+       if (node->constisnull)
+               appendStringInfoString(str, "<>");
+       else
+               outDatum(str, node->constvalue, node->constlen, node->constbyval);
 }
 
-/*
- * print the basic stuff of all nodes that inherit from Scan
- */
 static void
-_outScanInfo(StringInfo str, const Scan *node)
+_outBoolExpr(StringInfo str, const BoolExpr *node)
 {
-       _outPlanInfo(str, (const Plan *) node);
+       char       *opstr = NULL;
 
-       WRITE_UINT_FIELD(scanrelid);
-}
+       WRITE_NODE_TYPE("BOOLEXPR");
 
-/*
- * print the basic stuff of all nodes that inherit from Join
- */
-static void
-_outJoinPlanInfo(StringInfo str, const Join *node)
-{
-       _outPlanInfo(str, (const Plan *) node);
+       /* do-it-yourself enum representation */
+       switch (node->boolop)
+       {
+               case AND_EXPR:
+                       opstr = "and";
+                       break;
+               case OR_EXPR:
+                       opstr = "or";
+                       break;
+               case NOT_EXPR:
+                       opstr = "not";
+                       break;
+       }
+       appendStringInfoString(str, " :boolop ");
+       outToken(str, opstr);
 
-       WRITE_ENUM_FIELD(jointype, JoinType);
-       WRITE_BOOL_FIELD(inner_unique);
-       WRITE_NODE_FIELD(joinqual);
+       WRITE_NODE_FIELD(args);
+       WRITE_LOCATION_FIELD(location);
 }
 
 static void
-_outResult(StringInfo str, const Result *node)
+_outForeignKeyOptInfo(StringInfo str, const ForeignKeyOptInfo *node)
 {
-       WRITE_NODE_TYPE("RESULT");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_NODE_FIELD(resconstantqual);
-}
+       int                     i;
 
-static void
-_outProjectSet(StringInfo str, const ProjectSet *node)
-{
-       WRITE_NODE_TYPE("PROJECTSET");
+       WRITE_NODE_TYPE("FOREIGNKEYOPTINFO");
 
-       _outPlanInfo(str, (const Plan *) node);
+       WRITE_UINT_FIELD(con_relid);
+       WRITE_UINT_FIELD(ref_relid);
+       WRITE_INT_FIELD(nkeys);
+       WRITE_ATTRNUMBER_ARRAY(conkey, node->nkeys);
+       WRITE_ATTRNUMBER_ARRAY(confkey, node->nkeys);
+       WRITE_OID_ARRAY(conpfeqop, node->nkeys);
+       WRITE_INT_FIELD(nmatched_ec);
+       WRITE_INT_FIELD(nconst_ec);
+       WRITE_INT_FIELD(nmatched_rcols);
+       WRITE_INT_FIELD(nmatched_ri);
+       /* for compactness, just print the number of matches per column: */
+       appendStringInfoString(str, " :eclass");
+       for (i = 0; i < node->nkeys; i++)
+               appendStringInfo(str, " %d", (node->eclass[i] != NULL));
+       appendStringInfoString(str, " :rinfos");
+       for (i = 0; i < node->nkeys; i++)
+               appendStringInfo(str, " %d", list_length(node->rinfos[i]));
 }
 
 static void
-_outModifyTable(StringInfo str, const ModifyTable *node)
+_outEquivalenceClass(StringInfo str, const EquivalenceClass *node)
 {
-       WRITE_NODE_TYPE("MODIFYTABLE");
+       /*
+        * To simplify reading, we just chase up to the topmost merged EC and
+        * print that, without bothering to show the merge-ees separately.
+        */
+       while (node->ec_merged)
+               node = node->ec_merged;
 
-       _outPlanInfo(str, (const Plan *) node);
+       WRITE_NODE_TYPE("EQUIVALENCECLASS");
 
-       WRITE_ENUM_FIELD(operation, CmdType);
-       WRITE_BOOL_FIELD(canSetTag);
-       WRITE_UINT_FIELD(nominalRelation);
-       WRITE_UINT_FIELD(rootRelation);
-       WRITE_BOOL_FIELD(partColsUpdated);
-       WRITE_NODE_FIELD(resultRelations);
-       WRITE_NODE_FIELD(updateColnosLists);
-       WRITE_NODE_FIELD(withCheckOptionLists);
-       WRITE_NODE_FIELD(returningLists);
-       WRITE_NODE_FIELD(fdwPrivLists);
-       WRITE_BITMAPSET_FIELD(fdwDirectModifyPlans);
-       WRITE_NODE_FIELD(rowMarks);
-       WRITE_INT_FIELD(epqParam);
-       WRITE_ENUM_FIELD(onConflictAction, OnConflictAction);
-       WRITE_NODE_FIELD(arbiterIndexes);
-       WRITE_NODE_FIELD(onConflictSet);
-       WRITE_NODE_FIELD(onConflictCols);
-       WRITE_NODE_FIELD(onConflictWhere);
-       WRITE_UINT_FIELD(exclRelRTI);
-       WRITE_NODE_FIELD(exclRelTlist);
-       WRITE_NODE_FIELD(mergeActionLists);
+       WRITE_NODE_FIELD(ec_opfamilies);
+       WRITE_OID_FIELD(ec_collation);
+       WRITE_NODE_FIELD(ec_members);
+       WRITE_NODE_FIELD(ec_sources);
+       WRITE_NODE_FIELD(ec_derives);
+       WRITE_BITMAPSET_FIELD(ec_relids);
+       WRITE_BOOL_FIELD(ec_has_const);
+       WRITE_BOOL_FIELD(ec_has_volatile);
+       WRITE_BOOL_FIELD(ec_below_outer_join);
+       WRITE_BOOL_FIELD(ec_broken);
+       WRITE_UINT_FIELD(ec_sortref);
+       WRITE_UINT_FIELD(ec_min_security);
+       WRITE_UINT_FIELD(ec_max_security);
 }
 
 static void
-_outAppend(StringInfo str, const Append *node)
+_outExtensibleNode(StringInfo str, const ExtensibleNode *node)
 {
-       WRITE_NODE_TYPE("APPEND");
-
-       _outPlanInfo(str, (const Plan *) node);
+       const ExtensibleNodeMethods *methods;
 
-       WRITE_BITMAPSET_FIELD(apprelids);
-       WRITE_NODE_FIELD(appendplans);
-       WRITE_INT_FIELD(nasyncplans);
-       WRITE_INT_FIELD(first_partial_plan);
-       WRITE_NODE_FIELD(part_prune_info);
-}
+       methods = GetExtensibleNodeMethods(node->extnodename, false);
 
-static void
-_outMergeAppend(StringInfo str, const MergeAppend *node)
-{
-       WRITE_NODE_TYPE("MERGEAPPEND");
+       WRITE_NODE_TYPE("EXTENSIBLENODE");
 
-       _outPlanInfo(str, (const Plan *) node);
+       WRITE_STRING_FIELD(extnodename);
 
-       WRITE_BITMAPSET_FIELD(apprelids);
-       WRITE_NODE_FIELD(mergeplans);
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(sortColIdx, node->numCols);
-       WRITE_OID_ARRAY(sortOperators, node->numCols);
-       WRITE_OID_ARRAY(collations, node->numCols);
-       WRITE_BOOL_ARRAY(nullsFirst, node->numCols);
-       WRITE_NODE_FIELD(part_prune_info);
+       /* serialize the private fields */
+       methods->nodeOut(str, node);
 }
 
 static void
-_outRecursiveUnion(StringInfo str, const RecursiveUnion *node)
+_outQuery(StringInfo str, const Query *node)
 {
-       WRITE_NODE_TYPE("RECURSIVEUNION");
+       WRITE_NODE_TYPE("QUERY");
+
+       WRITE_ENUM_FIELD(commandType, CmdType);
+       WRITE_ENUM_FIELD(querySource, QuerySource);
+       /* we intentionally do not print the queryId field */
+       WRITE_BOOL_FIELD(canSetTag);
 
-       _outPlanInfo(str, (const Plan *) node);
+       /*
+        * Hack to work around missing outfuncs routines for a lot of the
+        * utility-statement node types.  (The only one we actually *need* for
+        * rules support is NotifyStmt.)  Someday we ought to support 'em all, but
+        * for the meantime do this to avoid getting lots of warnings when running
+        * with debug_print_parse on.
+        */
+       if (node->utilityStmt)
+       {
+               switch (nodeTag(node->utilityStmt))
+               {
+                       case T_CreateStmt:
+                       case T_IndexStmt:
+                       case T_NotifyStmt:
+                       case T_DeclareCursorStmt:
+                               WRITE_NODE_FIELD(utilityStmt);
+                               break;
+                       default:
+                               appendStringInfoString(str, " :utilityStmt ?");
+                               break;
+               }
+       }
+       else
+               appendStringInfoString(str, " :utilityStmt <>");
 
-       WRITE_INT_FIELD(wtParam);
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(dupColIdx, node->numCols);
-       WRITE_OID_ARRAY(dupOperators, node->numCols);
-       WRITE_OID_ARRAY(dupCollations, node->numCols);
-       WRITE_LONG_FIELD(numGroups);
+       WRITE_INT_FIELD(resultRelation);
+       WRITE_BOOL_FIELD(hasAggs);
+       WRITE_BOOL_FIELD(hasWindowFuncs);
+       WRITE_BOOL_FIELD(hasTargetSRFs);
+       WRITE_BOOL_FIELD(hasSubLinks);
+       WRITE_BOOL_FIELD(hasDistinctOn);
+       WRITE_BOOL_FIELD(hasRecursive);
+       WRITE_BOOL_FIELD(hasModifyingCTE);
+       WRITE_BOOL_FIELD(hasForUpdate);
+       WRITE_BOOL_FIELD(hasRowSecurity);
+       WRITE_BOOL_FIELD(isReturn);
+       WRITE_NODE_FIELD(cteList);
+       WRITE_NODE_FIELD(rtable);
+       WRITE_NODE_FIELD(jointree);
+       WRITE_NODE_FIELD(targetList);
+       WRITE_ENUM_FIELD(override, OverridingKind);
+       WRITE_NODE_FIELD(onConflict);
+       WRITE_NODE_FIELD(returningList);
+       WRITE_NODE_FIELD(groupClause);
+       WRITE_BOOL_FIELD(groupDistinct);
+       WRITE_NODE_FIELD(groupingSets);
+       WRITE_NODE_FIELD(havingQual);
+       WRITE_NODE_FIELD(windowClause);
+       WRITE_NODE_FIELD(distinctClause);
+       WRITE_NODE_FIELD(sortClause);
+       WRITE_NODE_FIELD(limitOffset);
+       WRITE_NODE_FIELD(limitCount);
+       WRITE_ENUM_FIELD(limitOption, LimitOption);
+       WRITE_NODE_FIELD(rowMarks);
+       WRITE_NODE_FIELD(setOperations);
+       WRITE_NODE_FIELD(constraintDeps);
+       WRITE_NODE_FIELD(withCheckOptions);
+       WRITE_NODE_FIELD(mergeActionList);
+       WRITE_BOOL_FIELD(mergeUseOuterJoin);
+       WRITE_LOCATION_FIELD(stmt_location);
+       WRITE_INT_FIELD(stmt_len);
 }
 
 static void
-_outBitmapAnd(StringInfo str, const BitmapAnd *node)
+_outRangeTblEntry(StringInfo str, const RangeTblEntry *node)
 {
-       WRITE_NODE_TYPE("BITMAPAND");
+       WRITE_NODE_TYPE("RANGETBLENTRY");
+
+       /* put alias + eref first to make dump more legible */
+       WRITE_NODE_FIELD(alias);
+       WRITE_NODE_FIELD(eref);
+       WRITE_ENUM_FIELD(rtekind, RTEKind);
 
-       _outPlanInfo(str, (const Plan *) node);
+       switch (node->rtekind)
+       {
+               case RTE_RELATION:
+                       WRITE_OID_FIELD(relid);
+                       WRITE_CHAR_FIELD(relkind);
+                       WRITE_INT_FIELD(rellockmode);
+                       WRITE_NODE_FIELD(tablesample);
+                       break;
+               case RTE_SUBQUERY:
+                       WRITE_NODE_FIELD(subquery);
+                       WRITE_BOOL_FIELD(security_barrier);
+                       break;
+               case RTE_JOIN:
+                       WRITE_ENUM_FIELD(jointype, JoinType);
+                       WRITE_INT_FIELD(joinmergedcols);
+                       WRITE_NODE_FIELD(joinaliasvars);
+                       WRITE_NODE_FIELD(joinleftcols);
+                       WRITE_NODE_FIELD(joinrightcols);
+                       WRITE_NODE_FIELD(join_using_alias);
+                       break;
+               case RTE_FUNCTION:
+                       WRITE_NODE_FIELD(functions);
+                       WRITE_BOOL_FIELD(funcordinality);
+                       break;
+               case RTE_TABLEFUNC:
+                       WRITE_NODE_FIELD(tablefunc);
+                       break;
+               case RTE_VALUES:
+                       WRITE_NODE_FIELD(values_lists);
+                       WRITE_NODE_FIELD(coltypes);
+                       WRITE_NODE_FIELD(coltypmods);
+                       WRITE_NODE_FIELD(colcollations);
+                       break;
+               case RTE_CTE:
+                       WRITE_STRING_FIELD(ctename);
+                       WRITE_UINT_FIELD(ctelevelsup);
+                       WRITE_BOOL_FIELD(self_reference);
+                       WRITE_NODE_FIELD(coltypes);
+                       WRITE_NODE_FIELD(coltypmods);
+                       WRITE_NODE_FIELD(colcollations);
+                       break;
+               case RTE_NAMEDTUPLESTORE:
+                       WRITE_STRING_FIELD(enrname);
+                       WRITE_FLOAT_FIELD(enrtuples, "%.0f");
+                       WRITE_OID_FIELD(relid);
+                       WRITE_NODE_FIELD(coltypes);
+                       WRITE_NODE_FIELD(coltypmods);
+                       WRITE_NODE_FIELD(colcollations);
+                       break;
+               case RTE_RESULT:
+                       /* no extra fields */
+                       break;
+               default:
+                       elog(ERROR, "unrecognized RTE kind: %d", (int) node->rtekind);
+                       break;
+       }
 
-       WRITE_NODE_FIELD(bitmapplans);
+       WRITE_BOOL_FIELD(lateral);
+       WRITE_BOOL_FIELD(inh);
+       WRITE_BOOL_FIELD(inFromCl);
+       WRITE_UINT_FIELD(requiredPerms);
+       WRITE_OID_FIELD(checkAsUser);
+       WRITE_BITMAPSET_FIELD(selectedCols);
+       WRITE_BITMAPSET_FIELD(insertedCols);
+       WRITE_BITMAPSET_FIELD(updatedCols);
+       WRITE_BITMAPSET_FIELD(extraUpdatedCols);
+       WRITE_NODE_FIELD(securityQuals);
 }
 
 static void
-_outBitmapOr(StringInfo str, const BitmapOr *node)
+_outA_Expr(StringInfo str, const A_Expr *node)
 {
-       WRITE_NODE_TYPE("BITMAPOR");
-
-       _outPlanInfo(str, (const Plan *) node);
+       WRITE_NODE_TYPE("A_EXPR");
 
-       WRITE_BOOL_FIELD(isshared);
-       WRITE_NODE_FIELD(bitmapplans);
-}
-
-static void
-_outGather(StringInfo str, const Gather *node)
-{
-       WRITE_NODE_TYPE("GATHER");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_INT_FIELD(num_workers);
-       WRITE_INT_FIELD(rescan_param);
-       WRITE_BOOL_FIELD(single_copy);
-       WRITE_BOOL_FIELD(invisible);
-       WRITE_BITMAPSET_FIELD(initParam);
-}
-
-static void
-_outGatherMerge(StringInfo str, const GatherMerge *node)
-{
-       WRITE_NODE_TYPE("GATHERMERGE");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_INT_FIELD(num_workers);
-       WRITE_INT_FIELD(rescan_param);
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(sortColIdx, node->numCols);
-       WRITE_OID_ARRAY(sortOperators, node->numCols);
-       WRITE_OID_ARRAY(collations, node->numCols);
-       WRITE_BOOL_ARRAY(nullsFirst, node->numCols);
-       WRITE_BITMAPSET_FIELD(initParam);
-}
-
-static void
-_outScan(StringInfo str, const Scan *node)
-{
-       WRITE_NODE_TYPE("SCAN");
+       switch (node->kind)
+       {
+               case AEXPR_OP:
+                       appendStringInfoChar(str, ' ');
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_OP_ANY:
+                       appendStringInfoChar(str, ' ');
+                       WRITE_NODE_FIELD(name);
+                       appendStringInfoString(str, " ANY ");
+                       break;
+               case AEXPR_OP_ALL:
+                       appendStringInfoChar(str, ' ');
+                       WRITE_NODE_FIELD(name);
+                       appendStringInfoString(str, " ALL ");
+                       break;
+               case AEXPR_DISTINCT:
+                       appendStringInfoString(str, " DISTINCT ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_NOT_DISTINCT:
+                       appendStringInfoString(str, " NOT_DISTINCT ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_NULLIF:
+                       appendStringInfoString(str, " NULLIF ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_IN:
+                       appendStringInfoString(str, " IN ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_LIKE:
+                       appendStringInfoString(str, " LIKE ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_ILIKE:
+                       appendStringInfoString(str, " ILIKE ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_SIMILAR:
+                       appendStringInfoString(str, " SIMILAR ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_BETWEEN:
+                       appendStringInfoString(str, " BETWEEN ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_NOT_BETWEEN:
+                       appendStringInfoString(str, " NOT_BETWEEN ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_BETWEEN_SYM:
+                       appendStringInfoString(str, " BETWEEN_SYM ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               case AEXPR_NOT_BETWEEN_SYM:
+                       appendStringInfoString(str, " NOT_BETWEEN_SYM ");
+                       WRITE_NODE_FIELD(name);
+                       break;
+               default:
+                       appendStringInfoString(str, " ??");
+                       break;
+       }
 
-       _outScanInfo(str, node);
+       WRITE_NODE_FIELD(lexpr);
+       WRITE_NODE_FIELD(rexpr);
+       WRITE_LOCATION_FIELD(location);
 }
 
 static void
-_outSeqScan(StringInfo str, const SeqScan *node)
+_outInteger(StringInfo str, const Integer *node)
 {
-       WRITE_NODE_TYPE("SEQSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
+       appendStringInfo(str, "%d", node->ival);
 }
 
 static void
-_outSampleScan(StringInfo str, const SampleScan *node)
+_outFloat(StringInfo str, const Float *node)
 {
-       WRITE_NODE_TYPE("SAMPLESCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_NODE_FIELD(tablesample);
+       /*
+        * We assume the value is a valid numeric literal and so does not need
+        * quoting.
+        */
+       appendStringInfoString(str, node->fval);
 }
 
 static void
-_outIndexScan(StringInfo str, const IndexScan *node)
+_outBoolean(StringInfo str, const Boolean *node)
 {
-       WRITE_NODE_TYPE("INDEXSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_OID_FIELD(indexid);
-       WRITE_NODE_FIELD(indexqual);
-       WRITE_NODE_FIELD(indexqualorig);
-       WRITE_NODE_FIELD(indexorderby);
-       WRITE_NODE_FIELD(indexorderbyorig);
-       WRITE_NODE_FIELD(indexorderbyops);
-       WRITE_ENUM_FIELD(indexorderdir, ScanDirection);
+       appendStringInfoString(str, node->boolval ? "true" : "false");
 }
 
 static void
-_outIndexOnlyScan(StringInfo str, const IndexOnlyScan *node)
+_outString(StringInfo str, const String *node)
 {
-       WRITE_NODE_TYPE("INDEXONLYSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_OID_FIELD(indexid);
-       WRITE_NODE_FIELD(indexqual);
-       WRITE_NODE_FIELD(recheckqual);
-       WRITE_NODE_FIELD(indexorderby);
-       WRITE_NODE_FIELD(indextlist);
-       WRITE_ENUM_FIELD(indexorderdir, ScanDirection);
+       /*
+        * We use outToken to provide escaping of the string's content, but we
+        * don't want it to do anything with an empty string.
+        */
+       appendStringInfoChar(str, '"');
+       if (node->sval[0] != '\0')
+               outToken(str, node->sval);
+       appendStringInfoChar(str, '"');
 }
 
 static void
-_outBitmapIndexScan(StringInfo str, const BitmapIndexScan *node)
+_outBitString(StringInfo str, const BitString *node)
 {
-       WRITE_NODE_TYPE("BITMAPINDEXSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_OID_FIELD(indexid);
-       WRITE_BOOL_FIELD(isshared);
-       WRITE_NODE_FIELD(indexqual);
-       WRITE_NODE_FIELD(indexqualorig);
+       /* internal representation already has leading 'b' */
+       appendStringInfoString(str, node->bsval);
 }
 
 static void
-_outBitmapHeapScan(StringInfo str, const BitmapHeapScan *node)
+_outA_Const(StringInfo str, const A_Const *node)
 {
-       WRITE_NODE_TYPE("BITMAPHEAPSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
+       WRITE_NODE_TYPE("A_CONST");
 
-       WRITE_NODE_FIELD(bitmapqualorig);
+       if (node->isnull)
+               appendStringInfoString(str, "NULL");
+       else
+       {
+               appendStringInfoString(str, " :val ");
+               outNode(str, &node->val);
+       }
+       WRITE_LOCATION_FIELD(location);
 }
 
 static void
-_outTidScan(StringInfo str, const TidScan *node)
+_outConstraint(StringInfo str, const Constraint *node)
 {
-       WRITE_NODE_TYPE("TIDSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
+       WRITE_NODE_TYPE("CONSTRAINT");
 
-       WRITE_NODE_FIELD(tidquals);
-}
+       WRITE_STRING_FIELD(conname);
+       WRITE_BOOL_FIELD(deferrable);
+       WRITE_BOOL_FIELD(initdeferred);
+       WRITE_LOCATION_FIELD(location);
 
-static void
-_outTidRangeScan(StringInfo str, const TidRangeScan *node)
-{
-       WRITE_NODE_TYPE("TIDRANGESCAN");
+       appendStringInfoString(str, " :contype ");
+       switch (node->contype)
+       {
+               case CONSTR_NULL:
+                       appendStringInfoString(str, "NULL");
+                       break;
 
-       _outScanInfo(str, (const Scan *) node);
+               case CONSTR_NOTNULL:
+                       appendStringInfoString(str, "NOT_NULL");
+                       break;
 
-       WRITE_NODE_FIELD(tidrangequals);
-}
+               case CONSTR_DEFAULT:
+                       appendStringInfoString(str, "DEFAULT");
+                       WRITE_NODE_FIELD(raw_expr);
+                       WRITE_STRING_FIELD(cooked_expr);
+                       break;
 
-static void
-_outSubqueryScan(StringInfo str, const SubqueryScan *node)
-{
-       WRITE_NODE_TYPE("SUBQUERYSCAN");
+               case CONSTR_IDENTITY:
+                       appendStringInfoString(str, "IDENTITY");
+                       WRITE_NODE_FIELD(raw_expr);
+                       WRITE_STRING_FIELD(cooked_expr);
+                       WRITE_CHAR_FIELD(generated_when);
+                       break;
 
-       _outScanInfo(str, (const Scan *) node);
+               case CONSTR_GENERATED:
+                       appendStringInfoString(str, "GENERATED");
+                       WRITE_NODE_FIELD(raw_expr);
+                       WRITE_STRING_FIELD(cooked_expr);
+                       WRITE_CHAR_FIELD(generated_when);
+                       break;
 
-       WRITE_NODE_FIELD(subplan);
-       WRITE_ENUM_FIELD(scanstatus, SubqueryScanStatus);
-}
+               case CONSTR_CHECK:
+                       appendStringInfoString(str, "CHECK");
+                       WRITE_BOOL_FIELD(is_no_inherit);
+                       WRITE_NODE_FIELD(raw_expr);
+                       WRITE_STRING_FIELD(cooked_expr);
+                       break;
 
-static void
-_outFunctionScan(StringInfo str, const FunctionScan *node)
-{
-       WRITE_NODE_TYPE("FUNCTIONSCAN");
+               case CONSTR_PRIMARY:
+                       appendStringInfoString(str, "PRIMARY_KEY");
+                       WRITE_NODE_FIELD(keys);
+                       WRITE_NODE_FIELD(including);
+                       WRITE_NODE_FIELD(options);
+                       WRITE_STRING_FIELD(indexname);
+                       WRITE_STRING_FIELD(indexspace);
+                       WRITE_BOOL_FIELD(reset_default_tblspc);
+                       /* access_method and where_clause not currently used */
+                       break;
 
-       _outScanInfo(str, (const Scan *) node);
+               case CONSTR_UNIQUE:
+                       appendStringInfoString(str, "UNIQUE");
+                       WRITE_BOOL_FIELD(nulls_not_distinct);
+                       WRITE_NODE_FIELD(keys);
+                       WRITE_NODE_FIELD(including);
+                       WRITE_NODE_FIELD(options);
+                       WRITE_STRING_FIELD(indexname);
+                       WRITE_STRING_FIELD(indexspace);
+                       WRITE_BOOL_FIELD(reset_default_tblspc);
+                       /* access_method and where_clause not currently used */
+                       break;
 
-       WRITE_NODE_FIELD(functions);
-       WRITE_BOOL_FIELD(funcordinality);
-}
+               case CONSTR_EXCLUSION:
+                       appendStringInfoString(str, "EXCLUSION");
+                       WRITE_NODE_FIELD(exclusions);
+                       WRITE_NODE_FIELD(including);
+                       WRITE_NODE_FIELD(options);
+                       WRITE_STRING_FIELD(indexname);
+                       WRITE_STRING_FIELD(indexspace);
+                       WRITE_BOOL_FIELD(reset_default_tblspc);
+                       WRITE_STRING_FIELD(access_method);
+                       WRITE_NODE_FIELD(where_clause);
+                       break;
 
-static void
-_outTableFuncScan(StringInfo str, const TableFuncScan *node)
-{
-       WRITE_NODE_TYPE("TABLEFUNCSCAN");
+               case CONSTR_FOREIGN:
+                       appendStringInfoString(str, "FOREIGN_KEY");
+                       WRITE_NODE_FIELD(pktable);
+                       WRITE_NODE_FIELD(fk_attrs);
+                       WRITE_NODE_FIELD(pk_attrs);
+                       WRITE_CHAR_FIELD(fk_matchtype);
+                       WRITE_CHAR_FIELD(fk_upd_action);
+                       WRITE_CHAR_FIELD(fk_del_action);
+                       WRITE_NODE_FIELD(fk_del_set_cols);
+                       WRITE_NODE_FIELD(old_conpfeqop);
+                       WRITE_OID_FIELD(old_pktable_oid);
+                       WRITE_BOOL_FIELD(skip_validation);
+                       WRITE_BOOL_FIELD(initially_valid);
+                       break;
 
-       _outScanInfo(str, (const Scan *) node);
+               case CONSTR_ATTR_DEFERRABLE:
+                       appendStringInfoString(str, "ATTR_DEFERRABLE");
+                       break;
 
-       WRITE_NODE_FIELD(tablefunc);
-}
+               case CONSTR_ATTR_NOT_DEFERRABLE:
+                       appendStringInfoString(str, "ATTR_NOT_DEFERRABLE");
+                       break;
 
-static void
-_outValuesScan(StringInfo str, const ValuesScan *node)
-{
-       WRITE_NODE_TYPE("VALUESSCAN");
+               case CONSTR_ATTR_DEFERRED:
+                       appendStringInfoString(str, "ATTR_DEFERRED");
+                       break;
 
-       _outScanInfo(str, (const Scan *) node);
+               case CONSTR_ATTR_IMMEDIATE:
+                       appendStringInfoString(str, "ATTR_IMMEDIATE");
+                       break;
 
-       WRITE_NODE_FIELD(values_lists);
+               default:
+                       appendStringInfo(str, "<unrecognized_constraint %d>",
+                                                        (int) node->contype);
+                       break;
+       }
 }
 
-static void
-_outCteScan(StringInfo str, const CteScan *node)
-{
-       WRITE_NODE_TYPE("CTESCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_INT_FIELD(ctePlanId);
-       WRITE_INT_FIELD(cteParam);
-}
 
-static void
-_outNamedTuplestoreScan(StringInfo str, const NamedTuplestoreScan *node)
+/*
+ * outNode -
+ *       converts a Node into ascii string and append it to 'str'
+ */
+void
+outNode(StringInfo str, const void *obj)
 {
-       WRITE_NODE_TYPE("NAMEDTUPLESTORESCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_STRING_FIELD(enrname);
-}
-
-static void
-_outWorkTableScan(StringInfo str, const WorkTableScan *node)
-{
-       WRITE_NODE_TYPE("WORKTABLESCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_INT_FIELD(wtParam);
-}
-
-static void
-_outForeignScan(StringInfo str, const ForeignScan *node)
-{
-       WRITE_NODE_TYPE("FOREIGNSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_ENUM_FIELD(operation, CmdType);
-       WRITE_UINT_FIELD(resultRelation);
-       WRITE_OID_FIELD(fs_server);
-       WRITE_NODE_FIELD(fdw_exprs);
-       WRITE_NODE_FIELD(fdw_private);
-       WRITE_NODE_FIELD(fdw_scan_tlist);
-       WRITE_NODE_FIELD(fdw_recheck_quals);
-       WRITE_BITMAPSET_FIELD(fs_relids);
-       WRITE_BOOL_FIELD(fsSystemCol);
-}
-
-static void
-_outCustomScan(StringInfo str, const CustomScan *node)
-{
-       WRITE_NODE_TYPE("CUSTOMSCAN");
-
-       _outScanInfo(str, (const Scan *) node);
-
-       WRITE_UINT_FIELD(flags);
-       WRITE_NODE_FIELD(custom_plans);
-       WRITE_NODE_FIELD(custom_exprs);
-       WRITE_NODE_FIELD(custom_private);
-       WRITE_NODE_FIELD(custom_scan_tlist);
-       WRITE_BITMAPSET_FIELD(custom_relids);
-       /* CustomName is a key to lookup CustomScanMethods */
-       appendStringInfoString(str, " :methods ");
-       outToken(str, node->methods->CustomName);
-}
-
-static void
-_outNestLoop(StringInfo str, const NestLoop *node)
-{
-       WRITE_NODE_TYPE("NESTLOOP");
-
-       _outJoinPlanInfo(str, (const Join *) node);
-
-       WRITE_NODE_FIELD(nestParams);
-}
-
-static void
-_outMergeJoin(StringInfo str, const MergeJoin *node)
-{
-       int                     numCols;
-
-       WRITE_NODE_TYPE("MERGEJOIN");
-
-       _outJoinPlanInfo(str, (const Join *) node);
-
-       WRITE_BOOL_FIELD(skip_mark_restore);
-       WRITE_NODE_FIELD(mergeclauses);
-
-       numCols = list_length(node->mergeclauses);
-
-       WRITE_OID_ARRAY(mergeFamilies, numCols);
-       WRITE_OID_ARRAY(mergeCollations, numCols);
-       WRITE_INT_ARRAY(mergeStrategies, numCols);
-       WRITE_BOOL_ARRAY(mergeNullsFirst, numCols);
-}
-
-static void
-_outHashJoin(StringInfo str, const HashJoin *node)
-{
-       WRITE_NODE_TYPE("HASHJOIN");
-
-       _outJoinPlanInfo(str, (const Join *) node);
-
-       WRITE_NODE_FIELD(hashclauses);
-       WRITE_NODE_FIELD(hashoperators);
-       WRITE_NODE_FIELD(hashcollations);
-       WRITE_NODE_FIELD(hashkeys);
-}
-
-static void
-_outAgg(StringInfo str, const Agg *node)
-{
-       WRITE_NODE_TYPE("AGG");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_ENUM_FIELD(aggstrategy, AggStrategy);
-       WRITE_ENUM_FIELD(aggsplit, AggSplit);
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(grpColIdx, node->numCols);
-       WRITE_OID_ARRAY(grpOperators, node->numCols);
-       WRITE_OID_ARRAY(grpCollations, node->numCols);
-       WRITE_LONG_FIELD(numGroups);
-       WRITE_UINT64_FIELD(transitionSpace);
-       WRITE_BITMAPSET_FIELD(aggParams);
-       WRITE_NODE_FIELD(groupingSets);
-       WRITE_NODE_FIELD(chain);
-}
-
-static void
-_outWindowAgg(StringInfo str, const WindowAgg *node)
-{
-       WRITE_NODE_TYPE("WINDOWAGG");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_UINT_FIELD(winref);
-       WRITE_INT_FIELD(partNumCols);
-       WRITE_ATTRNUMBER_ARRAY(partColIdx, node->partNumCols);
-       WRITE_OID_ARRAY(partOperators, node->partNumCols);
-       WRITE_OID_ARRAY(partCollations, node->partNumCols);
-       WRITE_INT_FIELD(ordNumCols);
-       WRITE_ATTRNUMBER_ARRAY(ordColIdx, node->ordNumCols);
-       WRITE_OID_ARRAY(ordOperators, node->ordNumCols);
-       WRITE_OID_ARRAY(ordCollations, node->ordNumCols);
-       WRITE_INT_FIELD(frameOptions);
-       WRITE_NODE_FIELD(startOffset);
-       WRITE_NODE_FIELD(endOffset);
-       WRITE_NODE_FIELD(runCondition);
-       WRITE_NODE_FIELD(runConditionOrig);
-       WRITE_OID_FIELD(startInRangeFunc);
-       WRITE_OID_FIELD(endInRangeFunc);
-       WRITE_OID_FIELD(inRangeColl);
-       WRITE_BOOL_FIELD(inRangeAsc);
-       WRITE_BOOL_FIELD(inRangeNullsFirst);
-       WRITE_BOOL_FIELD(topWindow);
-}
-
-static void
-_outGroup(StringInfo str, const Group *node)
-{
-       WRITE_NODE_TYPE("GROUP");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(grpColIdx, node->numCols);
-       WRITE_OID_ARRAY(grpOperators, node->numCols);
-       WRITE_OID_ARRAY(grpCollations, node->numCols);
-}
-
-static void
-_outMaterial(StringInfo str, const Material *node)
-{
-       WRITE_NODE_TYPE("MATERIAL");
-
-       _outPlanInfo(str, (const Plan *) node);
-}
-
-static void
-_outMemoize(StringInfo str, const Memoize *node)
-{
-       WRITE_NODE_TYPE("MEMOIZE");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_INT_FIELD(numKeys);
-       WRITE_OID_ARRAY(hashOperators, node->numKeys);
-       WRITE_OID_ARRAY(collations, node->numKeys);
-       WRITE_NODE_FIELD(param_exprs);
-       WRITE_BOOL_FIELD(singlerow);
-       WRITE_BOOL_FIELD(binary_mode);
-       WRITE_UINT_FIELD(est_entries);
-       WRITE_BITMAPSET_FIELD(keyparamids);
-}
-
-static void
-_outSortInfo(StringInfo str, const Sort *node)
-{
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(sortColIdx, node->numCols);
-       WRITE_OID_ARRAY(sortOperators, node->numCols);
-       WRITE_OID_ARRAY(collations, node->numCols);
-       WRITE_BOOL_ARRAY(nullsFirst, node->numCols);
-}
-
-static void
-_outSort(StringInfo str, const Sort *node)
-{
-       WRITE_NODE_TYPE("SORT");
-
-       _outSortInfo(str, node);
-}
-
-static void
-_outIncrementalSort(StringInfo str, const IncrementalSort *node)
-{
-       WRITE_NODE_TYPE("INCREMENTALSORT");
-
-       _outSortInfo(str, (const Sort *) node);
-
-       WRITE_INT_FIELD(nPresortedCols);
-}
-
-static void
-_outUnique(StringInfo str, const Unique *node)
-{
-       WRITE_NODE_TYPE("UNIQUE");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(uniqColIdx, node->numCols);
-       WRITE_OID_ARRAY(uniqOperators, node->numCols);
-       WRITE_OID_ARRAY(uniqCollations, node->numCols);
-}
-
-static void
-_outHash(StringInfo str, const Hash *node)
-{
-       WRITE_NODE_TYPE("HASH");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_NODE_FIELD(hashkeys);
-       WRITE_OID_FIELD(skewTable);
-       WRITE_INT_FIELD(skewColumn);
-       WRITE_BOOL_FIELD(skewInherit);
-       WRITE_FLOAT_FIELD(rows_total, "%.0f");
-}
-
-static void
-_outSetOp(StringInfo str, const SetOp *node)
-{
-       WRITE_NODE_TYPE("SETOP");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_ENUM_FIELD(cmd, SetOpCmd);
-       WRITE_ENUM_FIELD(strategy, SetOpStrategy);
-       WRITE_INT_FIELD(numCols);
-       WRITE_ATTRNUMBER_ARRAY(dupColIdx, node->numCols);
-       WRITE_OID_ARRAY(dupOperators, node->numCols);
-       WRITE_OID_ARRAY(dupCollations, node->numCols);
-       WRITE_INT_FIELD(flagColIdx);
-       WRITE_INT_FIELD(firstFlag);
-       WRITE_LONG_FIELD(numGroups);
-}
-
-static void
-_outLockRows(StringInfo str, const LockRows *node)
-{
-       WRITE_NODE_TYPE("LOCKROWS");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_NODE_FIELD(rowMarks);
-       WRITE_INT_FIELD(epqParam);
-}
-
-static void
-_outLimit(StringInfo str, const Limit *node)
-{
-       WRITE_NODE_TYPE("LIMIT");
-
-       _outPlanInfo(str, (const Plan *) node);
-
-       WRITE_NODE_FIELD(limitOffset);
-       WRITE_NODE_FIELD(limitCount);
-       WRITE_ENUM_FIELD(limitOption, LimitOption);
-       WRITE_INT_FIELD(uniqNumCols);
-       WRITE_ATTRNUMBER_ARRAY(uniqColIdx, node->uniqNumCols);
-       WRITE_OID_ARRAY(uniqOperators, node->uniqNumCols);
-       WRITE_OID_ARRAY(uniqCollations, node->uniqNumCols);
-}
-
-static void
-_outNestLoopParam(StringInfo str, const NestLoopParam *node)
-{
-       WRITE_NODE_TYPE("NESTLOOPPARAM");
-
-       WRITE_INT_FIELD(paramno);
-       WRITE_NODE_FIELD(paramval);
-}
-
-static void
-_outPlanRowMark(StringInfo str, const PlanRowMark *node)
-{
-       WRITE_NODE_TYPE("PLANROWMARK");
-
-       WRITE_UINT_FIELD(rti);
-       WRITE_UINT_FIELD(prti);
-       WRITE_UINT_FIELD(rowmarkId);
-       WRITE_ENUM_FIELD(markType, RowMarkType);
-       WRITE_INT_FIELD(allMarkTypes);
-       WRITE_ENUM_FIELD(strength, LockClauseStrength);
-       WRITE_ENUM_FIELD(waitPolicy, LockWaitPolicy);
-       WRITE_BOOL_FIELD(isParent);
-}
-
-static void
-_outPartitionPruneInfo(StringInfo str, const PartitionPruneInfo *node)
-{
-       WRITE_NODE_TYPE("PARTITIONPRUNEINFO");
-
-       WRITE_NODE_FIELD(prune_infos);
-       WRITE_BITMAPSET_FIELD(other_subplans);
-}
-
-static void
-_outPartitionedRelPruneInfo(StringInfo str, const PartitionedRelPruneInfo *node)
-{
-       WRITE_NODE_TYPE("PARTITIONEDRELPRUNEINFO");
-
-       WRITE_UINT_FIELD(rtindex);
-       WRITE_BITMAPSET_FIELD(present_parts);
-       WRITE_INT_FIELD(nparts);
-       WRITE_INT_ARRAY(subplan_map, node->nparts);
-       WRITE_INT_ARRAY(subpart_map, node->nparts);
-       WRITE_OID_ARRAY(relid_map, node->nparts);
-       WRITE_NODE_FIELD(initial_pruning_steps);
-       WRITE_NODE_FIELD(exec_pruning_steps);
-       WRITE_BITMAPSET_FIELD(execparamids);
-}
-
-static void
-_outPartitionPruneStepOp(StringInfo str, const PartitionPruneStepOp *node)
-{
-       WRITE_NODE_TYPE("PARTITIONPRUNESTEPOP");
-
-       WRITE_INT_FIELD(step.step_id);
-       WRITE_INT_FIELD(opstrategy);
-       WRITE_NODE_FIELD(exprs);
-       WRITE_NODE_FIELD(cmpfns);
-       WRITE_BITMAPSET_FIELD(nullkeys);
-}
-
-static void
-_outPartitionPruneStepCombine(StringInfo str, const PartitionPruneStepCombine *node)
-{
-       WRITE_NODE_TYPE("PARTITIONPRUNESTEPCOMBINE");
-
-       WRITE_INT_FIELD(step.step_id);
-       WRITE_ENUM_FIELD(combineOp, PartitionPruneCombineOp);
-       WRITE_NODE_FIELD(source_stepids);
-}
-
-static void
-_outPlanInvalItem(StringInfo str, const PlanInvalItem *node)
-{
-       WRITE_NODE_TYPE("PLANINVALITEM");
-
-       WRITE_INT_FIELD(cacheId);
-       WRITE_UINT_FIELD(hashValue);
-}
-
-/*****************************************************************************
- *
- *     Stuff from primnodes.h.
- *
- *****************************************************************************/
-
-static void
-_outAlias(StringInfo str, const Alias *node)
-{
-       WRITE_NODE_TYPE("ALIAS");
-
-       WRITE_STRING_FIELD(aliasname);
-       WRITE_NODE_FIELD(colnames);
-}
-
-static void
-_outRangeVar(StringInfo str, const RangeVar *node)
-{
-       WRITE_NODE_TYPE("RANGEVAR");
-
-       /*
-        * we deliberately ignore catalogname here, since it is presently not
-        * semantically meaningful
-        */
-       WRITE_STRING_FIELD(schemaname);
-       WRITE_STRING_FIELD(relname);
-       WRITE_BOOL_FIELD(inh);
-       WRITE_CHAR_FIELD(relpersistence);
-       WRITE_NODE_FIELD(alias);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outTableFunc(StringInfo str, const TableFunc *node)
-{
-       WRITE_NODE_TYPE("TABLEFUNC");
-
-       WRITE_ENUM_FIELD(functype, TableFuncType);
-       WRITE_NODE_FIELD(ns_uris);
-       WRITE_NODE_FIELD(ns_names);
-       WRITE_NODE_FIELD(docexpr);
-       WRITE_NODE_FIELD(rowexpr);
-       WRITE_NODE_FIELD(colnames);
-       WRITE_NODE_FIELD(coltypes);
-       WRITE_NODE_FIELD(coltypmods);
-       WRITE_NODE_FIELD(colcollations);
-       WRITE_NODE_FIELD(colexprs);
-       WRITE_NODE_FIELD(coldefexprs);
-       WRITE_NODE_FIELD(colvalexprs);
-       WRITE_BITMAPSET_FIELD(notnulls);
-       WRITE_NODE_FIELD(plan);
-       WRITE_INT_FIELD(ordinalitycol);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outIntoClause(StringInfo str, const IntoClause *node)
-{
-       WRITE_NODE_TYPE("INTOCLAUSE");
-
-       WRITE_NODE_FIELD(rel);
-       WRITE_NODE_FIELD(colNames);
-       WRITE_STRING_FIELD(accessMethod);
-       WRITE_NODE_FIELD(options);
-       WRITE_ENUM_FIELD(onCommit, OnCommitAction);
-       WRITE_STRING_FIELD(tableSpaceName);
-       WRITE_NODE_FIELD(viewQuery);
-       WRITE_BOOL_FIELD(skipData);
-}
-
-static void
-_outVar(StringInfo str, const Var *node)
-{
-       WRITE_NODE_TYPE("VAR");
-
-       WRITE_INT_FIELD(varno);
-       WRITE_INT_FIELD(varattno);
-       WRITE_OID_FIELD(vartype);
-       WRITE_INT_FIELD(vartypmod);
-       WRITE_OID_FIELD(varcollid);
-       WRITE_UINT_FIELD(varlevelsup);
-       WRITE_UINT_FIELD(varnosyn);
-       WRITE_INT_FIELD(varattnosyn);
-       WRITE_LOCATION_FIELD(location);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outConst(StringInfo str, const Const *node)
-{
-       WRITE_NODE_TYPE("CONST");
-
-       WRITE_OID_FIELD(consttype);
-       WRITE_INT_FIELD(consttypmod);
-       WRITE_OID_FIELD(constcollid);
-       WRITE_INT_FIELD(constlen);
-       WRITE_BOOL_FIELD(constbyval);
-       WRITE_BOOL_FIELD(constisnull);
-       WRITE_LOCATION_FIELD(location);
-
-       appendStringInfoString(str, " :constvalue ");
-       if (node->constisnull)
-               appendStringInfoString(str, "<>");
-       else
-               outDatum(str, node->constvalue, node->constlen, node->constbyval);
-}
-
-#ifdef OBSOLETE
-static void
-_outParam(StringInfo str, const Param *node)
-{
-       WRITE_NODE_TYPE("PARAM");
-
-       WRITE_ENUM_FIELD(paramkind, ParamKind);
-       WRITE_INT_FIELD(paramid);
-       WRITE_OID_FIELD(paramtype);
-       WRITE_INT_FIELD(paramtypmod);
-       WRITE_OID_FIELD(paramcollid);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outAggref(StringInfo str, const Aggref *node)
-{
-       WRITE_NODE_TYPE("AGGREF");
-
-       WRITE_OID_FIELD(aggfnoid);
-       WRITE_OID_FIELD(aggtype);
-       WRITE_OID_FIELD(aggcollid);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_OID_FIELD(aggtranstype);
-       WRITE_NODE_FIELD(aggargtypes);
-       WRITE_NODE_FIELD(aggdirectargs);
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(aggorder);
-       WRITE_NODE_FIELD(aggdistinct);
-       WRITE_NODE_FIELD(aggfilter);
-       WRITE_BOOL_FIELD(aggstar);
-       WRITE_BOOL_FIELD(aggvariadic);
-       WRITE_CHAR_FIELD(aggkind);
-       WRITE_UINT_FIELD(agglevelsup);
-       WRITE_ENUM_FIELD(aggsplit, AggSplit);
-       WRITE_INT_FIELD(aggno);
-       WRITE_INT_FIELD(aggtransno);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outGroupingFunc(StringInfo str, const GroupingFunc *node)
-{
-       WRITE_NODE_TYPE("GROUPINGFUNC");
-
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(refs);
-       WRITE_NODE_FIELD(cols);
-       WRITE_UINT_FIELD(agglevelsup);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outWindowFunc(StringInfo str, const WindowFunc *node)
-{
-       WRITE_NODE_TYPE("WINDOWFUNC");
-
-       WRITE_OID_FIELD(winfnoid);
-       WRITE_OID_FIELD(wintype);
-       WRITE_OID_FIELD(wincollid);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(aggfilter);
-       WRITE_UINT_FIELD(winref);
-       WRITE_BOOL_FIELD(winstar);
-       WRITE_BOOL_FIELD(winagg);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outSubscriptingRef(StringInfo str, const SubscriptingRef *node)
-{
-       WRITE_NODE_TYPE("SUBSCRIPTINGREF");
-
-       WRITE_OID_FIELD(refcontainertype);
-       WRITE_OID_FIELD(refelemtype);
-       WRITE_OID_FIELD(refrestype);
-       WRITE_INT_FIELD(reftypmod);
-       WRITE_OID_FIELD(refcollid);
-       WRITE_NODE_FIELD(refupperindexpr);
-       WRITE_NODE_FIELD(reflowerindexpr);
-       WRITE_NODE_FIELD(refexpr);
-       WRITE_NODE_FIELD(refassgnexpr);
-}
-
-static void
-_outFuncExpr(StringInfo str, const FuncExpr *node)
-{
-       WRITE_NODE_TYPE("FUNCEXPR");
-
-       WRITE_OID_FIELD(funcid);
-       WRITE_OID_FIELD(funcresulttype);
-       WRITE_BOOL_FIELD(funcretset);
-       WRITE_BOOL_FIELD(funcvariadic);
-       WRITE_ENUM_FIELD(funcformat, CoercionForm);
-       WRITE_OID_FIELD(funccollid);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outNamedArgExpr(StringInfo str, const NamedArgExpr *node)
-{
-       WRITE_NODE_TYPE("NAMEDARGEXPR");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_STRING_FIELD(name);
-       WRITE_INT_FIELD(argnumber);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outOpExpr(StringInfo str, const OpExpr *node)
-{
-       WRITE_NODE_TYPE("OPEXPR");
-
-       WRITE_OID_FIELD(opno);
-       WRITE_OID_FIELD(opfuncid);
-       WRITE_OID_FIELD(opresulttype);
-       WRITE_BOOL_FIELD(opretset);
-       WRITE_OID_FIELD(opcollid);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outDistinctExpr(StringInfo str, const DistinctExpr *node)
-{
-       WRITE_NODE_TYPE("DISTINCTEXPR");
-
-       WRITE_OID_FIELD(opno);
-       WRITE_OID_FIELD(opfuncid);
-       WRITE_OID_FIELD(opresulttype);
-       WRITE_BOOL_FIELD(opretset);
-       WRITE_OID_FIELD(opcollid);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outNullIfExpr(StringInfo str, const NullIfExpr *node)
-{
-       WRITE_NODE_TYPE("NULLIFEXPR");
-
-       WRITE_OID_FIELD(opno);
-       WRITE_OID_FIELD(opfuncid);
-       WRITE_OID_FIELD(opresulttype);
-       WRITE_BOOL_FIELD(opretset);
-       WRITE_OID_FIELD(opcollid);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outScalarArrayOpExpr(StringInfo str, const ScalarArrayOpExpr *node)
-{
-       WRITE_NODE_TYPE("SCALARARRAYOPEXPR");
-
-       WRITE_OID_FIELD(opno);
-       WRITE_OID_FIELD(opfuncid);
-       WRITE_OID_FIELD(hashfuncid);
-       WRITE_OID_FIELD(negfuncid);
-       WRITE_BOOL_FIELD(useOr);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outBoolExpr(StringInfo str, const BoolExpr *node)
-{
-       char       *opstr = NULL;
-
-       WRITE_NODE_TYPE("BOOLEXPR");
-
-       /* do-it-yourself enum representation */
-       switch (node->boolop)
-       {
-               case AND_EXPR:
-                       opstr = "and";
-                       break;
-               case OR_EXPR:
-                       opstr = "or";
-                       break;
-               case NOT_EXPR:
-                       opstr = "not";
-                       break;
-       }
-       appendStringInfoString(str, " :boolop ");
-       outToken(str, opstr);
-
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-
-#ifdef OBSOLETE
-static void
-_outSubLink(StringInfo str, const SubLink *node)
-{
-       WRITE_NODE_TYPE("SUBLINK");
-
-       WRITE_ENUM_FIELD(subLinkType, SubLinkType);
-       WRITE_INT_FIELD(subLinkId);
-       WRITE_NODE_FIELD(testexpr);
-       WRITE_NODE_FIELD(operName);
-       WRITE_NODE_FIELD(subselect);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outSubPlan(StringInfo str, const SubPlan *node)
-{
-       WRITE_NODE_TYPE("SUBPLAN");
-
-       WRITE_ENUM_FIELD(subLinkType, SubLinkType);
-       WRITE_NODE_FIELD(testexpr);
-       WRITE_NODE_FIELD(paramIds);
-       WRITE_INT_FIELD(plan_id);
-       WRITE_STRING_FIELD(plan_name);
-       WRITE_OID_FIELD(firstColType);
-       WRITE_INT_FIELD(firstColTypmod);
-       WRITE_OID_FIELD(firstColCollation);
-       WRITE_BOOL_FIELD(useHashTable);
-       WRITE_BOOL_FIELD(unknownEqFalse);
-       WRITE_BOOL_FIELD(parallel_safe);
-       WRITE_NODE_FIELD(setParam);
-       WRITE_NODE_FIELD(parParam);
-       WRITE_NODE_FIELD(args);
-       WRITE_FLOAT_FIELD(startup_cost, "%.2f");
-       WRITE_FLOAT_FIELD(per_call_cost, "%.2f");
-}
-
-static void
-_outAlternativeSubPlan(StringInfo str, const AlternativeSubPlan *node)
-{
-       WRITE_NODE_TYPE("ALTERNATIVESUBPLAN");
-
-       WRITE_NODE_FIELD(subplans);
-}
-
-static void
-_outFieldSelect(StringInfo str, const FieldSelect *node)
-{
-       WRITE_NODE_TYPE("FIELDSELECT");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_INT_FIELD(fieldnum);
-       WRITE_OID_FIELD(resulttype);
-       WRITE_INT_FIELD(resulttypmod);
-       WRITE_OID_FIELD(resultcollid);
-}
-
-static void
-_outFieldStore(StringInfo str, const FieldStore *node)
-{
-       WRITE_NODE_TYPE("FIELDSTORE");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_NODE_FIELD(newvals);
-       WRITE_NODE_FIELD(fieldnums);
-       WRITE_OID_FIELD(resulttype);
-}
-
-static void
-_outRelabelType(StringInfo str, const RelabelType *node)
-{
-       WRITE_NODE_TYPE("RELABELTYPE");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_OID_FIELD(resulttype);
-       WRITE_INT_FIELD(resulttypmod);
-       WRITE_OID_FIELD(resultcollid);
-       WRITE_ENUM_FIELD(relabelformat, CoercionForm);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCoerceViaIO(StringInfo str, const CoerceViaIO *node)
-{
-       WRITE_NODE_TYPE("COERCEVIAIO");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_OID_FIELD(resulttype);
-       WRITE_OID_FIELD(resultcollid);
-       WRITE_ENUM_FIELD(coerceformat, CoercionForm);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outArrayCoerceExpr(StringInfo str, const ArrayCoerceExpr *node)
-{
-       WRITE_NODE_TYPE("ARRAYCOERCEEXPR");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_NODE_FIELD(elemexpr);
-       WRITE_OID_FIELD(resulttype);
-       WRITE_INT_FIELD(resulttypmod);
-       WRITE_OID_FIELD(resultcollid);
-       WRITE_ENUM_FIELD(coerceformat, CoercionForm);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outConvertRowtypeExpr(StringInfo str, const ConvertRowtypeExpr *node)
-{
-       WRITE_NODE_TYPE("CONVERTROWTYPEEXPR");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_OID_FIELD(resulttype);
-       WRITE_ENUM_FIELD(convertformat, CoercionForm);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCollateExpr(StringInfo str, const CollateExpr *node)
-{
-       WRITE_NODE_TYPE("COLLATEEXPR");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_OID_FIELD(collOid);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCaseExpr(StringInfo str, const CaseExpr *node)
-{
-       WRITE_NODE_TYPE("CASEEXPR");
-
-       WRITE_OID_FIELD(casetype);
-       WRITE_OID_FIELD(casecollid);
-       WRITE_NODE_FIELD(arg);
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(defresult);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCaseWhen(StringInfo str, const CaseWhen *node)
-{
-       WRITE_NODE_TYPE("CASEWHEN");
-
-       WRITE_NODE_FIELD(expr);
-       WRITE_NODE_FIELD(result);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCaseTestExpr(StringInfo str, const CaseTestExpr *node)
-{
-       WRITE_NODE_TYPE("CASETESTEXPR");
-
-       WRITE_OID_FIELD(typeId);
-       WRITE_INT_FIELD(typeMod);
-       WRITE_OID_FIELD(collation);
-}
-
-static void
-_outArrayExpr(StringInfo str, const ArrayExpr *node)
-{
-       WRITE_NODE_TYPE("ARRAYEXPR");
-
-       WRITE_OID_FIELD(array_typeid);
-       WRITE_OID_FIELD(array_collid);
-       WRITE_OID_FIELD(element_typeid);
-       WRITE_NODE_FIELD(elements);
-       WRITE_BOOL_FIELD(multidims);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outRowExpr(StringInfo str, const RowExpr *node)
-{
-       WRITE_NODE_TYPE("ROWEXPR");
-
-       WRITE_NODE_FIELD(args);
-       WRITE_OID_FIELD(row_typeid);
-       WRITE_ENUM_FIELD(row_format, CoercionForm);
-       WRITE_NODE_FIELD(colnames);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outRowCompareExpr(StringInfo str, const RowCompareExpr *node)
-{
-       WRITE_NODE_TYPE("ROWCOMPAREEXPR");
-
-       WRITE_ENUM_FIELD(rctype, RowCompareType);
-       WRITE_NODE_FIELD(opnos);
-       WRITE_NODE_FIELD(opfamilies);
-       WRITE_NODE_FIELD(inputcollids);
-       WRITE_NODE_FIELD(largs);
-       WRITE_NODE_FIELD(rargs);
-}
-
-static void
-_outCoalesceExpr(StringInfo str, const CoalesceExpr *node)
-{
-       WRITE_NODE_TYPE("COALESCEEXPR");
-
-       WRITE_OID_FIELD(coalescetype);
-       WRITE_OID_FIELD(coalescecollid);
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outMinMaxExpr(StringInfo str, const MinMaxExpr *node)
-{
-       WRITE_NODE_TYPE("MINMAXEXPR");
-
-       WRITE_OID_FIELD(minmaxtype);
-       WRITE_OID_FIELD(minmaxcollid);
-       WRITE_OID_FIELD(inputcollid);
-       WRITE_ENUM_FIELD(op, MinMaxOp);
-       WRITE_NODE_FIELD(args);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outSQLValueFunction(StringInfo str, const SQLValueFunction *node)
-{
-       WRITE_NODE_TYPE("SQLVALUEFUNCTION");
-
-       WRITE_ENUM_FIELD(op, SQLValueFunctionOp);
-       WRITE_OID_FIELD(type);
-       WRITE_INT_FIELD(typmod);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outXmlExpr(StringInfo str, const XmlExpr *node)
-{
-       WRITE_NODE_TYPE("XMLEXPR");
-
-       WRITE_ENUM_FIELD(op, XmlExprOp);
-       WRITE_STRING_FIELD(name);
-       WRITE_NODE_FIELD(named_args);
-       WRITE_NODE_FIELD(arg_names);
-       WRITE_NODE_FIELD(args);
-       WRITE_ENUM_FIELD(xmloption, XmlOptionType);
-       WRITE_OID_FIELD(type);
-       WRITE_INT_FIELD(typmod);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outNullTest(StringInfo str, const NullTest *node)
-{
-       WRITE_NODE_TYPE("NULLTEST");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_ENUM_FIELD(nulltesttype, NullTestType);
-       WRITE_BOOL_FIELD(argisrow);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outBooleanTest(StringInfo str, const BooleanTest *node)
-{
-       WRITE_NODE_TYPE("BOOLEANTEST");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_ENUM_FIELD(booltesttype, BoolTestType);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCoerceToDomain(StringInfo str, const CoerceToDomain *node)
-{
-       WRITE_NODE_TYPE("COERCETODOMAIN");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_OID_FIELD(resulttype);
-       WRITE_INT_FIELD(resulttypmod);
-       WRITE_OID_FIELD(resultcollid);
-       WRITE_ENUM_FIELD(coercionformat, CoercionForm);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCoerceToDomainValue(StringInfo str, const CoerceToDomainValue *node)
-{
-       WRITE_NODE_TYPE("COERCETODOMAINVALUE");
-
-       WRITE_OID_FIELD(typeId);
-       WRITE_INT_FIELD(typeMod);
-       WRITE_OID_FIELD(collation);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outSetToDefault(StringInfo str, const SetToDefault *node)
-{
-       WRITE_NODE_TYPE("SETTODEFAULT");
-
-       WRITE_OID_FIELD(typeId);
-       WRITE_INT_FIELD(typeMod);
-       WRITE_OID_FIELD(collation);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCurrentOfExpr(StringInfo str, const CurrentOfExpr *node)
-{
-       WRITE_NODE_TYPE("CURRENTOFEXPR");
-
-       WRITE_UINT_FIELD(cvarno);
-       WRITE_STRING_FIELD(cursor_name);
-       WRITE_INT_FIELD(cursor_param);
-}
-
-static void
-_outNextValueExpr(StringInfo str, const NextValueExpr *node)
-{
-       WRITE_NODE_TYPE("NEXTVALUEEXPR");
-
-       WRITE_OID_FIELD(seqid);
-       WRITE_OID_FIELD(typeId);
-}
-
-static void
-_outInferenceElem(StringInfo str, const InferenceElem *node)
-{
-       WRITE_NODE_TYPE("INFERENCEELEM");
-
-       WRITE_NODE_FIELD(expr);
-       WRITE_OID_FIELD(infercollid);
-       WRITE_OID_FIELD(inferopclass);
-}
-
-static void
-_outTargetEntry(StringInfo str, const TargetEntry *node)
-{
-       WRITE_NODE_TYPE("TARGETENTRY");
-
-       WRITE_NODE_FIELD(expr);
-       WRITE_INT_FIELD(resno);
-       WRITE_STRING_FIELD(resname);
-       WRITE_UINT_FIELD(ressortgroupref);
-       WRITE_OID_FIELD(resorigtbl);
-       WRITE_INT_FIELD(resorigcol);
-       WRITE_BOOL_FIELD(resjunk);
-}
-
-static void
-_outRangeTblRef(StringInfo str, const RangeTblRef *node)
-{
-       WRITE_NODE_TYPE("RANGETBLREF");
-
-       WRITE_INT_FIELD(rtindex);
-}
-
-static void
-_outJoinExpr(StringInfo str, const JoinExpr *node)
-{
-       WRITE_NODE_TYPE("JOINEXPR");
-
-       WRITE_ENUM_FIELD(jointype, JoinType);
-       WRITE_BOOL_FIELD(isNatural);
-       WRITE_NODE_FIELD(larg);
-       WRITE_NODE_FIELD(rarg);
-       WRITE_NODE_FIELD(usingClause);
-       WRITE_NODE_FIELD(join_using_alias);
-       WRITE_NODE_FIELD(quals);
-       WRITE_NODE_FIELD(alias);
-       WRITE_INT_FIELD(rtindex);
-}
-
-static void
-_outFromExpr(StringInfo str, const FromExpr *node)
-{
-       WRITE_NODE_TYPE("FROMEXPR");
-
-       WRITE_NODE_FIELD(fromlist);
-       WRITE_NODE_FIELD(quals);
-}
-
-static void
-_outOnConflictExpr(StringInfo str, const OnConflictExpr *node)
-{
-       WRITE_NODE_TYPE("ONCONFLICTEXPR");
-
-       WRITE_ENUM_FIELD(action, OnConflictAction);
-       WRITE_NODE_FIELD(arbiterElems);
-       WRITE_NODE_FIELD(arbiterWhere);
-       WRITE_OID_FIELD(constraint);
-       WRITE_NODE_FIELD(onConflictSet);
-       WRITE_NODE_FIELD(onConflictWhere);
-       WRITE_INT_FIELD(exclRelIndex);
-       WRITE_NODE_FIELD(exclRelTlist);
-}
-
-static void
-_outJsonFormat(StringInfo str, const JsonFormat *node)
-{
-       WRITE_NODE_TYPE("JSONFORMAT");
-
-       WRITE_ENUM_FIELD(format_type, JsonFormatType);
-       WRITE_ENUM_FIELD(encoding, JsonEncoding);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outJsonReturning(StringInfo str, const JsonReturning *node)
-{
-       WRITE_NODE_TYPE("JSONRETURNING");
-
-       WRITE_NODE_FIELD(format);
-       WRITE_OID_FIELD(typid);
-       WRITE_INT_FIELD(typmod);
-}
-
-static void
-_outJsonValueExpr(StringInfo str, const JsonValueExpr *node)
-{
-       WRITE_NODE_TYPE("JSONVALUEEXPR");
-
-       WRITE_NODE_FIELD(raw_expr);
-       WRITE_NODE_FIELD(formatted_expr);
-       WRITE_NODE_FIELD(format);
-}
-
-static void
-_outJsonConstructorExpr(StringInfo str, const JsonConstructorExpr *node)
-{
-       WRITE_NODE_TYPE("JSONCONSTRUCTOREXPR");
-
-       WRITE_ENUM_FIELD(type, JsonConstructorType);
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(func);
-       WRITE_NODE_FIELD(coercion);
-       WRITE_NODE_FIELD(returning);
-       WRITE_BOOL_FIELD(absent_on_null);
-       WRITE_BOOL_FIELD(unique);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outJsonIsPredicate(StringInfo str, const JsonIsPredicate *node)
-{
-       WRITE_NODE_TYPE("JSONISPREDICATE");
-
-       WRITE_NODE_FIELD(expr);
-       WRITE_NODE_FIELD(format);
-       WRITE_ENUM_FIELD(item_type, JsonValueType);
-       WRITE_BOOL_FIELD(unique_keys);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outJsonBehavior(StringInfo str, const JsonBehavior *node)
-{
-       WRITE_NODE_TYPE("JSONBEHAVIOR");
-
-       WRITE_ENUM_FIELD(btype, JsonBehaviorType);
-       WRITE_NODE_FIELD(default_expr);
-}
-
-static void
-_outJsonExpr(StringInfo str, const JsonExpr *node)
-{
-       WRITE_NODE_TYPE("JSONEXPR");
-
-       WRITE_ENUM_FIELD(op, JsonExprOp);
-       WRITE_NODE_FIELD(formatted_expr);
-       WRITE_NODE_FIELD(result_coercion);
-       WRITE_NODE_FIELD(format);
-       WRITE_NODE_FIELD(path_spec);
-       WRITE_NODE_FIELD(passing_names);
-       WRITE_NODE_FIELD(passing_values);
-       WRITE_NODE_FIELD(returning);
-       WRITE_NODE_FIELD(on_empty);
-       WRITE_NODE_FIELD(on_error);
-       WRITE_NODE_FIELD(coercions);
-       WRITE_ENUM_FIELD(wrapper, JsonWrapper);
-       WRITE_BOOL_FIELD(omit_quotes);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outJsonCoercion(StringInfo str, const JsonCoercion *node)
-{
-       WRITE_NODE_TYPE("JSONCOERCION");
-
-       WRITE_NODE_FIELD(expr);
-       WRITE_BOOL_FIELD(via_populate);
-       WRITE_BOOL_FIELD(via_io);
-       WRITE_OID_FIELD(collation);
-}
-
-static void
-_outJsonItemCoercions(StringInfo str, const JsonItemCoercions *node)
-{
-       WRITE_NODE_TYPE("JSONITEMCOERCIONS");
-
-       WRITE_NODE_FIELD(null);
-       WRITE_NODE_FIELD(string);
-       WRITE_NODE_FIELD(numeric);
-       WRITE_NODE_FIELD(boolean);
-       WRITE_NODE_FIELD(date);
-       WRITE_NODE_FIELD(time);
-       WRITE_NODE_FIELD(timetz);
-       WRITE_NODE_FIELD(timestamp);
-       WRITE_NODE_FIELD(timestamptz);
-       WRITE_NODE_FIELD(composite);
-}
-
-static void
-_outJsonTableParent(StringInfo str, const JsonTableParent *node)
-{
-       WRITE_NODE_TYPE("JSONTABLEPARENT");
-
-       WRITE_NODE_FIELD(path);
-       WRITE_STRING_FIELD(name);
-       WRITE_NODE_FIELD(child);
-       WRITE_BOOL_FIELD(outerJoin);
-       WRITE_INT_FIELD(colMin);
-       WRITE_INT_FIELD(colMax);
-       WRITE_BOOL_FIELD(errorOnError);
-}
-
-static void
-_outJsonTableSibling(StringInfo str, const JsonTableSibling *node)
-{
-       WRITE_NODE_TYPE("JSONTABLESIBLING");
-
-       WRITE_NODE_FIELD(larg);
-       WRITE_NODE_FIELD(rarg);
-       WRITE_BOOL_FIELD(cross);
-}
-
-/*****************************************************************************
- *
- *     Stuff from pathnodes.h.
- *
- *****************************************************************************/
-
-/*
- * print the basic stuff of all nodes that inherit from Path
- *
- * Note we do NOT print the parent, else we'd be in infinite recursion.
- * We can print the parent's relids for identification purposes, though.
- * We print the pathtarget only if it's not the default one for the rel.
- * We also do not print the whole of param_info, since it's printed by
- * _outRelOptInfo; it's sufficient and less cluttering to print just the
- * required outer relids.
- */
-static void
-_outPathInfo(StringInfo str, const Path *node)
-{
-       WRITE_ENUM_FIELD(pathtype, NodeTag);
-       appendStringInfoString(str, " :parent_relids ");
-       outBitmapset(str, node->parent->relids);
-       if (node->pathtarget != node->parent->reltarget)
-               WRITE_NODE_FIELD(pathtarget);
-       appendStringInfoString(str, " :required_outer ");
-       if (node->param_info)
-               outBitmapset(str, node->param_info->ppi_req_outer);
-       else
-               outBitmapset(str, NULL);
-       WRITE_BOOL_FIELD(parallel_aware);
-       WRITE_BOOL_FIELD(parallel_safe);
-       WRITE_INT_FIELD(parallel_workers);
-       WRITE_FLOAT_FIELD(rows, "%.0f");
-       WRITE_FLOAT_FIELD(startup_cost, "%.2f");
-       WRITE_FLOAT_FIELD(total_cost, "%.2f");
-       WRITE_NODE_FIELD(pathkeys);
-}
-
-/*
- * print the basic stuff of all nodes that inherit from JoinPath
- */
-static void
-_outJoinPathInfo(StringInfo str, const JoinPath *node)
-{
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_ENUM_FIELD(jointype, JoinType);
-       WRITE_BOOL_FIELD(inner_unique);
-       WRITE_NODE_FIELD(outerjoinpath);
-       WRITE_NODE_FIELD(innerjoinpath);
-       WRITE_NODE_FIELD(joinrestrictinfo);
-}
-
-static void
-_outPath(StringInfo str, const Path *node)
-{
-       WRITE_NODE_TYPE("PATH");
-
-       _outPathInfo(str, (const Path *) node);
-}
-
-static void
-_outIndexPath(StringInfo str, const IndexPath *node)
-{
-       WRITE_NODE_TYPE("INDEXPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(indexinfo);
-       WRITE_NODE_FIELD(indexclauses);
-       WRITE_NODE_FIELD(indexorderbys);
-       WRITE_NODE_FIELD(indexorderbycols);
-       WRITE_ENUM_FIELD(indexscandir, ScanDirection);
-       WRITE_FLOAT_FIELD(indextotalcost, "%.2f");
-       WRITE_FLOAT_FIELD(indexselectivity, "%.4f");
-}
-
-static void
-_outBitmapHeapPath(StringInfo str, const BitmapHeapPath *node)
-{
-       WRITE_NODE_TYPE("BITMAPHEAPPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(bitmapqual);
-}
-
-static void
-_outBitmapAndPath(StringInfo str, const BitmapAndPath *node)
-{
-       WRITE_NODE_TYPE("BITMAPANDPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(bitmapquals);
-       WRITE_FLOAT_FIELD(bitmapselectivity, "%.4f");
-}
-
-static void
-_outBitmapOrPath(StringInfo str, const BitmapOrPath *node)
-{
-       WRITE_NODE_TYPE("BITMAPORPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(bitmapquals);
-       WRITE_FLOAT_FIELD(bitmapselectivity, "%.4f");
-}
-
-static void
-_outTidPath(StringInfo str, const TidPath *node)
-{
-       WRITE_NODE_TYPE("TIDPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(tidquals);
-}
-
-static void
-_outTidRangePath(StringInfo str, const TidRangePath *node)
-{
-       WRITE_NODE_TYPE("TIDRANGEPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(tidrangequals);
-}
-
-static void
-_outSubqueryScanPath(StringInfo str, const SubqueryScanPath *node)
-{
-       WRITE_NODE_TYPE("SUBQUERYSCANPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-}
-
-static void
-_outForeignPath(StringInfo str, const ForeignPath *node)
-{
-       WRITE_NODE_TYPE("FOREIGNPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(fdw_outerpath);
-       WRITE_NODE_FIELD(fdw_private);
-}
-
-static void
-_outCustomPath(StringInfo str, const CustomPath *node)
-{
-       WRITE_NODE_TYPE("CUSTOMPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_UINT_FIELD(flags);
-       WRITE_NODE_FIELD(custom_paths);
-       WRITE_NODE_FIELD(custom_private);
-       appendStringInfoString(str, " :methods ");
-       outToken(str, node->methods->CustomName);
-}
-
-static void
-_outAppendPath(StringInfo str, const AppendPath *node)
-{
-       WRITE_NODE_TYPE("APPENDPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpaths);
-       WRITE_INT_FIELD(first_partial_path);
-       WRITE_FLOAT_FIELD(limit_tuples, "%.0f");
-}
-
-static void
-_outMergeAppendPath(StringInfo str, const MergeAppendPath *node)
-{
-       WRITE_NODE_TYPE("MERGEAPPENDPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpaths);
-       WRITE_FLOAT_FIELD(limit_tuples, "%.0f");
-}
-
-static void
-_outGroupResultPath(StringInfo str, const GroupResultPath *node)
-{
-       WRITE_NODE_TYPE("GROUPRESULTPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(quals);
-}
-
-static void
-_outMaterialPath(StringInfo str, const MaterialPath *node)
-{
-       WRITE_NODE_TYPE("MATERIALPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-}
-
-static void
-_outMemoizePath(StringInfo str, const MemoizePath *node)
-{
-       WRITE_NODE_TYPE("MEMOIZEPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_NODE_FIELD(hash_operators);
-       WRITE_NODE_FIELD(param_exprs);
-       WRITE_BOOL_FIELD(singlerow);
-       WRITE_BOOL_FIELD(binary_mode);
-       WRITE_FLOAT_FIELD(calls, "%.0f");
-       WRITE_UINT_FIELD(est_entries);
-}
-
-static void
-_outUniquePath(StringInfo str, const UniquePath *node)
-{
-       WRITE_NODE_TYPE("UNIQUEPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_ENUM_FIELD(umethod, UniquePathMethod);
-       WRITE_NODE_FIELD(in_operators);
-       WRITE_NODE_FIELD(uniq_exprs);
-}
-
-static void
-_outGatherPath(StringInfo str, const GatherPath *node)
-{
-       WRITE_NODE_TYPE("GATHERPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_BOOL_FIELD(single_copy);
-       WRITE_INT_FIELD(num_workers);
-}
-
-static void
-_outProjectionPath(StringInfo str, const ProjectionPath *node)
-{
-       WRITE_NODE_TYPE("PROJECTIONPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_BOOL_FIELD(dummypp);
-}
-
-static void
-_outProjectSetPath(StringInfo str, const ProjectSetPath *node)
-{
-       WRITE_NODE_TYPE("PROJECTSETPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-}
-
-static void
-_outSortPathInfo(StringInfo str, const SortPath *node)
-{
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-}
-
-static void
-_outSortPath(StringInfo str, const SortPath *node)
-{
-       WRITE_NODE_TYPE("SORTPATH");
-
-       _outSortPathInfo(str, node);
-}
-
-static void
-_outIncrementalSortPath(StringInfo str, const IncrementalSortPath *node)
-{
-       WRITE_NODE_TYPE("INCREMENTALSORTPATH");
-
-       _outSortPathInfo(str, (const SortPath *) node);
-
-       WRITE_INT_FIELD(nPresortedCols);
-}
-
-static void
-_outGroupPath(StringInfo str, const GroupPath *node)
-{
-       WRITE_NODE_TYPE("GROUPPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_NODE_FIELD(groupClause);
-       WRITE_NODE_FIELD(qual);
-}
-
-static void
-_outUpperUniquePath(StringInfo str, const UpperUniquePath *node)
-{
-       WRITE_NODE_TYPE("UPPERUNIQUEPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_INT_FIELD(numkeys);
-}
-
-static void
-_outAggPath(StringInfo str, const AggPath *node)
-{
-       WRITE_NODE_TYPE("AGGPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_ENUM_FIELD(aggstrategy, AggStrategy);
-       WRITE_ENUM_FIELD(aggsplit, AggSplit);
-       WRITE_FLOAT_FIELD(numGroups, "%.0f");
-       WRITE_UINT64_FIELD(transitionSpace);
-       WRITE_NODE_FIELD(groupClause);
-       WRITE_NODE_FIELD(qual);
-}
-
-static void
-_outRollupData(StringInfo str, const RollupData *node)
-{
-       WRITE_NODE_TYPE("ROLLUP");
-
-       WRITE_NODE_FIELD(groupClause);
-       WRITE_NODE_FIELD(gsets);
-       WRITE_NODE_FIELD(gsets_data);
-       WRITE_FLOAT_FIELD(numGroups, "%.0f");
-       WRITE_BOOL_FIELD(hashable);
-       WRITE_BOOL_FIELD(is_hashed);
-}
-
-static void
-_outGroupingSetData(StringInfo str, const GroupingSetData *node)
-{
-       WRITE_NODE_TYPE("GSDATA");
-
-       WRITE_NODE_FIELD(set);
-       WRITE_FLOAT_FIELD(numGroups, "%.0f");
-}
-
-static void
-_outGroupingSetsPath(StringInfo str, const GroupingSetsPath *node)
-{
-       WRITE_NODE_TYPE("GROUPINGSETSPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_ENUM_FIELD(aggstrategy, AggStrategy);
-       WRITE_NODE_FIELD(rollups);
-       WRITE_NODE_FIELD(qual);
-       WRITE_UINT64_FIELD(transitionSpace);
-}
-
-static void
-_outMinMaxAggPath(StringInfo str, const MinMaxAggPath *node)
-{
-       WRITE_NODE_TYPE("MINMAXAGGPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(mmaggregates);
-       WRITE_NODE_FIELD(quals);
-}
-
-static void
-_outWindowAggPath(StringInfo str, const WindowAggPath *node)
-{
-       WRITE_NODE_TYPE("WINDOWAGGPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_NODE_FIELD(winclause);
-       WRITE_NODE_FIELD(qual);
-       WRITE_BOOL_FIELD(topwindow);
-}
-
-static void
-_outSetOpPath(StringInfo str, const SetOpPath *node)
-{
-       WRITE_NODE_TYPE("SETOPPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_ENUM_FIELD(cmd, SetOpCmd);
-       WRITE_ENUM_FIELD(strategy, SetOpStrategy);
-       WRITE_NODE_FIELD(distinctList);
-       WRITE_INT_FIELD(flagColIdx);
-       WRITE_INT_FIELD(firstFlag);
-       WRITE_FLOAT_FIELD(numGroups, "%.0f");
-}
-
-static void
-_outRecursiveUnionPath(StringInfo str, const RecursiveUnionPath *node)
-{
-       WRITE_NODE_TYPE("RECURSIVEUNIONPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(leftpath);
-       WRITE_NODE_FIELD(rightpath);
-       WRITE_NODE_FIELD(distinctList);
-       WRITE_INT_FIELD(wtParam);
-       WRITE_FLOAT_FIELD(numGroups, "%.0f");
-}
-
-static void
-_outLockRowsPath(StringInfo str, const LockRowsPath *node)
-{
-       WRITE_NODE_TYPE("LOCKROWSPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_NODE_FIELD(rowMarks);
-       WRITE_INT_FIELD(epqParam);
-}
-
-static void
-_outModifyTablePath(StringInfo str, const ModifyTablePath *node)
-{
-       WRITE_NODE_TYPE("MODIFYTABLEPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_ENUM_FIELD(operation, CmdType);
-       WRITE_BOOL_FIELD(canSetTag);
-       WRITE_UINT_FIELD(nominalRelation);
-       WRITE_UINT_FIELD(rootRelation);
-       WRITE_BOOL_FIELD(partColsUpdated);
-       WRITE_NODE_FIELD(resultRelations);
-       WRITE_NODE_FIELD(updateColnosLists);
-       WRITE_NODE_FIELD(withCheckOptionLists);
-       WRITE_NODE_FIELD(returningLists);
-       WRITE_NODE_FIELD(rowMarks);
-       WRITE_NODE_FIELD(onconflict);
-       WRITE_INT_FIELD(epqParam);
-       WRITE_NODE_FIELD(mergeActionLists);
-}
-
-static void
-_outLimitPath(StringInfo str, const LimitPath *node)
-{
-       WRITE_NODE_TYPE("LIMITPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_NODE_FIELD(limitOffset);
-       WRITE_NODE_FIELD(limitCount);
-       WRITE_ENUM_FIELD(limitOption, LimitOption);
-}
-
-static void
-_outGatherMergePath(StringInfo str, const GatherMergePath *node)
-{
-       WRITE_NODE_TYPE("GATHERMERGEPATH");
-
-       _outPathInfo(str, (const Path *) node);
-
-       WRITE_NODE_FIELD(subpath);
-       WRITE_INT_FIELD(num_workers);
-}
-
-static void
-_outNestPath(StringInfo str, const NestPath *node)
-{
-       WRITE_NODE_TYPE("NESTPATH");
-
-       _outJoinPathInfo(str, (const JoinPath *) node);
-}
-
-static void
-_outMergePath(StringInfo str, const MergePath *node)
-{
-       WRITE_NODE_TYPE("MERGEPATH");
-
-       _outJoinPathInfo(str, (const JoinPath *) node);
-
-       WRITE_NODE_FIELD(path_mergeclauses);
-       WRITE_NODE_FIELD(outersortkeys);
-       WRITE_NODE_FIELD(innersortkeys);
-       WRITE_BOOL_FIELD(skip_mark_restore);
-       WRITE_BOOL_FIELD(materialize_inner);
-}
-
-static void
-_outHashPath(StringInfo str, const HashPath *node)
-{
-       WRITE_NODE_TYPE("HASHPATH");
-
-       _outJoinPathInfo(str, (const JoinPath *) node);
-
-       WRITE_NODE_FIELD(path_hashclauses);
-       WRITE_INT_FIELD(num_batches);
-       WRITE_FLOAT_FIELD(inner_rows_total, "%.0f");
-}
-
-static void
-_outPlannerGlobal(StringInfo str, const PlannerGlobal *node)
-{
-       WRITE_NODE_TYPE("PLANNERGLOBAL");
-
-       /* NB: this isn't a complete set of fields */
-       WRITE_NODE_FIELD(subplans);
-       WRITE_BITMAPSET_FIELD(rewindPlanIDs);
-       WRITE_NODE_FIELD(finalrtable);
-       WRITE_NODE_FIELD(finalrowmarks);
-       WRITE_NODE_FIELD(resultRelations);
-       WRITE_NODE_FIELD(appendRelations);
-       WRITE_NODE_FIELD(relationOids);
-       WRITE_NODE_FIELD(invalItems);
-       WRITE_NODE_FIELD(paramExecTypes);
-       WRITE_UINT_FIELD(lastPHId);
-       WRITE_UINT_FIELD(lastRowMarkId);
-       WRITE_INT_FIELD(lastPlanNodeId);
-       WRITE_BOOL_FIELD(transientPlan);
-       WRITE_BOOL_FIELD(dependsOnRole);
-       WRITE_BOOL_FIELD(parallelModeOK);
-       WRITE_BOOL_FIELD(parallelModeNeeded);
-       WRITE_CHAR_FIELD(maxParallelHazard);
-}
-
-static void
-_outPlannerInfo(StringInfo str, const PlannerInfo *node)
-{
-       WRITE_NODE_TYPE("PLANNERINFO");
-
-       /* NB: this isn't a complete set of fields */
-       WRITE_NODE_FIELD(parse);
-       WRITE_NODE_FIELD(glob);
-       WRITE_UINT_FIELD(query_level);
-       WRITE_NODE_FIELD(plan_params);
-       WRITE_BITMAPSET_FIELD(outer_params);
-       WRITE_BITMAPSET_FIELD(all_baserels);
-       WRITE_BITMAPSET_FIELD(nullable_baserels);
-       WRITE_NODE_FIELD(join_rel_list);
-       WRITE_INT_FIELD(join_cur_level);
-       WRITE_NODE_FIELD(init_plans);
-       WRITE_NODE_FIELD(cte_plan_ids);
-       WRITE_NODE_FIELD(multiexpr_params);
-       WRITE_NODE_FIELD(eq_classes);
-       WRITE_BOOL_FIELD(ec_merging_done);
-       WRITE_NODE_FIELD(canon_pathkeys);
-       WRITE_NODE_FIELD(left_join_clauses);
-       WRITE_NODE_FIELD(right_join_clauses);
-       WRITE_NODE_FIELD(full_join_clauses);
-       WRITE_NODE_FIELD(join_info_list);
-       WRITE_BITMAPSET_FIELD(all_result_relids);
-       WRITE_BITMAPSET_FIELD(leaf_result_relids);
-       WRITE_NODE_FIELD(append_rel_list);
-       WRITE_NODE_FIELD(row_identity_vars);
-       WRITE_NODE_FIELD(rowMarks);
-       WRITE_NODE_FIELD(placeholder_list);
-       WRITE_NODE_FIELD(fkey_list);
-       WRITE_NODE_FIELD(query_pathkeys);
-       WRITE_NODE_FIELD(group_pathkeys);
-       WRITE_NODE_FIELD(window_pathkeys);
-       WRITE_NODE_FIELD(distinct_pathkeys);
-       WRITE_NODE_FIELD(sort_pathkeys);
-       WRITE_NODE_FIELD(processed_tlist);
-       WRITE_NODE_FIELD(update_colnos);
-       WRITE_NODE_FIELD(minmax_aggs);
-       WRITE_FLOAT_FIELD(total_table_pages, "%.0f");
-       WRITE_FLOAT_FIELD(tuple_fraction, "%.4f");
-       WRITE_FLOAT_FIELD(limit_tuples, "%.0f");
-       WRITE_UINT_FIELD(qual_security_level);
-       WRITE_BOOL_FIELD(hasJoinRTEs);
-       WRITE_BOOL_FIELD(hasLateralRTEs);
-       WRITE_BOOL_FIELD(hasHavingQual);
-       WRITE_BOOL_FIELD(hasPseudoConstantQuals);
-       WRITE_BOOL_FIELD(hasAlternativeSubPlans);
-       WRITE_BOOL_FIELD(hasRecursion);
-       WRITE_INT_FIELD(wt_param_id);
-       WRITE_BITMAPSET_FIELD(curOuterRels);
-       WRITE_NODE_FIELD(curOuterParams);
-       WRITE_BOOL_FIELD(partColsUpdated);
-}
-
-static void
-_outRelOptInfo(StringInfo str, const RelOptInfo *node)
-{
-       WRITE_NODE_TYPE("RELOPTINFO");
-
-       /* NB: this isn't a complete set of fields */
-       WRITE_ENUM_FIELD(reloptkind, RelOptKind);
-       WRITE_BITMAPSET_FIELD(relids);
-       WRITE_FLOAT_FIELD(rows, "%.0f");
-       WRITE_BOOL_FIELD(consider_startup);
-       WRITE_BOOL_FIELD(consider_param_startup);
-       WRITE_BOOL_FIELD(consider_parallel);
-       WRITE_NODE_FIELD(reltarget);
-       WRITE_NODE_FIELD(pathlist);
-       WRITE_NODE_FIELD(ppilist);
-       WRITE_NODE_FIELD(partial_pathlist);
-       WRITE_NODE_FIELD(cheapest_startup_path);
-       WRITE_NODE_FIELD(cheapest_total_path);
-       WRITE_NODE_FIELD(cheapest_unique_path);
-       WRITE_NODE_FIELD(cheapest_parameterized_paths);
-       WRITE_BITMAPSET_FIELD(direct_lateral_relids);
-       WRITE_BITMAPSET_FIELD(lateral_relids);
-       WRITE_UINT_FIELD(relid);
-       WRITE_OID_FIELD(reltablespace);
-       WRITE_ENUM_FIELD(rtekind, RTEKind);
-       WRITE_INT_FIELD(min_attr);
-       WRITE_INT_FIELD(max_attr);
-       WRITE_NODE_FIELD(lateral_vars);
-       WRITE_BITMAPSET_FIELD(lateral_referencers);
-       WRITE_NODE_FIELD(indexlist);
-       WRITE_NODE_FIELD(statlist);
-       WRITE_UINT_FIELD(pages);
-       WRITE_FLOAT_FIELD(tuples, "%.0f");
-       WRITE_FLOAT_FIELD(allvisfrac, "%.6f");
-       WRITE_BITMAPSET_FIELD(eclass_indexes);
-       WRITE_NODE_FIELD(subroot);
-       WRITE_NODE_FIELD(subplan_params);
-       WRITE_INT_FIELD(rel_parallel_workers);
-       WRITE_UINT_FIELD(amflags);
-       WRITE_OID_FIELD(serverid);
-       WRITE_OID_FIELD(userid);
-       WRITE_BOOL_FIELD(useridiscurrent);
-       /* we don't try to print fdwroutine or fdw_private */
-       /* can't print unique_for_rels/non_unique_for_rels; BMSes aren't Nodes */
-       WRITE_NODE_FIELD(baserestrictinfo);
-       WRITE_UINT_FIELD(baserestrict_min_security);
-       WRITE_NODE_FIELD(joininfo);
-       WRITE_BOOL_FIELD(has_eclass_joins);
-       WRITE_BOOL_FIELD(consider_partitionwise_join);
-       WRITE_BITMAPSET_FIELD(top_parent_relids);
-       WRITE_BOOL_FIELD(partbounds_merged);
-       WRITE_BITMAPSET_FIELD(live_parts);
-       WRITE_BITMAPSET_FIELD(all_partrels);
-}
-
-static void
-_outIndexOptInfo(StringInfo str, const IndexOptInfo *node)
-{
-       WRITE_NODE_TYPE("INDEXOPTINFO");
-
-       /* NB: this isn't a complete set of fields */
-       WRITE_OID_FIELD(indexoid);
-       /* Do NOT print rel field, else infinite recursion */
-       WRITE_UINT_FIELD(pages);
-       WRITE_FLOAT_FIELD(tuples, "%.0f");
-       WRITE_INT_FIELD(tree_height);
-       WRITE_INT_FIELD(ncolumns);
-       /* array fields aren't really worth the trouble to print */
-       WRITE_OID_FIELD(relam);
-       /* indexprs is redundant since we print indextlist */
-       WRITE_NODE_FIELD(indpred);
-       WRITE_NODE_FIELD(indextlist);
-       WRITE_NODE_FIELD(indrestrictinfo);
-       WRITE_BOOL_FIELD(predOK);
-       WRITE_BOOL_FIELD(unique);
-       WRITE_BOOL_FIELD(immediate);
-       WRITE_BOOL_FIELD(hypothetical);
-       /* we don't bother with fields copied from the index AM's API struct */
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outForeignKeyOptInfo(StringInfo str, const ForeignKeyOptInfo *node)
-{
-       int                     i;
-
-       WRITE_NODE_TYPE("FOREIGNKEYOPTINFO");
-
-       WRITE_UINT_FIELD(con_relid);
-       WRITE_UINT_FIELD(ref_relid);
-       WRITE_INT_FIELD(nkeys);
-       WRITE_ATTRNUMBER_ARRAY(conkey, node->nkeys);
-       WRITE_ATTRNUMBER_ARRAY(confkey, node->nkeys);
-       WRITE_OID_ARRAY(conpfeqop, node->nkeys);
-       WRITE_INT_FIELD(nmatched_ec);
-       WRITE_INT_FIELD(nconst_ec);
-       WRITE_INT_FIELD(nmatched_rcols);
-       WRITE_INT_FIELD(nmatched_ri);
-       /* for compactness, just print the number of matches per column: */
-       appendStringInfoString(str, " :eclass");
-       for (i = 0; i < node->nkeys; i++)
-               appendStringInfo(str, " %d", (node->eclass[i] != NULL));
-       appendStringInfoString(str, " :rinfos");
-       for (i = 0; i < node->nkeys; i++)
-               appendStringInfo(str, " %d", list_length(node->rinfos[i]));
-}
-
-#ifdef OBSOLETE
-static void
-_outStatisticExtInfo(StringInfo str, const StatisticExtInfo *node)
-{
-       WRITE_NODE_TYPE("STATISTICEXTINFO");
-
-       /* NB: this isn't a complete set of fields */
-       WRITE_OID_FIELD(statOid);
-       /* don't write rel, leads to infinite recursion in plan tree dump */
-       WRITE_CHAR_FIELD(kind);
-       WRITE_BITMAPSET_FIELD(keys);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outEquivalenceClass(StringInfo str, const EquivalenceClass *node)
-{
-       /*
-        * To simplify reading, we just chase up to the topmost merged EC and
-        * print that, without bothering to show the merge-ees separately.
-        */
-       while (node->ec_merged)
-               node = node->ec_merged;
-
-       WRITE_NODE_TYPE("EQUIVALENCECLASS");
-
-       WRITE_NODE_FIELD(ec_opfamilies);
-       WRITE_OID_FIELD(ec_collation);
-       WRITE_NODE_FIELD(ec_members);
-       WRITE_NODE_FIELD(ec_sources);
-       WRITE_NODE_FIELD(ec_derives);
-       WRITE_BITMAPSET_FIELD(ec_relids);
-       WRITE_BOOL_FIELD(ec_has_const);
-       WRITE_BOOL_FIELD(ec_has_volatile);
-       WRITE_BOOL_FIELD(ec_below_outer_join);
-       WRITE_BOOL_FIELD(ec_broken);
-       WRITE_UINT_FIELD(ec_sortref);
-       WRITE_UINT_FIELD(ec_min_security);
-       WRITE_UINT_FIELD(ec_max_security);
-}
-
-#ifdef OBSOLETE
-static void
-_outEquivalenceMember(StringInfo str, const EquivalenceMember *node)
-{
-       WRITE_NODE_TYPE("EQUIVALENCEMEMBER");
-
-       WRITE_NODE_FIELD(em_expr);
-       WRITE_BITMAPSET_FIELD(em_relids);
-       WRITE_BITMAPSET_FIELD(em_nullable_relids);
-       WRITE_BOOL_FIELD(em_is_const);
-       WRITE_BOOL_FIELD(em_is_child);
-       WRITE_OID_FIELD(em_datatype);
-}
-
-static void
-_outPathKey(StringInfo str, const PathKey *node)
-{
-       WRITE_NODE_TYPE("PATHKEY");
-
-       WRITE_NODE_FIELD(pk_eclass);
-       WRITE_OID_FIELD(pk_opfamily);
-       WRITE_INT_FIELD(pk_strategy);
-       WRITE_BOOL_FIELD(pk_nulls_first);
-}
-
-static void
-_outPathTarget(StringInfo str, const PathTarget *node)
-{
-       WRITE_NODE_TYPE("PATHTARGET");
-
-       WRITE_NODE_FIELD(exprs);
-       WRITE_INDEX_ARRAY(sortgrouprefs, list_length(node->exprs));
-       WRITE_FLOAT_FIELD(cost.startup, "%.2f");
-       WRITE_FLOAT_FIELD(cost.per_tuple, "%.2f");
-       WRITE_INT_FIELD(width);
-       WRITE_ENUM_FIELD(has_volatile_expr, VolatileFunctionStatus);
-}
-
-static void
-_outParamPathInfo(StringInfo str, const ParamPathInfo *node)
-{
-       WRITE_NODE_TYPE("PARAMPATHINFO");
-
-       WRITE_BITMAPSET_FIELD(ppi_req_outer);
-       WRITE_FLOAT_FIELD(ppi_rows, "%.0f");
-       WRITE_NODE_FIELD(ppi_clauses);
-}
-
-static void
-_outRestrictInfo(StringInfo str, const RestrictInfo *node)
-{
-       WRITE_NODE_TYPE("RESTRICTINFO");
-
-       /* NB: this isn't a complete set of fields */
-       WRITE_NODE_FIELD(clause);
-       WRITE_BOOL_FIELD(is_pushed_down);
-       WRITE_BOOL_FIELD(outerjoin_delayed);
-       WRITE_BOOL_FIELD(can_join);
-       WRITE_BOOL_FIELD(pseudoconstant);
-       WRITE_BOOL_FIELD(leakproof);
-       WRITE_ENUM_FIELD(has_volatile, VolatileFunctionStatus);
-       WRITE_UINT_FIELD(security_level);
-       WRITE_BITMAPSET_FIELD(clause_relids);
-       WRITE_BITMAPSET_FIELD(required_relids);
-       WRITE_BITMAPSET_FIELD(outer_relids);
-       WRITE_BITMAPSET_FIELD(nullable_relids);
-       WRITE_BITMAPSET_FIELD(left_relids);
-       WRITE_BITMAPSET_FIELD(right_relids);
-       WRITE_NODE_FIELD(orclause);
-       /* don't write parent_ec, leads to infinite recursion in plan tree dump */
-       WRITE_FLOAT_FIELD(norm_selec, "%.4f");
-       WRITE_FLOAT_FIELD(outer_selec, "%.4f");
-       WRITE_NODE_FIELD(mergeopfamilies);
-       /* don't write left_ec, leads to infinite recursion in plan tree dump */
-       /* don't write right_ec, leads to infinite recursion in plan tree dump */
-       WRITE_NODE_FIELD(left_em);
-       WRITE_NODE_FIELD(right_em);
-       WRITE_BOOL_FIELD(outer_is_left);
-       WRITE_OID_FIELD(hashjoinoperator);
-       WRITE_OID_FIELD(left_hasheqoperator);
-       WRITE_OID_FIELD(right_hasheqoperator);
-}
-
-static void
-_outIndexClause(StringInfo str, const IndexClause *node)
-{
-       WRITE_NODE_TYPE("INDEXCLAUSE");
-
-       WRITE_NODE_FIELD(rinfo);
-       WRITE_NODE_FIELD(indexquals);
-       WRITE_BOOL_FIELD(lossy);
-       WRITE_INT_FIELD(indexcol);
-       WRITE_NODE_FIELD(indexcols);
-}
-
-static void
-_outPlaceHolderVar(StringInfo str, const PlaceHolderVar *node)
-{
-       WRITE_NODE_TYPE("PLACEHOLDERVAR");
-
-       WRITE_NODE_FIELD(phexpr);
-       WRITE_BITMAPSET_FIELD(phrels);
-       WRITE_UINT_FIELD(phid);
-       WRITE_UINT_FIELD(phlevelsup);
-}
-
-static void
-_outSpecialJoinInfo(StringInfo str, const SpecialJoinInfo *node)
-{
-       WRITE_NODE_TYPE("SPECIALJOININFO");
-
-       WRITE_BITMAPSET_FIELD(min_lefthand);
-       WRITE_BITMAPSET_FIELD(min_righthand);
-       WRITE_BITMAPSET_FIELD(syn_lefthand);
-       WRITE_BITMAPSET_FIELD(syn_righthand);
-       WRITE_ENUM_FIELD(jointype, JoinType);
-       WRITE_BOOL_FIELD(lhs_strict);
-       WRITE_BOOL_FIELD(delay_upper_joins);
-       WRITE_BOOL_FIELD(semi_can_btree);
-       WRITE_BOOL_FIELD(semi_can_hash);
-       WRITE_NODE_FIELD(semi_operators);
-       WRITE_NODE_FIELD(semi_rhs_exprs);
-}
-
-static void
-_outAppendRelInfo(StringInfo str, const AppendRelInfo *node)
-{
-       WRITE_NODE_TYPE("APPENDRELINFO");
-
-       WRITE_UINT_FIELD(parent_relid);
-       WRITE_UINT_FIELD(child_relid);
-       WRITE_OID_FIELD(parent_reltype);
-       WRITE_OID_FIELD(child_reltype);
-       WRITE_NODE_FIELD(translated_vars);
-       WRITE_INT_FIELD(num_child_cols);
-       WRITE_ATTRNUMBER_ARRAY(parent_colnos, node->num_child_cols);
-       WRITE_OID_FIELD(parent_reloid);
-}
-
-static void
-_outRowIdentityVarInfo(StringInfo str, const RowIdentityVarInfo *node)
-{
-       WRITE_NODE_TYPE("ROWIDENTITYVARINFO");
-
-       WRITE_NODE_FIELD(rowidvar);
-       WRITE_INT_FIELD(rowidwidth);
-       WRITE_STRING_FIELD(rowidname);
-       WRITE_BITMAPSET_FIELD(rowidrels);
-}
-
-static void
-_outPlaceHolderInfo(StringInfo str, const PlaceHolderInfo *node)
-{
-       WRITE_NODE_TYPE("PLACEHOLDERINFO");
-
-       WRITE_UINT_FIELD(phid);
-       WRITE_NODE_FIELD(ph_var);
-       WRITE_BITMAPSET_FIELD(ph_eval_at);
-       WRITE_BITMAPSET_FIELD(ph_lateral);
-       WRITE_BITMAPSET_FIELD(ph_needed);
-       WRITE_INT_FIELD(ph_width);
-}
-
-static void
-_outMinMaxAggInfo(StringInfo str, const MinMaxAggInfo *node)
-{
-       WRITE_NODE_TYPE("MINMAXAGGINFO");
-
-       WRITE_OID_FIELD(aggfnoid);
-       WRITE_OID_FIELD(aggsortop);
-       WRITE_NODE_FIELD(target);
-       /* We intentionally omit subroot --- too large, not interesting enough */
-       WRITE_NODE_FIELD(path);
-       WRITE_FLOAT_FIELD(pathcost, "%.2f");
-       WRITE_NODE_FIELD(param);
-}
-
-static void
-_outPlannerParamItem(StringInfo str, const PlannerParamItem *node)
-{
-       WRITE_NODE_TYPE("PLANNERPARAMITEM");
-
-       WRITE_NODE_FIELD(item);
-       WRITE_INT_FIELD(paramId);
-}
-#endif                                                 /* OBSOLETE */
-
-/*****************************************************************************
- *
- *     Stuff from extensible.h
- *
- *****************************************************************************/
-
-static void
-_outExtensibleNode(StringInfo str, const ExtensibleNode *node)
-{
-       const ExtensibleNodeMethods *methods;
-
-       methods = GetExtensibleNodeMethods(node->extnodename, false);
-
-       WRITE_NODE_TYPE("EXTENSIBLENODE");
-
-       WRITE_STRING_FIELD(extnodename);
-
-       /* serialize the private fields */
-       methods->nodeOut(str, node);
-}
-
-#ifdef OBSOLETE
-/*****************************************************************************
- *
- *     Stuff from parsenodes.h.
- *
- *****************************************************************************/
-
-/*
- * print the basic stuff of all nodes that inherit from CreateStmt
- */
-static void
-_outCreateStmtInfo(StringInfo str, const CreateStmt *node)
-{
-       WRITE_NODE_FIELD(relation);
-       WRITE_NODE_FIELD(tableElts);
-       WRITE_NODE_FIELD(inhRelations);
-       WRITE_NODE_FIELD(partspec);
-       WRITE_NODE_FIELD(partbound);
-       WRITE_NODE_FIELD(ofTypename);
-       WRITE_NODE_FIELD(constraints);
-       WRITE_NODE_FIELD(options);
-       WRITE_ENUM_FIELD(oncommit, OnCommitAction);
-       WRITE_STRING_FIELD(tablespacename);
-       WRITE_STRING_FIELD(accessMethod);
-       WRITE_BOOL_FIELD(if_not_exists);
-}
-
-static void
-_outCreateStmt(StringInfo str, const CreateStmt *node)
-{
-       WRITE_NODE_TYPE("CREATESTMT");
-
-       _outCreateStmtInfo(str, (const CreateStmt *) node);
-}
-
-static void
-_outCreateForeignTableStmt(StringInfo str, const CreateForeignTableStmt *node)
-{
-       WRITE_NODE_TYPE("CREATEFOREIGNTABLESTMT");
-
-       _outCreateStmtInfo(str, (const CreateStmt *) node);
-
-       WRITE_STRING_FIELD(servername);
-       WRITE_NODE_FIELD(options);
-}
-
-static void
-_outImportForeignSchemaStmt(StringInfo str, const ImportForeignSchemaStmt *node)
-{
-       WRITE_NODE_TYPE("IMPORTFOREIGNSCHEMASTMT");
-
-       WRITE_STRING_FIELD(server_name);
-       WRITE_STRING_FIELD(remote_schema);
-       WRITE_STRING_FIELD(local_schema);
-       WRITE_ENUM_FIELD(list_type, ImportForeignSchemaType);
-       WRITE_NODE_FIELD(table_list);
-       WRITE_NODE_FIELD(options);
-}
-
-static void
-_outIndexStmt(StringInfo str, const IndexStmt *node)
-{
-       WRITE_NODE_TYPE("INDEXSTMT");
-
-       WRITE_STRING_FIELD(idxname);
-       WRITE_NODE_FIELD(relation);
-       WRITE_STRING_FIELD(accessMethod);
-       WRITE_STRING_FIELD(tableSpace);
-       WRITE_NODE_FIELD(indexParams);
-       WRITE_NODE_FIELD(indexIncludingParams);
-       WRITE_NODE_FIELD(options);
-       WRITE_NODE_FIELD(whereClause);
-       WRITE_NODE_FIELD(excludeOpNames);
-       WRITE_STRING_FIELD(idxcomment);
-       WRITE_OID_FIELD(indexOid);
-       WRITE_OID_FIELD(oldNumber);
-       WRITE_UINT_FIELD(oldCreateSubid);
-       WRITE_UINT_FIELD(oldFirstRelfilelocatorSubid);
-       WRITE_BOOL_FIELD(unique);
-       WRITE_BOOL_FIELD(nulls_not_distinct);
-       WRITE_BOOL_FIELD(primary);
-       WRITE_BOOL_FIELD(isconstraint);
-       WRITE_BOOL_FIELD(deferrable);
-       WRITE_BOOL_FIELD(initdeferred);
-       WRITE_BOOL_FIELD(transformed);
-       WRITE_BOOL_FIELD(concurrent);
-       WRITE_BOOL_FIELD(if_not_exists);
-       WRITE_BOOL_FIELD(reset_default_tblspc);
-}
-
-static void
-_outCreateStatsStmt(StringInfo str, const CreateStatsStmt *node)
-{
-       WRITE_NODE_TYPE("CREATESTATSSTMT");
-
-       WRITE_NODE_FIELD(defnames);
-       WRITE_NODE_FIELD(stat_types);
-       WRITE_NODE_FIELD(exprs);
-       WRITE_NODE_FIELD(relations);
-       WRITE_STRING_FIELD(stxcomment);
-       WRITE_BOOL_FIELD(transformed);
-       WRITE_BOOL_FIELD(if_not_exists);
-}
-
-static void
-_outAlterStatsStmt(StringInfo str, const AlterStatsStmt *node)
-{
-       WRITE_NODE_TYPE("ALTERSTATSSTMT");
-
-       WRITE_NODE_FIELD(defnames);
-       WRITE_INT_FIELD(stxstattarget);
-       WRITE_BOOL_FIELD(missing_ok);
-}
-
-static void
-_outNotifyStmt(StringInfo str, const NotifyStmt *node)
-{
-       WRITE_NODE_TYPE("NOTIFYSTMT");
-
-       WRITE_STRING_FIELD(conditionname);
-       WRITE_STRING_FIELD(payload);
-}
-
-static void
-_outDeclareCursorStmt(StringInfo str, const DeclareCursorStmt *node)
-{
-       WRITE_NODE_TYPE("DECLARECURSORSTMT");
-
-       WRITE_STRING_FIELD(portalname);
-       WRITE_INT_FIELD(options);
-       WRITE_NODE_FIELD(query);
-}
-
-static void
-_outSelectStmt(StringInfo str, const SelectStmt *node)
-{
-       WRITE_NODE_TYPE("SELECT");
-
-       WRITE_NODE_FIELD(distinctClause);
-       WRITE_NODE_FIELD(intoClause);
-       WRITE_NODE_FIELD(targetList);
-       WRITE_NODE_FIELD(fromClause);
-       WRITE_NODE_FIELD(whereClause);
-       WRITE_NODE_FIELD(groupClause);
-       WRITE_BOOL_FIELD(groupDistinct);
-       WRITE_NODE_FIELD(havingClause);
-       WRITE_NODE_FIELD(windowClause);
-       WRITE_NODE_FIELD(valuesLists);
-       WRITE_NODE_FIELD(sortClause);
-       WRITE_NODE_FIELD(limitOffset);
-       WRITE_NODE_FIELD(limitCount);
-       WRITE_ENUM_FIELD(limitOption, LimitOption);
-       WRITE_NODE_FIELD(lockingClause);
-       WRITE_NODE_FIELD(withClause);
-       WRITE_ENUM_FIELD(op, SetOperation);
-       WRITE_BOOL_FIELD(all);
-       WRITE_NODE_FIELD(larg);
-       WRITE_NODE_FIELD(rarg);
-}
-
-static void
-_outReturnStmt(StringInfo str, const ReturnStmt *node)
-{
-       WRITE_NODE_TYPE("RETURN");
-
-       WRITE_NODE_FIELD(returnval);
-}
-
-static void
-_outPLAssignStmt(StringInfo str, const PLAssignStmt *node)
-{
-       WRITE_NODE_TYPE("PLASSIGN");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_NODE_FIELD(indirection);
-       WRITE_INT_FIELD(nnames);
-       WRITE_NODE_FIELD(val);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outFuncCall(StringInfo str, const FuncCall *node)
-{
-       WRITE_NODE_TYPE("FUNCCALL");
-
-       WRITE_NODE_FIELD(funcname);
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(agg_order);
-       WRITE_NODE_FIELD(agg_filter);
-       WRITE_NODE_FIELD(over);
-       WRITE_BOOL_FIELD(agg_within_group);
-       WRITE_BOOL_FIELD(agg_star);
-       WRITE_BOOL_FIELD(agg_distinct);
-       WRITE_BOOL_FIELD(func_variadic);
-       WRITE_ENUM_FIELD(funcformat, CoercionForm);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outDefElem(StringInfo str, const DefElem *node)
-{
-       WRITE_NODE_TYPE("DEFELEM");
-
-       WRITE_STRING_FIELD(defnamespace);
-       WRITE_STRING_FIELD(defname);
-       WRITE_NODE_FIELD(arg);
-       WRITE_ENUM_FIELD(defaction, DefElemAction);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outTableLikeClause(StringInfo str, const TableLikeClause *node)
-{
-       WRITE_NODE_TYPE("TABLELIKECLAUSE");
-
-       WRITE_NODE_FIELD(relation);
-       WRITE_UINT_FIELD(options);
-       WRITE_OID_FIELD(relationOid);
-}
-
-static void
-_outLockingClause(StringInfo str, const LockingClause *node)
-{
-       WRITE_NODE_TYPE("LOCKINGCLAUSE");
-
-       WRITE_NODE_FIELD(lockedRels);
-       WRITE_ENUM_FIELD(strength, LockClauseStrength);
-       WRITE_ENUM_FIELD(waitPolicy, LockWaitPolicy);
-}
-
-static void
-_outXmlSerialize(StringInfo str, const XmlSerialize *node)
-{
-       WRITE_NODE_TYPE("XMLSERIALIZE");
-
-       WRITE_ENUM_FIELD(xmloption, XmlOptionType);
-       WRITE_NODE_FIELD(expr);
-       WRITE_NODE_FIELD(typeName);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outTriggerTransition(StringInfo str, const TriggerTransition *node)
-{
-       WRITE_NODE_TYPE("TRIGGERTRANSITION");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_BOOL_FIELD(isNew);
-       WRITE_BOOL_FIELD(isTable);
-}
-
-static void
-_outColumnDef(StringInfo str, const ColumnDef *node)
-{
-       WRITE_NODE_TYPE("COLUMNDEF");
-
-       WRITE_STRING_FIELD(colname);
-       WRITE_NODE_FIELD(typeName);
-       WRITE_STRING_FIELD(compression);
-       WRITE_INT_FIELD(inhcount);
-       WRITE_BOOL_FIELD(is_local);
-       WRITE_BOOL_FIELD(is_not_null);
-       WRITE_BOOL_FIELD(is_from_type);
-       WRITE_CHAR_FIELD(storage);
-       WRITE_NODE_FIELD(raw_default);
-       WRITE_NODE_FIELD(cooked_default);
-       WRITE_CHAR_FIELD(identity);
-       WRITE_NODE_FIELD(identitySequence);
-       WRITE_CHAR_FIELD(generated);
-       WRITE_NODE_FIELD(collClause);
-       WRITE_OID_FIELD(collOid);
-       WRITE_NODE_FIELD(constraints);
-       WRITE_NODE_FIELD(fdwoptions);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outTypeName(StringInfo str, const TypeName *node)
-{
-       WRITE_NODE_TYPE("TYPENAME");
-
-       WRITE_NODE_FIELD(names);
-       WRITE_OID_FIELD(typeOid);
-       WRITE_BOOL_FIELD(setof);
-       WRITE_BOOL_FIELD(pct_type);
-       WRITE_NODE_FIELD(typmods);
-       WRITE_INT_FIELD(typemod);
-       WRITE_NODE_FIELD(arrayBounds);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outTypeCast(StringInfo str, const TypeCast *node)
-{
-       WRITE_NODE_TYPE("TYPECAST");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_NODE_FIELD(typeName);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCollateClause(StringInfo str, const CollateClause *node)
-{
-       WRITE_NODE_TYPE("COLLATECLAUSE");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_NODE_FIELD(collname);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outIndexElem(StringInfo str, const IndexElem *node)
-{
-       WRITE_NODE_TYPE("INDEXELEM");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_NODE_FIELD(expr);
-       WRITE_STRING_FIELD(indexcolname);
-       WRITE_NODE_FIELD(collation);
-       WRITE_NODE_FIELD(opclass);
-       WRITE_NODE_FIELD(opclassopts);
-       WRITE_ENUM_FIELD(ordering, SortByDir);
-       WRITE_ENUM_FIELD(nulls_ordering, SortByNulls);
-}
-
-static void
-_outStatsElem(StringInfo str, const StatsElem *node)
-{
-       WRITE_NODE_TYPE("STATSELEM");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_NODE_FIELD(expr);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outQuery(StringInfo str, const Query *node)
-{
-       WRITE_NODE_TYPE("QUERY");
-
-       WRITE_ENUM_FIELD(commandType, CmdType);
-       WRITE_ENUM_FIELD(querySource, QuerySource);
-       /* we intentionally do not print the queryId field */
-       WRITE_BOOL_FIELD(canSetTag);
-
-       /*
-        * Hack to work around missing outfuncs routines for a lot of the
-        * utility-statement node types.  (The only one we actually *need* for
-        * rules support is NotifyStmt.)  Someday we ought to support 'em all, but
-        * for the meantime do this to avoid getting lots of warnings when running
-        * with debug_print_parse on.
-        */
-       if (node->utilityStmt)
-       {
-               switch (nodeTag(node->utilityStmt))
-               {
-                       case T_CreateStmt:
-                       case T_IndexStmt:
-                       case T_NotifyStmt:
-                       case T_DeclareCursorStmt:
-                               WRITE_NODE_FIELD(utilityStmt);
-                               break;
-                       default:
-                               appendStringInfoString(str, " :utilityStmt ?");
-                               break;
-               }
-       }
-       else
-               appendStringInfoString(str, " :utilityStmt <>");
-
-       WRITE_INT_FIELD(resultRelation);
-       WRITE_BOOL_FIELD(hasAggs);
-       WRITE_BOOL_FIELD(hasWindowFuncs);
-       WRITE_BOOL_FIELD(hasTargetSRFs);
-       WRITE_BOOL_FIELD(hasSubLinks);
-       WRITE_BOOL_FIELD(hasDistinctOn);
-       WRITE_BOOL_FIELD(hasRecursive);
-       WRITE_BOOL_FIELD(hasModifyingCTE);
-       WRITE_BOOL_FIELD(hasForUpdate);
-       WRITE_BOOL_FIELD(hasRowSecurity);
-       WRITE_BOOL_FIELD(isReturn);
-       WRITE_NODE_FIELD(cteList);
-       WRITE_NODE_FIELD(rtable);
-       WRITE_NODE_FIELD(jointree);
-       WRITE_NODE_FIELD(targetList);
-       WRITE_ENUM_FIELD(override, OverridingKind);
-       WRITE_NODE_FIELD(onConflict);
-       WRITE_NODE_FIELD(returningList);
-       WRITE_NODE_FIELD(groupClause);
-       WRITE_BOOL_FIELD(groupDistinct);
-       WRITE_NODE_FIELD(groupingSets);
-       WRITE_NODE_FIELD(havingQual);
-       WRITE_NODE_FIELD(windowClause);
-       WRITE_NODE_FIELD(distinctClause);
-       WRITE_NODE_FIELD(sortClause);
-       WRITE_NODE_FIELD(limitOffset);
-       WRITE_NODE_FIELD(limitCount);
-       WRITE_ENUM_FIELD(limitOption, LimitOption);
-       WRITE_NODE_FIELD(rowMarks);
-       WRITE_NODE_FIELD(setOperations);
-       WRITE_NODE_FIELD(constraintDeps);
-       WRITE_NODE_FIELD(withCheckOptions);
-       WRITE_NODE_FIELD(mergeActionList);
-       WRITE_BOOL_FIELD(mergeUseOuterJoin);
-       WRITE_LOCATION_FIELD(stmt_location);
-       WRITE_INT_FIELD(stmt_len);
-}
-
-#ifdef OBSOLETE
-static void
-_outWithCheckOption(StringInfo str, const WithCheckOption *node)
-{
-       WRITE_NODE_TYPE("WITHCHECKOPTION");
-
-       WRITE_ENUM_FIELD(kind, WCOKind);
-       WRITE_STRING_FIELD(relname);
-       WRITE_STRING_FIELD(polname);
-       WRITE_NODE_FIELD(qual);
-       WRITE_BOOL_FIELD(cascaded);
-}
-
-static void
-_outSortGroupClause(StringInfo str, const SortGroupClause *node)
-{
-       WRITE_NODE_TYPE("SORTGROUPCLAUSE");
-
-       WRITE_UINT_FIELD(tleSortGroupRef);
-       WRITE_OID_FIELD(eqop);
-       WRITE_OID_FIELD(sortop);
-       WRITE_BOOL_FIELD(nulls_first);
-       WRITE_BOOL_FIELD(hashable);
-}
-
-static void
-_outGroupingSet(StringInfo str, const GroupingSet *node)
-{
-       WRITE_NODE_TYPE("GROUPINGSET");
-
-       WRITE_ENUM_FIELD(kind, GroupingSetKind);
-       WRITE_NODE_FIELD(content);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outWindowClause(StringInfo str, const WindowClause *node)
-{
-       WRITE_NODE_TYPE("WINDOWCLAUSE");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_STRING_FIELD(refname);
-       WRITE_NODE_FIELD(partitionClause);
-       WRITE_NODE_FIELD(orderClause);
-       WRITE_INT_FIELD(frameOptions);
-       WRITE_NODE_FIELD(startOffset);
-       WRITE_NODE_FIELD(endOffset);
-       WRITE_NODE_FIELD(runCondition);
-       WRITE_OID_FIELD(startInRangeFunc);
-       WRITE_OID_FIELD(endInRangeFunc);
-       WRITE_OID_FIELD(inRangeColl);
-       WRITE_BOOL_FIELD(inRangeAsc);
-       WRITE_BOOL_FIELD(inRangeNullsFirst);
-       WRITE_UINT_FIELD(winref);
-       WRITE_BOOL_FIELD(copiedOrder);
-}
-
-static void
-_outRowMarkClause(StringInfo str, const RowMarkClause *node)
-{
-       WRITE_NODE_TYPE("ROWMARKCLAUSE");
-
-       WRITE_UINT_FIELD(rti);
-       WRITE_ENUM_FIELD(strength, LockClauseStrength);
-       WRITE_ENUM_FIELD(waitPolicy, LockWaitPolicy);
-       WRITE_BOOL_FIELD(pushedDown);
-}
-
-static void
-_outWithClause(StringInfo str, const WithClause *node)
-{
-       WRITE_NODE_TYPE("WITHCLAUSE");
-
-       WRITE_NODE_FIELD(ctes);
-       WRITE_BOOL_FIELD(recursive);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCTESearchClause(StringInfo str, const CTESearchClause *node)
-{
-       WRITE_NODE_TYPE("CTESEARCHCLAUSE");
-
-       WRITE_NODE_FIELD(search_col_list);
-       WRITE_BOOL_FIELD(search_breadth_first);
-       WRITE_STRING_FIELD(search_seq_column);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outCTECycleClause(StringInfo str, const CTECycleClause *node)
-{
-       WRITE_NODE_TYPE("CTECYCLECLAUSE");
-
-       WRITE_NODE_FIELD(cycle_col_list);
-       WRITE_STRING_FIELD(cycle_mark_column);
-       WRITE_NODE_FIELD(cycle_mark_value);
-       WRITE_NODE_FIELD(cycle_mark_default);
-       WRITE_STRING_FIELD(cycle_path_column);
-       WRITE_LOCATION_FIELD(location);
-       WRITE_OID_FIELD(cycle_mark_type);
-       WRITE_INT_FIELD(cycle_mark_typmod);
-       WRITE_OID_FIELD(cycle_mark_collation);
-       WRITE_OID_FIELD(cycle_mark_neop);
-}
-
-static void
-_outCommonTableExpr(StringInfo str, const CommonTableExpr *node)
-{
-       WRITE_NODE_TYPE("COMMONTABLEEXPR");
-
-       WRITE_STRING_FIELD(ctename);
-       WRITE_NODE_FIELD(aliascolnames);
-       WRITE_ENUM_FIELD(ctematerialized, CTEMaterialize);
-       WRITE_NODE_FIELD(ctequery);
-       WRITE_NODE_FIELD(search_clause);
-       WRITE_NODE_FIELD(cycle_clause);
-       WRITE_LOCATION_FIELD(location);
-       WRITE_BOOL_FIELD(cterecursive);
-       WRITE_INT_FIELD(cterefcount);
-       WRITE_NODE_FIELD(ctecolnames);
-       WRITE_NODE_FIELD(ctecoltypes);
-       WRITE_NODE_FIELD(ctecoltypmods);
-       WRITE_NODE_FIELD(ctecolcollations);
-}
-
-static void
-_outMergeWhenClause(StringInfo str, const MergeWhenClause *node)
-{
-       WRITE_NODE_TYPE("MERGEWHENCLAUSE");
-
-       WRITE_BOOL_FIELD(matched);
-       WRITE_ENUM_FIELD(commandType, CmdType);
-       WRITE_ENUM_FIELD(override, OverridingKind);
-       WRITE_NODE_FIELD(condition);
-       WRITE_NODE_FIELD(targetList);
-       WRITE_NODE_FIELD(values);
-}
-
-static void
-_outMergeAction(StringInfo str, const MergeAction *node)
-{
-       WRITE_NODE_TYPE("MERGEACTION");
-
-       WRITE_BOOL_FIELD(matched);
-       WRITE_ENUM_FIELD(commandType, CmdType);
-       WRITE_ENUM_FIELD(override, OverridingKind);
-       WRITE_NODE_FIELD(qual);
-       WRITE_NODE_FIELD(targetList);
-       WRITE_NODE_FIELD(updateColnos);
-}
-
-static void
-_outSetOperationStmt(StringInfo str, const SetOperationStmt *node)
-{
-       WRITE_NODE_TYPE("SETOPERATIONSTMT");
-
-       WRITE_ENUM_FIELD(op, SetOperation);
-       WRITE_BOOL_FIELD(all);
-       WRITE_NODE_FIELD(larg);
-       WRITE_NODE_FIELD(rarg);
-       WRITE_NODE_FIELD(colTypes);
-       WRITE_NODE_FIELD(colTypmods);
-       WRITE_NODE_FIELD(colCollations);
-       WRITE_NODE_FIELD(groupClauses);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outRangeTblEntry(StringInfo str, const RangeTblEntry *node)
-{
-       WRITE_NODE_TYPE("RANGETBLENTRY");
-
-       /* put alias + eref first to make dump more legible */
-       WRITE_NODE_FIELD(alias);
-       WRITE_NODE_FIELD(eref);
-       WRITE_ENUM_FIELD(rtekind, RTEKind);
-
-       switch (node->rtekind)
-       {
-               case RTE_RELATION:
-                       WRITE_OID_FIELD(relid);
-                       WRITE_CHAR_FIELD(relkind);
-                       WRITE_INT_FIELD(rellockmode);
-                       WRITE_NODE_FIELD(tablesample);
-                       break;
-               case RTE_SUBQUERY:
-                       WRITE_NODE_FIELD(subquery);
-                       WRITE_BOOL_FIELD(security_barrier);
-                       break;
-               case RTE_JOIN:
-                       WRITE_ENUM_FIELD(jointype, JoinType);
-                       WRITE_INT_FIELD(joinmergedcols);
-                       WRITE_NODE_FIELD(joinaliasvars);
-                       WRITE_NODE_FIELD(joinleftcols);
-                       WRITE_NODE_FIELD(joinrightcols);
-                       WRITE_NODE_FIELD(join_using_alias);
-                       break;
-               case RTE_FUNCTION:
-                       WRITE_NODE_FIELD(functions);
-                       WRITE_BOOL_FIELD(funcordinality);
-                       break;
-               case RTE_TABLEFUNC:
-                       WRITE_NODE_FIELD(tablefunc);
-                       break;
-               case RTE_VALUES:
-                       WRITE_NODE_FIELD(values_lists);
-                       WRITE_NODE_FIELD(coltypes);
-                       WRITE_NODE_FIELD(coltypmods);
-                       WRITE_NODE_FIELD(colcollations);
-                       break;
-               case RTE_CTE:
-                       WRITE_STRING_FIELD(ctename);
-                       WRITE_UINT_FIELD(ctelevelsup);
-                       WRITE_BOOL_FIELD(self_reference);
-                       WRITE_NODE_FIELD(coltypes);
-                       WRITE_NODE_FIELD(coltypmods);
-                       WRITE_NODE_FIELD(colcollations);
-                       break;
-               case RTE_NAMEDTUPLESTORE:
-                       WRITE_STRING_FIELD(enrname);
-                       WRITE_FLOAT_FIELD(enrtuples, "%.0f");
-                       WRITE_OID_FIELD(relid);
-                       WRITE_NODE_FIELD(coltypes);
-                       WRITE_NODE_FIELD(coltypmods);
-                       WRITE_NODE_FIELD(colcollations);
-                       break;
-               case RTE_RESULT:
-                       /* no extra fields */
-                       break;
-               default:
-                       elog(ERROR, "unrecognized RTE kind: %d", (int) node->rtekind);
-                       break;
-       }
-
-       WRITE_BOOL_FIELD(lateral);
-       WRITE_BOOL_FIELD(inh);
-       WRITE_BOOL_FIELD(inFromCl);
-       WRITE_UINT_FIELD(requiredPerms);
-       WRITE_OID_FIELD(checkAsUser);
-       WRITE_BITMAPSET_FIELD(selectedCols);
-       WRITE_BITMAPSET_FIELD(insertedCols);
-       WRITE_BITMAPSET_FIELD(updatedCols);
-       WRITE_BITMAPSET_FIELD(extraUpdatedCols);
-       WRITE_NODE_FIELD(securityQuals);
-}
-
-#ifdef OBSOLETE
-static void
-_outRangeTblFunction(StringInfo str, const RangeTblFunction *node)
-{
-       WRITE_NODE_TYPE("RANGETBLFUNCTION");
-
-       WRITE_NODE_FIELD(funcexpr);
-       WRITE_INT_FIELD(funccolcount);
-       WRITE_NODE_FIELD(funccolnames);
-       WRITE_NODE_FIELD(funccoltypes);
-       WRITE_NODE_FIELD(funccoltypmods);
-       WRITE_NODE_FIELD(funccolcollations);
-       WRITE_BITMAPSET_FIELD(funcparams);
-}
-
-static void
-_outTableSampleClause(StringInfo str, const TableSampleClause *node)
-{
-       WRITE_NODE_TYPE("TABLESAMPLECLAUSE");
-
-       WRITE_OID_FIELD(tsmhandler);
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(repeatable);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outA_Expr(StringInfo str, const A_Expr *node)
-{
-       WRITE_NODE_TYPE("A_EXPR");
-
-       switch (node->kind)
-       {
-               case AEXPR_OP:
-                       appendStringInfoChar(str, ' ');
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_OP_ANY:
-                       appendStringInfoChar(str, ' ');
-                       WRITE_NODE_FIELD(name);
-                       appendStringInfoString(str, " ANY ");
-                       break;
-               case AEXPR_OP_ALL:
-                       appendStringInfoChar(str, ' ');
-                       WRITE_NODE_FIELD(name);
-                       appendStringInfoString(str, " ALL ");
-                       break;
-               case AEXPR_DISTINCT:
-                       appendStringInfoString(str, " DISTINCT ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_NOT_DISTINCT:
-                       appendStringInfoString(str, " NOT_DISTINCT ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_NULLIF:
-                       appendStringInfoString(str, " NULLIF ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_IN:
-                       appendStringInfoString(str, " IN ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_LIKE:
-                       appendStringInfoString(str, " LIKE ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_ILIKE:
-                       appendStringInfoString(str, " ILIKE ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_SIMILAR:
-                       appendStringInfoString(str, " SIMILAR ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_BETWEEN:
-                       appendStringInfoString(str, " BETWEEN ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_NOT_BETWEEN:
-                       appendStringInfoString(str, " NOT_BETWEEN ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_BETWEEN_SYM:
-                       appendStringInfoString(str, " BETWEEN_SYM ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               case AEXPR_NOT_BETWEEN_SYM:
-                       appendStringInfoString(str, " NOT_BETWEEN_SYM ");
-                       WRITE_NODE_FIELD(name);
-                       break;
-               default:
-                       appendStringInfoString(str, " ??");
-                       break;
-       }
-
-       WRITE_NODE_FIELD(lexpr);
-       WRITE_NODE_FIELD(rexpr);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outInteger(StringInfo str, const Integer *node)
-{
-       appendStringInfo(str, "%d", node->ival);
-}
-
-static void
-_outFloat(StringInfo str, const Float *node)
-{
-       /*
-        * We assume the value is a valid numeric literal and so does not need
-        * quoting.
-        */
-       appendStringInfoString(str, node->fval);
-}
-
-static void
-_outBoolean(StringInfo str, const Boolean *node)
-{
-       appendStringInfoString(str, node->boolval ? "true" : "false");
-}
-
-static void
-_outString(StringInfo str, const String *node)
-{
-       /*
-        * We use outToken to provide escaping of the string's content, but we
-        * don't want it to do anything with an empty string.
-        */
-       appendStringInfoChar(str, '"');
-       if (node->sval[0] != '\0')
-               outToken(str, node->sval);
-       appendStringInfoChar(str, '"');
-}
-
-static void
-_outBitString(StringInfo str, const BitString *node)
-{
-       /* internal representation already has leading 'b' */
-       appendStringInfoString(str, node->bsval);
-}
-
-#ifdef OBSOLETE
-static void
-_outColumnRef(StringInfo str, const ColumnRef *node)
-{
-       WRITE_NODE_TYPE("COLUMNREF");
-
-       WRITE_NODE_FIELD(fields);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outParamRef(StringInfo str, const ParamRef *node)
-{
-       WRITE_NODE_TYPE("PARAMREF");
-
-       WRITE_INT_FIELD(number);
-       WRITE_LOCATION_FIELD(location);
-}
-
-/*
- * Node types found in raw parse trees (supported for debug purposes)
- */
-
-static void
-_outRawStmt(StringInfo str, const RawStmt *node)
-{
-       WRITE_NODE_TYPE("RAWSTMT");
-
-       WRITE_NODE_FIELD(stmt);
-       WRITE_LOCATION_FIELD(stmt_location);
-       WRITE_INT_FIELD(stmt_len);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outA_Const(StringInfo str, const A_Const *node)
-{
-       WRITE_NODE_TYPE("A_CONST");
-
-       if (node->isnull)
-               appendStringInfoString(str, "NULL");
-       else
-       {
-               appendStringInfoString(str, " :val ");
-               outNode(str, &node->val);
-       }
-       WRITE_LOCATION_FIELD(location);
-}
-
-#ifdef OBSOLETE
-static void
-_outA_Star(StringInfo str, const A_Star *node)
-{
-       WRITE_NODE_TYPE("A_STAR");
-}
-
-static void
-_outA_Indices(StringInfo str, const A_Indices *node)
-{
-       WRITE_NODE_TYPE("A_INDICES");
-
-       WRITE_BOOL_FIELD(is_slice);
-       WRITE_NODE_FIELD(lidx);
-       WRITE_NODE_FIELD(uidx);
-}
-
-static void
-_outA_Indirection(StringInfo str, const A_Indirection *node)
-{
-       WRITE_NODE_TYPE("A_INDIRECTION");
-
-       WRITE_NODE_FIELD(arg);
-       WRITE_NODE_FIELD(indirection);
-}
-
-static void
-_outA_ArrayExpr(StringInfo str, const A_ArrayExpr *node)
-{
-       WRITE_NODE_TYPE("A_ARRAYEXPR");
-
-       WRITE_NODE_FIELD(elements);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outResTarget(StringInfo str, const ResTarget *node)
-{
-       WRITE_NODE_TYPE("RESTARGET");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_NODE_FIELD(indirection);
-       WRITE_NODE_FIELD(val);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outMultiAssignRef(StringInfo str, const MultiAssignRef *node)
-{
-       WRITE_NODE_TYPE("MULTIASSIGNREF");
-
-       WRITE_NODE_FIELD(source);
-       WRITE_INT_FIELD(colno);
-       WRITE_INT_FIELD(ncolumns);
-}
-
-static void
-_outSortBy(StringInfo str, const SortBy *node)
-{
-       WRITE_NODE_TYPE("SORTBY");
-
-       WRITE_NODE_FIELD(node);
-       WRITE_ENUM_FIELD(sortby_dir, SortByDir);
-       WRITE_ENUM_FIELD(sortby_nulls, SortByNulls);
-       WRITE_NODE_FIELD(useOp);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outWindowDef(StringInfo str, const WindowDef *node)
-{
-       WRITE_NODE_TYPE("WINDOWDEF");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_STRING_FIELD(refname);
-       WRITE_NODE_FIELD(partitionClause);
-       WRITE_NODE_FIELD(orderClause);
-       WRITE_INT_FIELD(frameOptions);
-       WRITE_NODE_FIELD(startOffset);
-       WRITE_NODE_FIELD(endOffset);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outRangeSubselect(StringInfo str, const RangeSubselect *node)
-{
-       WRITE_NODE_TYPE("RANGESUBSELECT");
-
-       WRITE_BOOL_FIELD(lateral);
-       WRITE_NODE_FIELD(subquery);
-       WRITE_NODE_FIELD(alias);
-}
-
-static void
-_outRangeFunction(StringInfo str, const RangeFunction *node)
-{
-       WRITE_NODE_TYPE("RANGEFUNCTION");
-
-       WRITE_BOOL_FIELD(lateral);
-       WRITE_BOOL_FIELD(ordinality);
-       WRITE_BOOL_FIELD(is_rowsfrom);
-       WRITE_NODE_FIELD(functions);
-       WRITE_NODE_FIELD(alias);
-       WRITE_NODE_FIELD(coldeflist);
-}
-
-static void
-_outRangeTableSample(StringInfo str, const RangeTableSample *node)
-{
-       WRITE_NODE_TYPE("RANGETABLESAMPLE");
-
-       WRITE_NODE_FIELD(relation);
-       WRITE_NODE_FIELD(method);
-       WRITE_NODE_FIELD(args);
-       WRITE_NODE_FIELD(repeatable);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outRangeTableFunc(StringInfo str, const RangeTableFunc *node)
-{
-       WRITE_NODE_TYPE("RANGETABLEFUNC");
-
-       WRITE_BOOL_FIELD(lateral);
-       WRITE_NODE_FIELD(docexpr);
-       WRITE_NODE_FIELD(rowexpr);
-       WRITE_NODE_FIELD(namespaces);
-       WRITE_NODE_FIELD(columns);
-       WRITE_NODE_FIELD(alias);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outRangeTableFuncCol(StringInfo str, const RangeTableFuncCol *node)
-{
-       WRITE_NODE_TYPE("RANGETABLEFUNCCOL");
-
-       WRITE_STRING_FIELD(colname);
-       WRITE_NODE_FIELD(typeName);
-       WRITE_BOOL_FIELD(for_ordinality);
-       WRITE_BOOL_FIELD(is_not_null);
-       WRITE_NODE_FIELD(colexpr);
-       WRITE_NODE_FIELD(coldefexpr);
-       WRITE_LOCATION_FIELD(location);
-}
-#endif                                                 /* OBSOLETE */
-
-static void
-_outConstraint(StringInfo str, const Constraint *node)
-{
-       WRITE_NODE_TYPE("CONSTRAINT");
-
-       WRITE_STRING_FIELD(conname);
-       WRITE_BOOL_FIELD(deferrable);
-       WRITE_BOOL_FIELD(initdeferred);
-       WRITE_LOCATION_FIELD(location);
-
-       appendStringInfoString(str, " :contype ");
-       switch (node->contype)
-       {
-               case CONSTR_NULL:
-                       appendStringInfoString(str, "NULL");
-                       break;
-
-               case CONSTR_NOTNULL:
-                       appendStringInfoString(str, "NOT_NULL");
-                       break;
-
-               case CONSTR_DEFAULT:
-                       appendStringInfoString(str, "DEFAULT");
-                       WRITE_NODE_FIELD(raw_expr);
-                       WRITE_STRING_FIELD(cooked_expr);
-                       break;
-
-               case CONSTR_IDENTITY:
-                       appendStringInfoString(str, "IDENTITY");
-                       WRITE_NODE_FIELD(raw_expr);
-                       WRITE_STRING_FIELD(cooked_expr);
-                       WRITE_CHAR_FIELD(generated_when);
-                       break;
-
-               case CONSTR_GENERATED:
-                       appendStringInfoString(str, "GENERATED");
-                       WRITE_NODE_FIELD(raw_expr);
-                       WRITE_STRING_FIELD(cooked_expr);
-                       WRITE_CHAR_FIELD(generated_when);
-                       break;
-
-               case CONSTR_CHECK:
-                       appendStringInfoString(str, "CHECK");
-                       WRITE_BOOL_FIELD(is_no_inherit);
-                       WRITE_NODE_FIELD(raw_expr);
-                       WRITE_STRING_FIELD(cooked_expr);
-                       break;
-
-               case CONSTR_PRIMARY:
-                       appendStringInfoString(str, "PRIMARY_KEY");
-                       WRITE_NODE_FIELD(keys);
-                       WRITE_NODE_FIELD(including);
-                       WRITE_NODE_FIELD(options);
-                       WRITE_STRING_FIELD(indexname);
-                       WRITE_STRING_FIELD(indexspace);
-                       WRITE_BOOL_FIELD(reset_default_tblspc);
-                       /* access_method and where_clause not currently used */
-                       break;
-
-               case CONSTR_UNIQUE:
-                       appendStringInfoString(str, "UNIQUE");
-                       WRITE_BOOL_FIELD(nulls_not_distinct);
-                       WRITE_NODE_FIELD(keys);
-                       WRITE_NODE_FIELD(including);
-                       WRITE_NODE_FIELD(options);
-                       WRITE_STRING_FIELD(indexname);
-                       WRITE_STRING_FIELD(indexspace);
-                       WRITE_BOOL_FIELD(reset_default_tblspc);
-                       /* access_method and where_clause not currently used */
-                       break;
-
-               case CONSTR_EXCLUSION:
-                       appendStringInfoString(str, "EXCLUSION");
-                       WRITE_NODE_FIELD(exclusions);
-                       WRITE_NODE_FIELD(including);
-                       WRITE_NODE_FIELD(options);
-                       WRITE_STRING_FIELD(indexname);
-                       WRITE_STRING_FIELD(indexspace);
-                       WRITE_BOOL_FIELD(reset_default_tblspc);
-                       WRITE_STRING_FIELD(access_method);
-                       WRITE_NODE_FIELD(where_clause);
-                       break;
-
-               case CONSTR_FOREIGN:
-                       appendStringInfoString(str, "FOREIGN_KEY");
-                       WRITE_NODE_FIELD(pktable);
-                       WRITE_NODE_FIELD(fk_attrs);
-                       WRITE_NODE_FIELD(pk_attrs);
-                       WRITE_CHAR_FIELD(fk_matchtype);
-                       WRITE_CHAR_FIELD(fk_upd_action);
-                       WRITE_CHAR_FIELD(fk_del_action);
-                       WRITE_NODE_FIELD(fk_del_set_cols);
-                       WRITE_NODE_FIELD(old_conpfeqop);
-                       WRITE_OID_FIELD(old_pktable_oid);
-                       WRITE_BOOL_FIELD(skip_validation);
-                       WRITE_BOOL_FIELD(initially_valid);
-                       break;
-
-               case CONSTR_ATTR_DEFERRABLE:
-                       appendStringInfoString(str, "ATTR_DEFERRABLE");
-                       break;
-
-               case CONSTR_ATTR_NOT_DEFERRABLE:
-                       appendStringInfoString(str, "ATTR_NOT_DEFERRABLE");
-                       break;
-
-               case CONSTR_ATTR_DEFERRED:
-                       appendStringInfoString(str, "ATTR_DEFERRED");
-                       break;
-
-               case CONSTR_ATTR_IMMEDIATE:
-                       appendStringInfoString(str, "ATTR_IMMEDIATE");
-                       break;
-
-               default:
-                       appendStringInfo(str, "<unrecognized_constraint %d>",
-                                                        (int) node->contype);
-                       break;
-       }
-}
-
-#ifdef OBSOLETE
-static void
-_outForeignKeyCacheInfo(StringInfo str, const ForeignKeyCacheInfo *node)
-{
-       WRITE_NODE_TYPE("FOREIGNKEYCACHEINFO");
-
-       WRITE_OID_FIELD(conoid);
-       WRITE_OID_FIELD(conrelid);
-       WRITE_OID_FIELD(confrelid);
-       WRITE_INT_FIELD(nkeys);
-       WRITE_ATTRNUMBER_ARRAY(conkey, node->nkeys);
-       WRITE_ATTRNUMBER_ARRAY(confkey, node->nkeys);
-       WRITE_OID_ARRAY(conpfeqop, node->nkeys);
-}
-
-static void
-_outPartitionElem(StringInfo str, const PartitionElem *node)
-{
-       WRITE_NODE_TYPE("PARTITIONELEM");
-
-       WRITE_STRING_FIELD(name);
-       WRITE_NODE_FIELD(expr);
-       WRITE_NODE_FIELD(collation);
-       WRITE_NODE_FIELD(opclass);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outPartitionSpec(StringInfo str, const PartitionSpec *node)
-{
-       WRITE_NODE_TYPE("PARTITIONSPEC");
-
-       WRITE_STRING_FIELD(strategy);
-       WRITE_NODE_FIELD(partParams);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outPartitionBoundSpec(StringInfo str, const PartitionBoundSpec *node)
-{
-       WRITE_NODE_TYPE("PARTITIONBOUNDSPEC");
-
-       WRITE_CHAR_FIELD(strategy);
-       WRITE_BOOL_FIELD(is_default);
-       WRITE_INT_FIELD(modulus);
-       WRITE_INT_FIELD(remainder);
-       WRITE_NODE_FIELD(listdatums);
-       WRITE_NODE_FIELD(lowerdatums);
-       WRITE_NODE_FIELD(upperdatums);
-       WRITE_LOCATION_FIELD(location);
-}
-
-static void
-_outPartitionRangeDatum(StringInfo str, const PartitionRangeDatum *node)
-{
-       WRITE_NODE_TYPE("PARTITIONRANGEDATUM");
-
-       WRITE_ENUM_FIELD(kind, PartitionRangeDatumKind);
-       WRITE_NODE_FIELD(value);
-       WRITE_LOCATION_FIELD(location);
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * outNode -
- *       converts a Node into ascii string and append it to 'str'
- */
-void
-outNode(StringInfo str, const void *obj)
-{
-       /* Guard against stack overflow due to overly complex expressions */
-       check_stack_depth();
+       /* Guard against stack overflow due to overly complex expressions */
+       check_stack_depth();
 
        if (obj == NULL)
                appendStringInfoString(str, "<>");
@@ -4062,713 +865,6 @@ outNode(StringInfo str, const void *obj)
                switch (nodeTag(obj))
                {
 #include "outfuncs.switch.c"
-#ifdef OBSOLETE
-                       case T_PlannedStmt:
-                               _outPlannedStmt(str, obj);
-                               break;
-                       case T_Result:
-                               _outResult(str, obj);
-                               break;
-                       case T_ProjectSet:
-                               _outProjectSet(str, obj);
-                               break;
-                       case T_ModifyTable:
-                               _outModifyTable(str, obj);
-                               break;
-                       case T_Append:
-                               _outAppend(str, obj);
-                               break;
-                       case T_MergeAppend:
-                               _outMergeAppend(str, obj);
-                               break;
-                       case T_RecursiveUnion:
-                               _outRecursiveUnion(str, obj);
-                               break;
-                       case T_BitmapAnd:
-                               _outBitmapAnd(str, obj);
-                               break;
-                       case T_BitmapOr:
-                               _outBitmapOr(str, obj);
-                               break;
-                       case T_Gather:
-                               _outGather(str, obj);
-                               break;
-                       case T_GatherMerge:
-                               _outGatherMerge(str, obj);
-                               break;
-                       case T_Scan:
-                               _outScan(str, obj);
-                               break;
-                       case T_SeqScan:
-                               _outSeqScan(str, obj);
-                               break;
-                       case T_SampleScan:
-                               _outSampleScan(str, obj);
-                               break;
-                       case T_IndexScan:
-                               _outIndexScan(str, obj);
-                               break;
-                       case T_IndexOnlyScan:
-                               _outIndexOnlyScan(str, obj);
-                               break;
-                       case T_BitmapIndexScan:
-                               _outBitmapIndexScan(str, obj);
-                               break;
-                       case T_BitmapHeapScan:
-                               _outBitmapHeapScan(str, obj);
-                               break;
-                       case T_TidScan:
-                               _outTidScan(str, obj);
-                               break;
-                       case T_TidRangeScan:
-                               _outTidRangeScan(str, obj);
-                               break;
-                       case T_SubqueryScan:
-                               _outSubqueryScan(str, obj);
-                               break;
-                       case T_FunctionScan:
-                               _outFunctionScan(str, obj);
-                               break;
-                       case T_TableFuncScan:
-                               _outTableFuncScan(str, obj);
-                               break;
-                       case T_ValuesScan:
-                               _outValuesScan(str, obj);
-                               break;
-                       case T_CteScan:
-                               _outCteScan(str, obj);
-                               break;
-                       case T_NamedTuplestoreScan:
-                               _outNamedTuplestoreScan(str, obj);
-                               break;
-                       case T_WorkTableScan:
-                               _outWorkTableScan(str, obj);
-                               break;
-                       case T_ForeignScan:
-                               _outForeignScan(str, obj);
-                               break;
-                       case T_CustomScan:
-                               _outCustomScan(str, obj);
-                               break;
-                       case T_NestLoop:
-                               _outNestLoop(str, obj);
-                               break;
-                       case T_MergeJoin:
-                               _outMergeJoin(str, obj);
-                               break;
-                       case T_HashJoin:
-                               _outHashJoin(str, obj);
-                               break;
-                       case T_Agg:
-                               _outAgg(str, obj);
-                               break;
-                       case T_WindowAgg:
-                               _outWindowAgg(str, obj);
-                               break;
-                       case T_Group:
-                               _outGroup(str, obj);
-                               break;
-                       case T_Material:
-                               _outMaterial(str, obj);
-                               break;
-                       case T_Memoize:
-                               _outMemoize(str, obj);
-                               break;
-                       case T_Sort:
-                               _outSort(str, obj);
-                               break;
-                       case T_IncrementalSort:
-                               _outIncrementalSort(str, obj);
-                               break;
-                       case T_Unique:
-                               _outUnique(str, obj);
-                               break;
-                       case T_Hash:
-                               _outHash(str, obj);
-                               break;
-                       case T_SetOp:
-                               _outSetOp(str, obj);
-                               break;
-                       case T_LockRows:
-                               _outLockRows(str, obj);
-                               break;
-                       case T_Limit:
-                               _outLimit(str, obj);
-                               break;
-                       case T_NestLoopParam:
-                               _outNestLoopParam(str, obj);
-                               break;
-                       case T_PlanRowMark:
-                               _outPlanRowMark(str, obj);
-                               break;
-                       case T_PartitionPruneInfo:
-                               _outPartitionPruneInfo(str, obj);
-                               break;
-                       case T_PartitionedRelPruneInfo:
-                               _outPartitionedRelPruneInfo(str, obj);
-                               break;
-                       case T_PartitionPruneStepOp:
-                               _outPartitionPruneStepOp(str, obj);
-                               break;
-                       case T_PartitionPruneStepCombine:
-                               _outPartitionPruneStepCombine(str, obj);
-                               break;
-                       case T_PlanInvalItem:
-                               _outPlanInvalItem(str, obj);
-                               break;
-                       case T_Alias:
-                               _outAlias(str, obj);
-                               break;
-                       case T_RangeVar:
-                               _outRangeVar(str, obj);
-                               break;
-                       case T_TableFunc:
-                               _outTableFunc(str, obj);
-                               break;
-                       case T_IntoClause:
-                               _outIntoClause(str, obj);
-                               break;
-                       case T_Var:
-                               _outVar(str, obj);
-                               break;
-                       case T_Const:
-                               _outConst(str, obj);
-                               break;
-                       case T_Param:
-                               _outParam(str, obj);
-                               break;
-                       case T_Aggref:
-                               _outAggref(str, obj);
-                               break;
-                       case T_GroupingFunc:
-                               _outGroupingFunc(str, obj);
-                               break;
-                       case T_WindowFunc:
-                               _outWindowFunc(str, obj);
-                               break;
-                       case T_SubscriptingRef:
-                               _outSubscriptingRef(str, obj);
-                               break;
-                       case T_FuncExpr:
-                               _outFuncExpr(str, obj);
-                               break;
-                       case T_NamedArgExpr:
-                               _outNamedArgExpr(str, obj);
-                               break;
-                       case T_OpExpr:
-                               _outOpExpr(str, obj);
-                               break;
-                       case T_DistinctExpr:
-                               _outDistinctExpr(str, obj);
-                               break;
-                       case T_NullIfExpr:
-                               _outNullIfExpr(str, obj);
-                               break;
-                       case T_ScalarArrayOpExpr:
-                               _outScalarArrayOpExpr(str, obj);
-                               break;
-                       case T_BoolExpr:
-                               _outBoolExpr(str, obj);
-                               break;
-                       case T_SubLink:
-                               _outSubLink(str, obj);
-                               break;
-                       case T_SubPlan:
-                               _outSubPlan(str, obj);
-                               break;
-                       case T_AlternativeSubPlan:
-                               _outAlternativeSubPlan(str, obj);
-                               break;
-                       case T_FieldSelect:
-                               _outFieldSelect(str, obj);
-                               break;
-                       case T_FieldStore:
-                               _outFieldStore(str, obj);
-                               break;
-                       case T_RelabelType:
-                               _outRelabelType(str, obj);
-                               break;
-                       case T_CoerceViaIO:
-                               _outCoerceViaIO(str, obj);
-                               break;
-                       case T_ArrayCoerceExpr:
-                               _outArrayCoerceExpr(str, obj);
-                               break;
-                       case T_ConvertRowtypeExpr:
-                               _outConvertRowtypeExpr(str, obj);
-                               break;
-                       case T_CollateExpr:
-                               _outCollateExpr(str, obj);
-                               break;
-                       case T_CaseExpr:
-                               _outCaseExpr(str, obj);
-                               break;
-                       case T_CaseWhen:
-                               _outCaseWhen(str, obj);
-                               break;
-                       case T_CaseTestExpr:
-                               _outCaseTestExpr(str, obj);
-                               break;
-                       case T_ArrayExpr:
-                               _outArrayExpr(str, obj);
-                               break;
-                       case T_RowExpr:
-                               _outRowExpr(str, obj);
-                               break;
-                       case T_RowCompareExpr:
-                               _outRowCompareExpr(str, obj);
-                               break;
-                       case T_CoalesceExpr:
-                               _outCoalesceExpr(str, obj);
-                               break;
-                       case T_MinMaxExpr:
-                               _outMinMaxExpr(str, obj);
-                               break;
-                       case T_SQLValueFunction:
-                               _outSQLValueFunction(str, obj);
-                               break;
-                       case T_XmlExpr:
-                               _outXmlExpr(str, obj);
-                               break;
-                       case T_NullTest:
-                               _outNullTest(str, obj);
-                               break;
-                       case T_BooleanTest:
-                               _outBooleanTest(str, obj);
-                               break;
-                       case T_CoerceToDomain:
-                               _outCoerceToDomain(str, obj);
-                               break;
-                       case T_CoerceToDomainValue:
-                               _outCoerceToDomainValue(str, obj);
-                               break;
-                       case T_SetToDefault:
-                               _outSetToDefault(str, obj);
-                               break;
-                       case T_CurrentOfExpr:
-                               _outCurrentOfExpr(str, obj);
-                               break;
-                       case T_NextValueExpr:
-                               _outNextValueExpr(str, obj);
-                               break;
-                       case T_InferenceElem:
-                               _outInferenceElem(str, obj);
-                               break;
-                       case T_TargetEntry:
-                               _outTargetEntry(str, obj);
-                               break;
-                       case T_RangeTblRef:
-                               _outRangeTblRef(str, obj);
-                               break;
-                       case T_JoinExpr:
-                               _outJoinExpr(str, obj);
-                               break;
-                       case T_FromExpr:
-                               _outFromExpr(str, obj);
-                               break;
-                       case T_OnConflictExpr:
-                               _outOnConflictExpr(str, obj);
-                               break;
-                       case T_Path:
-                               _outPath(str, obj);
-                               break;
-                       case T_IndexPath:
-                               _outIndexPath(str, obj);
-                               break;
-                       case T_BitmapHeapPath:
-                               _outBitmapHeapPath(str, obj);
-                               break;
-                       case T_BitmapAndPath:
-                               _outBitmapAndPath(str, obj);
-                               break;
-                       case T_BitmapOrPath:
-                               _outBitmapOrPath(str, obj);
-                               break;
-                       case T_TidPath:
-                               _outTidPath(str, obj);
-                               break;
-                       case T_TidRangePath:
-                               _outTidRangePath(str, obj);
-                               break;
-                       case T_SubqueryScanPath:
-                               _outSubqueryScanPath(str, obj);
-                               break;
-                       case T_ForeignPath:
-                               _outForeignPath(str, obj);
-                               break;
-                       case T_CustomPath:
-                               _outCustomPath(str, obj);
-                               break;
-                       case T_AppendPath:
-                               _outAppendPath(str, obj);
-                               break;
-                       case T_MergeAppendPath:
-                               _outMergeAppendPath(str, obj);
-                               break;
-                       case T_GroupResultPath:
-                               _outGroupResultPath(str, obj);
-                               break;
-                       case T_MaterialPath:
-                               _outMaterialPath(str, obj);
-                               break;
-                       case T_MemoizePath:
-                               _outMemoizePath(str, obj);
-                               break;
-                       case T_UniquePath:
-                               _outUniquePath(str, obj);
-                               break;
-                       case T_GatherPath:
-                               _outGatherPath(str, obj);
-                               break;
-                       case T_ProjectionPath:
-                               _outProjectionPath(str, obj);
-                               break;
-                       case T_ProjectSetPath:
-                               _outProjectSetPath(str, obj);
-                               break;
-                       case T_SortPath:
-                               _outSortPath(str, obj);
-                               break;
-                       case T_IncrementalSortPath:
-                               _outIncrementalSortPath(str, obj);
-                               break;
-                       case T_GroupPath:
-                               _outGroupPath(str, obj);
-                               break;
-                       case T_UpperUniquePath:
-                               _outUpperUniquePath(str, obj);
-                               break;
-                       case T_AggPath:
-                               _outAggPath(str, obj);
-                               break;
-                       case T_GroupingSetsPath:
-                               _outGroupingSetsPath(str, obj);
-                               break;
-                       case T_MinMaxAggPath:
-                               _outMinMaxAggPath(str, obj);
-                               break;
-                       case T_WindowAggPath:
-                               _outWindowAggPath(str, obj);
-                               break;
-                       case T_SetOpPath:
-                               _outSetOpPath(str, obj);
-                               break;
-                       case T_RecursiveUnionPath:
-                               _outRecursiveUnionPath(str, obj);
-                               break;
-                       case T_LockRowsPath:
-                               _outLockRowsPath(str, obj);
-                               break;
-                       case T_ModifyTablePath:
-                               _outModifyTablePath(str, obj);
-                               break;
-                       case T_LimitPath:
-                               _outLimitPath(str, obj);
-                               break;
-                       case T_GatherMergePath:
-                               _outGatherMergePath(str, obj);
-                               break;
-                       case T_NestPath:
-                               _outNestPath(str, obj);
-                               break;
-                       case T_MergePath:
-                               _outMergePath(str, obj);
-                               break;
-                       case T_HashPath:
-                               _outHashPath(str, obj);
-                               break;
-                       case T_PlannerGlobal:
-                               _outPlannerGlobal(str, obj);
-                               break;
-                       case T_PlannerInfo:
-                               _outPlannerInfo(str, obj);
-                               break;
-                       case T_RelOptInfo:
-                               _outRelOptInfo(str, obj);
-                               break;
-                       case T_IndexOptInfo:
-                               _outIndexOptInfo(str, obj);
-                               break;
-                       case T_ForeignKeyOptInfo:
-                               _outForeignKeyOptInfo(str, obj);
-                               break;
-                       case T_EquivalenceClass:
-                               _outEquivalenceClass(str, obj);
-                               break;
-                       case T_EquivalenceMember:
-                               _outEquivalenceMember(str, obj);
-                               break;
-                       case T_PathKey:
-                               _outPathKey(str, obj);
-                               break;
-                       case T_PathTarget:
-                               _outPathTarget(str, obj);
-                               break;
-                       case T_ParamPathInfo:
-                               _outParamPathInfo(str, obj);
-                               break;
-                       case T_RestrictInfo:
-                               _outRestrictInfo(str, obj);
-                               break;
-                       case T_IndexClause:
-                               _outIndexClause(str, obj);
-                               break;
-                       case T_PlaceHolderVar:
-                               _outPlaceHolderVar(str, obj);
-                               break;
-                       case T_SpecialJoinInfo:
-                               _outSpecialJoinInfo(str, obj);
-                               break;
-                       case T_AppendRelInfo:
-                               _outAppendRelInfo(str, obj);
-                               break;
-                       case T_RowIdentityVarInfo:
-                               _outRowIdentityVarInfo(str, obj);
-                               break;
-                       case T_PlaceHolderInfo:
-                               _outPlaceHolderInfo(str, obj);
-                               break;
-                       case T_MinMaxAggInfo:
-                               _outMinMaxAggInfo(str, obj);
-                               break;
-                       case T_PlannerParamItem:
-                               _outPlannerParamItem(str, obj);
-                               break;
-                       case T_RollupData:
-                               _outRollupData(str, obj);
-                               break;
-                       case T_GroupingSetData:
-                               _outGroupingSetData(str, obj);
-                               break;
-                       case T_StatisticExtInfo:
-                               _outStatisticExtInfo(str, obj);
-                               break;
-                       case T_ExtensibleNode:
-                               _outExtensibleNode(str, obj);
-                               break;
-                       case T_CreateStmt:
-                               _outCreateStmt(str, obj);
-                               break;
-                       case T_CreateForeignTableStmt:
-                               _outCreateForeignTableStmt(str, obj);
-                               break;
-                       case T_ImportForeignSchemaStmt:
-                               _outImportForeignSchemaStmt(str, obj);
-                               break;
-                       case T_IndexStmt:
-                               _outIndexStmt(str, obj);
-                               break;
-                       case T_CreateStatsStmt:
-                               _outCreateStatsStmt(str, obj);
-                               break;
-                       case T_AlterStatsStmt:
-                               _outAlterStatsStmt(str, obj);
-                               break;
-                       case T_NotifyStmt:
-                               _outNotifyStmt(str, obj);
-                               break;
-                       case T_DeclareCursorStmt:
-                               _outDeclareCursorStmt(str, obj);
-                               break;
-                       case T_SelectStmt:
-                               _outSelectStmt(str, obj);
-                               break;
-                       case T_ReturnStmt:
-                               _outReturnStmt(str, obj);
-                               break;
-                       case T_PLAssignStmt:
-                               _outPLAssignStmt(str, obj);
-                               break;
-                       case T_ColumnDef:
-                               _outColumnDef(str, obj);
-                               break;
-                       case T_TypeName:
-                               _outTypeName(str, obj);
-                               break;
-                       case T_TypeCast:
-                               _outTypeCast(str, obj);
-                               break;
-                       case T_CollateClause:
-                               _outCollateClause(str, obj);
-                               break;
-                       case T_IndexElem:
-                               _outIndexElem(str, obj);
-                               break;
-                       case T_StatsElem:
-                               _outStatsElem(str, obj);
-                               break;
-                       case T_Query:
-                               _outQuery(str, obj);
-                               break;
-                       case T_WithCheckOption:
-                               _outWithCheckOption(str, obj);
-                               break;
-                       case T_SortGroupClause:
-                               _outSortGroupClause(str, obj);
-                               break;
-                       case T_GroupingSet:
-                               _outGroupingSet(str, obj);
-                               break;
-                       case T_WindowClause:
-                               _outWindowClause(str, obj);
-                               break;
-                       case T_RowMarkClause:
-                               _outRowMarkClause(str, obj);
-                               break;
-                       case T_WithClause:
-                               _outWithClause(str, obj);
-                               break;
-                       case T_CTESearchClause:
-                               _outCTESearchClause(str, obj);
-                               break;
-                       case T_CTECycleClause:
-                               _outCTECycleClause(str, obj);
-                               break;
-                       case T_CommonTableExpr:
-                               _outCommonTableExpr(str, obj);
-                               break;
-                       case T_MergeWhenClause:
-                               _outMergeWhenClause(str, obj);
-                               break;
-                       case T_MergeAction:
-                               _outMergeAction(str, obj);
-                               break;
-                       case T_SetOperationStmt:
-                               _outSetOperationStmt(str, obj);
-                               break;
-                       case T_RangeTblEntry:
-                               _outRangeTblEntry(str, obj);
-                               break;
-                       case T_RangeTblFunction:
-                               _outRangeTblFunction(str, obj);
-                               break;
-                       case T_TableSampleClause:
-                               _outTableSampleClause(str, obj);
-                               break;
-                       case T_A_Expr:
-                               _outA_Expr(str, obj);
-                               break;
-                       case T_ColumnRef:
-                               _outColumnRef(str, obj);
-                               break;
-                       case T_ParamRef:
-                               _outParamRef(str, obj);
-                               break;
-                       case T_RawStmt:
-                               _outRawStmt(str, obj);
-                               break;
-                       case T_A_Const:
-                               _outA_Const(str, obj);
-                               break;
-                       case T_A_Star:
-                               _outA_Star(str, obj);
-                               break;
-                       case T_A_Indices:
-                               _outA_Indices(str, obj);
-                               break;
-                       case T_A_Indirection:
-                               _outA_Indirection(str, obj);
-                               break;
-                       case T_A_ArrayExpr:
-                               _outA_ArrayExpr(str, obj);
-                               break;
-                       case T_ResTarget:
-                               _outResTarget(str, obj);
-                               break;
-                       case T_MultiAssignRef:
-                               _outMultiAssignRef(str, obj);
-                               break;
-                       case T_SortBy:
-                               _outSortBy(str, obj);
-                               break;
-                       case T_WindowDef:
-                               _outWindowDef(str, obj);
-                               break;
-                       case T_RangeSubselect:
-                               _outRangeSubselect(str, obj);
-                               break;
-                       case T_RangeFunction:
-                               _outRangeFunction(str, obj);
-                               break;
-                       case T_RangeTableSample:
-                               _outRangeTableSample(str, obj);
-                               break;
-                       case T_RangeTableFunc:
-                               _outRangeTableFunc(str, obj);
-                               break;
-                       case T_RangeTableFuncCol:
-                               _outRangeTableFuncCol(str, obj);
-                               break;
-                       case T_Constraint:
-                               _outConstraint(str, obj);
-                               break;
-                       case T_FuncCall:
-                               _outFuncCall(str, obj);
-                               break;
-                       case T_DefElem:
-                               _outDefElem(str, obj);
-                               break;
-                       case T_TableLikeClause:
-                               _outTableLikeClause(str, obj);
-                               break;
-                       case T_LockingClause:
-                               _outLockingClause(str, obj);
-                               break;
-                       case T_XmlSerialize:
-                               _outXmlSerialize(str, obj);
-                               break;
-                       case T_ForeignKeyCacheInfo:
-                               _outForeignKeyCacheInfo(str, obj);
-                               break;
-                       case T_TriggerTransition:
-                               _outTriggerTransition(str, obj);
-                               break;
-                       case T_PartitionElem:
-                               _outPartitionElem(str, obj);
-                               break;
-                       case T_PartitionSpec:
-                               _outPartitionSpec(str, obj);
-                               break;
-                       case T_PartitionBoundSpec:
-                               _outPartitionBoundSpec(str, obj);
-                               break;
-                       case T_PartitionRangeDatum:
-                               _outPartitionRangeDatum(str, obj);
-                               break;
-                       case T_JsonFormat:
-                               _outJsonFormat(str, obj);
-                               break;
-                       case T_JsonReturning:
-                               _outJsonReturning(str, obj);
-                               break;
-                       case T_JsonValueExpr:
-                               _outJsonValueExpr(str, obj);
-                               break;
-                       case T_JsonConstructorExpr:
-                               _outJsonConstructorExpr(str, obj);
-                               break;
-                       case T_JsonIsPredicate:
-                               _outJsonIsPredicate(str, obj);
-                               break;
-                       case T_JsonBehavior:
-                               _outJsonBehavior(str, obj);
-                               break;
-                       case T_JsonExpr:
-                               _outJsonExpr(str, obj);
-                               break;
-                       case T_JsonCoercion:
-                               _outJsonCoercion(str, obj);
-                               break;
-                       case T_JsonItemCoercions:
-                               _outJsonItemCoercions(str, obj);
-                               break;
-                       case T_JsonTableParent:
-                               _outJsonTableParent(str, obj);
-                               break;
-                       case T_JsonTableSibling:
-                               _outJsonTableSibling(str, obj);
-                               break;
-#endif                                                 /* OBSOLETE */
 
                        default:
 
index 21176cd4c04904f4d23a6d4ebfd03ee7bb05afad..67b0f798c15c8a5a9fada943aa99d9ae409a7ab6 100644 (file)
@@ -238,9 +238,12 @@ readBitmapset(void)
 
 #include "readfuncs.funcs.c"
 
+
 /*
- * _readQuery
+ * Support functions for nodes with custom_read_write attribute or
+ * special_read_write attribute
  */
+
 static Query *
 _readQuery(void)
 {
@@ -291,2636 +294,169 @@ _readQuery(void)
        READ_DONE();
 }
 
-#ifdef OBSOLETE
-/*
- * _readNotifyStmt
- */
-static NotifyStmt *
-_readNotifyStmt(void)
-{
-       READ_LOCALS(NotifyStmt);
-
-       READ_STRING_FIELD(conditionname);
-       READ_STRING_FIELD(payload);
-
-       READ_DONE();
-}
-
-/*
- * _readDeclareCursorStmt
- */
-static DeclareCursorStmt *
-_readDeclareCursorStmt(void)
-{
-       READ_LOCALS(DeclareCursorStmt);
-
-       READ_STRING_FIELD(portalname);
-       READ_INT_FIELD(options);
-       READ_NODE_FIELD(query);
-
-       READ_DONE();
-}
-
-/*
- * _readWithCheckOption
- */
-static WithCheckOption *
-_readWithCheckOption(void)
-{
-       READ_LOCALS(WithCheckOption);
-
-       READ_ENUM_FIELD(kind, WCOKind);
-       READ_STRING_FIELD(relname);
-       READ_STRING_FIELD(polname);
-       READ_NODE_FIELD(qual);
-       READ_BOOL_FIELD(cascaded);
-
-       READ_DONE();
-}
-
-/*
- * _readSortGroupClause
- */
-static SortGroupClause *
-_readSortGroupClause(void)
-{
-       READ_LOCALS(SortGroupClause);
-
-       READ_UINT_FIELD(tleSortGroupRef);
-       READ_OID_FIELD(eqop);
-       READ_OID_FIELD(sortop);
-       READ_BOOL_FIELD(nulls_first);
-       READ_BOOL_FIELD(hashable);
-
-       READ_DONE();
-}
-
-/*
- * _readGroupingSet
- */
-static GroupingSet *
-_readGroupingSet(void)
+static Const *
+_readConst(void)
 {
-       READ_LOCALS(GroupingSet);
+       READ_LOCALS(Const);
 
-       READ_ENUM_FIELD(kind, GroupingSetKind);
-       READ_NODE_FIELD(content);
+       READ_OID_FIELD(consttype);
+       READ_INT_FIELD(consttypmod);
+       READ_OID_FIELD(constcollid);
+       READ_INT_FIELD(constlen);
+       READ_BOOL_FIELD(constbyval);
+       READ_BOOL_FIELD(constisnull);
        READ_LOCATION_FIELD(location);
 
-       READ_DONE();
-}
-
-/*
- * _readWindowClause
- */
-static WindowClause *
-_readWindowClause(void)
-{
-       READ_LOCALS(WindowClause);
-
-       READ_STRING_FIELD(name);
-       READ_STRING_FIELD(refname);
-       READ_NODE_FIELD(partitionClause);
-       READ_NODE_FIELD(orderClause);
-       READ_INT_FIELD(frameOptions);
-       READ_NODE_FIELD(startOffset);
-       READ_NODE_FIELD(endOffset);
-       READ_NODE_FIELD(runCondition);
-       READ_OID_FIELD(startInRangeFunc);
-       READ_OID_FIELD(endInRangeFunc);
-       READ_OID_FIELD(inRangeColl);
-       READ_BOOL_FIELD(inRangeAsc);
-       READ_BOOL_FIELD(inRangeNullsFirst);
-       READ_UINT_FIELD(winref);
-       READ_BOOL_FIELD(copiedOrder);
-
-       READ_DONE();
-}
-
-/*
- * _readRowMarkClause
- */
-static RowMarkClause *
-_readRowMarkClause(void)
-{
-       READ_LOCALS(RowMarkClause);
-
-       READ_UINT_FIELD(rti);
-       READ_ENUM_FIELD(strength, LockClauseStrength);
-       READ_ENUM_FIELD(waitPolicy, LockWaitPolicy);
-       READ_BOOL_FIELD(pushedDown);
-
-       READ_DONE();
-}
-
-/*
- * _readCTESearchClause
- */
-static CTESearchClause *
-_readCTESearchClause(void)
-{
-       READ_LOCALS(CTESearchClause);
-
-       READ_NODE_FIELD(search_col_list);
-       READ_BOOL_FIELD(search_breadth_first);
-       READ_STRING_FIELD(search_seq_column);
-       READ_LOCATION_FIELD(location);
+       token = pg_strtok(&length); /* skip :constvalue */
+       if (local_node->constisnull)
+               token = pg_strtok(&length); /* skip "<>" */
+       else
+               local_node->constvalue = readDatum(local_node->constbyval);
 
        READ_DONE();
 }
 
-/*
- * _readCTECycleClause
- */
-static CTECycleClause *
-_readCTECycleClause(void)
+static BoolExpr *
+_readBoolExpr(void)
 {
-       READ_LOCALS(CTECycleClause);
-
-       READ_NODE_FIELD(cycle_col_list);
-       READ_STRING_FIELD(cycle_mark_column);
-       READ_NODE_FIELD(cycle_mark_value);
-       READ_NODE_FIELD(cycle_mark_default);
-       READ_STRING_FIELD(cycle_path_column);
-       READ_LOCATION_FIELD(location);
-       READ_OID_FIELD(cycle_mark_type);
-       READ_INT_FIELD(cycle_mark_typmod);
-       READ_OID_FIELD(cycle_mark_collation);
-       READ_OID_FIELD(cycle_mark_neop);
+       READ_LOCALS(BoolExpr);
 
-       READ_DONE();
-}
+       /* do-it-yourself enum representation */
+       token = pg_strtok(&length); /* skip :boolop */
+       token = pg_strtok(&length); /* get field value */
+       if (strncmp(token, "and", 3) == 0)
+               local_node->boolop = AND_EXPR;
+       else if (strncmp(token, "or", 2) == 0)
+               local_node->boolop = OR_EXPR;
+       else if (strncmp(token, "not", 3) == 0)
+               local_node->boolop = NOT_EXPR;
+       else
+               elog(ERROR, "unrecognized boolop \"%.*s\"", length, token);
 
-/*
- * _readCommonTableExpr
- */
-static CommonTableExpr *
-_readCommonTableExpr(void)
-{
-       READ_LOCALS(CommonTableExpr);
-
-       READ_STRING_FIELD(ctename);
-       READ_NODE_FIELD(aliascolnames);
-       READ_ENUM_FIELD(ctematerialized, CTEMaterialize);
-       READ_NODE_FIELD(ctequery);
-       READ_NODE_FIELD(search_clause);
-       READ_NODE_FIELD(cycle_clause);
+       READ_NODE_FIELD(args);
        READ_LOCATION_FIELD(location);
-       READ_BOOL_FIELD(cterecursive);
-       READ_INT_FIELD(cterefcount);
-       READ_NODE_FIELD(ctecolnames);
-       READ_NODE_FIELD(ctecoltypes);
-       READ_NODE_FIELD(ctecoltypmods);
-       READ_NODE_FIELD(ctecolcollations);
-
-       READ_DONE();
-}
-
-/*
- * _readMergeWhenClause
- */
-static MergeWhenClause *
-_readMergeWhenClause(void)
-{
-       READ_LOCALS(MergeWhenClause);
-
-       READ_BOOL_FIELD(matched);
-       READ_ENUM_FIELD(commandType, CmdType);
-       READ_ENUM_FIELD(override, OverridingKind);
-       READ_NODE_FIELD(condition);
-       READ_NODE_FIELD(targetList);
-       READ_NODE_FIELD(values);
-
-       READ_DONE();
-}
-
-/*
- * _readMergeAction
- */
-static MergeAction *
-_readMergeAction(void)
-{
-       READ_LOCALS(MergeAction);
-
-       READ_BOOL_FIELD(matched);
-       READ_ENUM_FIELD(commandType, CmdType);
-       READ_ENUM_FIELD(override, OverridingKind);
-       READ_NODE_FIELD(qual);
-       READ_NODE_FIELD(targetList);
-       READ_NODE_FIELD(updateColnos);
-
-       READ_DONE();
-}
-
-/*
- * _readSetOperationStmt
- */
-static SetOperationStmt *
-_readSetOperationStmt(void)
-{
-       READ_LOCALS(SetOperationStmt);
-
-       READ_ENUM_FIELD(op, SetOperation);
-       READ_BOOL_FIELD(all);
-       READ_NODE_FIELD(larg);
-       READ_NODE_FIELD(rarg);
-       READ_NODE_FIELD(colTypes);
-       READ_NODE_FIELD(colTypmods);
-       READ_NODE_FIELD(colCollations);
-       READ_NODE_FIELD(groupClauses);
 
        READ_DONE();
 }
 
-
-/*
- *     Stuff from primnodes.h.
- */
-
-static Alias *
-_readAlias(void)
+static RangeTblEntry *
+_readRangeTblEntry(void)
 {
-       READ_LOCALS(Alias);
-
-       READ_STRING_FIELD(aliasname);
-       READ_NODE_FIELD(colnames);
+       READ_LOCALS(RangeTblEntry);
 
-       READ_DONE();
-}
+       /* put alias + eref first to make dump more legible */
+       READ_NODE_FIELD(alias);
+       READ_NODE_FIELD(eref);
+       READ_ENUM_FIELD(rtekind, RTEKind);
 
-static RangeVar *
-_readRangeVar(void)
-{
-       READ_LOCALS(RangeVar);
+       switch (local_node->rtekind)
+       {
+               case RTE_RELATION:
+                       READ_OID_FIELD(relid);
+                       READ_CHAR_FIELD(relkind);
+                       READ_INT_FIELD(rellockmode);
+                       READ_NODE_FIELD(tablesample);
+                       break;
+               case RTE_SUBQUERY:
+                       READ_NODE_FIELD(subquery);
+                       READ_BOOL_FIELD(security_barrier);
+                       break;
+               case RTE_JOIN:
+                       READ_ENUM_FIELD(jointype, JoinType);
+                       READ_INT_FIELD(joinmergedcols);
+                       READ_NODE_FIELD(joinaliasvars);
+                       READ_NODE_FIELD(joinleftcols);
+                       READ_NODE_FIELD(joinrightcols);
+                       READ_NODE_FIELD(join_using_alias);
+                       break;
+               case RTE_FUNCTION:
+                       READ_NODE_FIELD(functions);
+                       READ_BOOL_FIELD(funcordinality);
+                       break;
+               case RTE_TABLEFUNC:
+                       READ_NODE_FIELD(tablefunc);
+                       /* The RTE must have a copy of the column type info, if any */
+                       if (local_node->tablefunc)
+                       {
+                               TableFunc  *tf = local_node->tablefunc;
 
-       local_node->catalogname = NULL; /* not currently saved in output format */
+                               local_node->coltypes = tf->coltypes;
+                               local_node->coltypmods = tf->coltypmods;
+                               local_node->colcollations = tf->colcollations;
+                       }
+                       break;
+               case RTE_VALUES:
+                       READ_NODE_FIELD(values_lists);
+                       READ_NODE_FIELD(coltypes);
+                       READ_NODE_FIELD(coltypmods);
+                       READ_NODE_FIELD(colcollations);
+                       break;
+               case RTE_CTE:
+                       READ_STRING_FIELD(ctename);
+                       READ_UINT_FIELD(ctelevelsup);
+                       READ_BOOL_FIELD(self_reference);
+                       READ_NODE_FIELD(coltypes);
+                       READ_NODE_FIELD(coltypmods);
+                       READ_NODE_FIELD(colcollations);
+                       break;
+               case RTE_NAMEDTUPLESTORE:
+                       READ_STRING_FIELD(enrname);
+                       READ_FLOAT_FIELD(enrtuples);
+                       READ_OID_FIELD(relid);
+                       READ_NODE_FIELD(coltypes);
+                       READ_NODE_FIELD(coltypmods);
+                       READ_NODE_FIELD(colcollations);
+                       break;
+               case RTE_RESULT:
+                       /* no extra fields */
+                       break;
+               default:
+                       elog(ERROR, "unrecognized RTE kind: %d",
+                                (int) local_node->rtekind);
+                       break;
+       }
 
-       READ_STRING_FIELD(schemaname);
-       READ_STRING_FIELD(relname);
+       READ_BOOL_FIELD(lateral);
        READ_BOOL_FIELD(inh);
-       READ_CHAR_FIELD(relpersistence);
-       READ_NODE_FIELD(alias);
-       READ_LOCATION_FIELD(location);
+       READ_BOOL_FIELD(inFromCl);
+       READ_UINT_FIELD(requiredPerms);
+       READ_OID_FIELD(checkAsUser);
+       READ_BITMAPSET_FIELD(selectedCols);
+       READ_BITMAPSET_FIELD(insertedCols);
+       READ_BITMAPSET_FIELD(updatedCols);
+       READ_BITMAPSET_FIELD(extraUpdatedCols);
+       READ_NODE_FIELD(securityQuals);
 
        READ_DONE();
 }
 
-/*
- * _readTableFunc
- */
-static TableFunc *
-_readTableFunc(void)
+static ExtensibleNode *
+_readExtensibleNode(void)
 {
-       READ_LOCALS(TableFunc);
-
-       READ_ENUM_FIELD(functype, TableFuncType);
-       READ_NODE_FIELD(ns_uris);
-       READ_NODE_FIELD(ns_names);
-       READ_NODE_FIELD(docexpr);
-       READ_NODE_FIELD(rowexpr);
-       READ_NODE_FIELD(colnames);
-       READ_NODE_FIELD(coltypes);
-       READ_NODE_FIELD(coltypmods);
-       READ_NODE_FIELD(colcollations);
-       READ_NODE_FIELD(colexprs);
-       READ_NODE_FIELD(coldefexprs);
-       READ_NODE_FIELD(colvalexprs);
-       READ_BITMAPSET_FIELD(notnulls);
-       READ_NODE_FIELD(plan);
-       READ_INT_FIELD(ordinalitycol);
-       READ_LOCATION_FIELD(location);
+       const ExtensibleNodeMethods *methods;
+       ExtensibleNode *local_node;
+       const char *extnodename;
 
-       READ_DONE();
-}
+       READ_TEMP_LOCALS();
 
-static IntoClause *
-_readIntoClause(void)
-{
-       READ_LOCALS(IntoClause);
+       token = pg_strtok(&length); /* skip :extnodename */
+       token = pg_strtok(&length); /* get extnodename */
 
-       READ_NODE_FIELD(rel);
-       READ_NODE_FIELD(colNames);
-       READ_STRING_FIELD(accessMethod);
-       READ_NODE_FIELD(options);
-       READ_ENUM_FIELD(onCommit, OnCommitAction);
-       READ_STRING_FIELD(tableSpaceName);
-       READ_NODE_FIELD(viewQuery);
-       READ_BOOL_FIELD(skipData);
+       extnodename = nullable_string(token, length);
+       if (!extnodename)
+               elog(ERROR, "extnodename has to be supplied");
+       methods = GetExtensibleNodeMethods(extnodename, false);
 
-       READ_DONE();
-}
+       local_node = (ExtensibleNode *) newNode(methods->node_size,
+                                                                                       T_ExtensibleNode);
+       local_node->extnodename = extnodename;
 
-/*
- * _readVar
- */
-static Var *
-_readVar(void)
-{
-       READ_LOCALS(Var);
-
-       READ_INT_FIELD(varno);
-       READ_INT_FIELD(varattno);
-       READ_OID_FIELD(vartype);
-       READ_INT_FIELD(vartypmod);
-       READ_OID_FIELD(varcollid);
-       READ_UINT_FIELD(varlevelsup);
-       READ_UINT_FIELD(varnosyn);
-       READ_INT_FIELD(varattnosyn);
-       READ_LOCATION_FIELD(location);
+       /* deserialize the private fields */
+       methods->nodeRead(local_node);
 
        READ_DONE();
 }
-#endif                                                 /* OBSOLETE */
-
-/*
- * _readConst
- */
-static Const *
-_readConst(void)
-{
-       READ_LOCALS(Const);
 
-       READ_OID_FIELD(consttype);
-       READ_INT_FIELD(consttypmod);
-       READ_OID_FIELD(constcollid);
-       READ_INT_FIELD(constlen);
-       READ_BOOL_FIELD(constbyval);
-       READ_BOOL_FIELD(constisnull);
-       READ_LOCATION_FIELD(location);
-
-       token = pg_strtok(&length); /* skip :constvalue */
-       if (local_node->constisnull)
-               token = pg_strtok(&length); /* skip "<>" */
-       else
-               local_node->constvalue = readDatum(local_node->constbyval);
-
-       READ_DONE();
-}
-
-#ifdef OBSOLETE
-/*
- * _readParam
- */
-static Param *
-_readParam(void)
-{
-       READ_LOCALS(Param);
-
-       READ_ENUM_FIELD(paramkind, ParamKind);
-       READ_INT_FIELD(paramid);
-       READ_OID_FIELD(paramtype);
-       READ_INT_FIELD(paramtypmod);
-       READ_OID_FIELD(paramcollid);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readAggref
- */
-static Aggref *
-_readAggref(void)
-{
-       READ_LOCALS(Aggref);
-
-       READ_OID_FIELD(aggfnoid);
-       READ_OID_FIELD(aggtype);
-       READ_OID_FIELD(aggcollid);
-       READ_OID_FIELD(inputcollid);
-       READ_OID_FIELD(aggtranstype);
-       READ_NODE_FIELD(aggargtypes);
-       READ_NODE_FIELD(aggdirectargs);
-       READ_NODE_FIELD(args);
-       READ_NODE_FIELD(aggorder);
-       READ_NODE_FIELD(aggdistinct);
-       READ_NODE_FIELD(aggfilter);
-       READ_BOOL_FIELD(aggstar);
-       READ_BOOL_FIELD(aggvariadic);
-       READ_CHAR_FIELD(aggkind);
-       READ_UINT_FIELD(agglevelsup);
-       READ_ENUM_FIELD(aggsplit, AggSplit);
-       READ_INT_FIELD(aggno);
-       READ_INT_FIELD(aggtransno);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readGroupingFunc
- */
-static GroupingFunc *
-_readGroupingFunc(void)
-{
-       READ_LOCALS(GroupingFunc);
-
-       READ_NODE_FIELD(args);
-       READ_NODE_FIELD(refs);
-       READ_NODE_FIELD(cols);
-       READ_UINT_FIELD(agglevelsup);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readWindowFunc
- */
-static WindowFunc *
-_readWindowFunc(void)
-{
-       READ_LOCALS(WindowFunc);
-
-       READ_OID_FIELD(winfnoid);
-       READ_OID_FIELD(wintype);
-       READ_OID_FIELD(wincollid);
-       READ_OID_FIELD(inputcollid);
-       READ_NODE_FIELD(args);
-       READ_NODE_FIELD(aggfilter);
-       READ_UINT_FIELD(winref);
-       READ_BOOL_FIELD(winstar);
-       READ_BOOL_FIELD(winagg);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readSubscriptingRef
- */
-static SubscriptingRef *
-_readSubscriptingRef(void)
-{
-       READ_LOCALS(SubscriptingRef);
-
-       READ_OID_FIELD(refcontainertype);
-       READ_OID_FIELD(refelemtype);
-       READ_OID_FIELD(refrestype);
-       READ_INT_FIELD(reftypmod);
-       READ_OID_FIELD(refcollid);
-       READ_NODE_FIELD(refupperindexpr);
-       READ_NODE_FIELD(reflowerindexpr);
-       READ_NODE_FIELD(refexpr);
-       READ_NODE_FIELD(refassgnexpr);
-
-       READ_DONE();
-}
-
-/*
- * _readFuncExpr
- */
-static FuncExpr *
-_readFuncExpr(void)
-{
-       READ_LOCALS(FuncExpr);
-
-       READ_OID_FIELD(funcid);
-       READ_OID_FIELD(funcresulttype);
-       READ_BOOL_FIELD(funcretset);
-       READ_BOOL_FIELD(funcvariadic);
-       READ_ENUM_FIELD(funcformat, CoercionForm);
-       READ_OID_FIELD(funccollid);
-       READ_OID_FIELD(inputcollid);
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readNamedArgExpr
- */
-static NamedArgExpr *
-_readNamedArgExpr(void)
-{
-       READ_LOCALS(NamedArgExpr);
-
-       READ_NODE_FIELD(arg);
-       READ_STRING_FIELD(name);
-       READ_INT_FIELD(argnumber);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readOpExpr
- */
-static OpExpr *
-_readOpExpr(void)
-{
-       READ_LOCALS(OpExpr);
-
-       READ_OID_FIELD(opno);
-       READ_OID_FIELD(opfuncid);
-       READ_OID_FIELD(opresulttype);
-       READ_BOOL_FIELD(opretset);
-       READ_OID_FIELD(opcollid);
-       READ_OID_FIELD(inputcollid);
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readDistinctExpr
- */
-static DistinctExpr *
-_readDistinctExpr(void)
-{
-       READ_LOCALS(DistinctExpr);
-
-       READ_OID_FIELD(opno);
-       READ_OID_FIELD(opfuncid);
-       READ_OID_FIELD(opresulttype);
-       READ_BOOL_FIELD(opretset);
-       READ_OID_FIELD(opcollid);
-       READ_OID_FIELD(inputcollid);
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readNullIfExpr
- */
-static NullIfExpr *
-_readNullIfExpr(void)
-{
-       READ_LOCALS(NullIfExpr);
-
-       READ_OID_FIELD(opno);
-       READ_OID_FIELD(opfuncid);
-       READ_OID_FIELD(opresulttype);
-       READ_BOOL_FIELD(opretset);
-       READ_OID_FIELD(opcollid);
-       READ_OID_FIELD(inputcollid);
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readScalarArrayOpExpr
- */
-static ScalarArrayOpExpr *
-_readScalarArrayOpExpr(void)
-{
-       READ_LOCALS(ScalarArrayOpExpr);
-
-       READ_OID_FIELD(opno);
-       READ_OID_FIELD(opfuncid);
-       READ_OID_FIELD(hashfuncid);
-       READ_OID_FIELD(negfuncid);
-       READ_BOOL_FIELD(useOr);
-       READ_OID_FIELD(inputcollid);
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * _readBoolExpr
- */
-static BoolExpr *
-_readBoolExpr(void)
-{
-       READ_LOCALS(BoolExpr);
-
-       /* do-it-yourself enum representation */
-       token = pg_strtok(&length); /* skip :boolop */
-       token = pg_strtok(&length); /* get field value */
-       if (strncmp(token, "and", 3) == 0)
-               local_node->boolop = AND_EXPR;
-       else if (strncmp(token, "or", 2) == 0)
-               local_node->boolop = OR_EXPR;
-       else if (strncmp(token, "not", 3) == 0)
-               local_node->boolop = NOT_EXPR;
-       else
-               elog(ERROR, "unrecognized boolop \"%.*s\"", length, token);
-
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-#ifdef OBSOLETE
-/*
- * _readSubLink
- */
-static SubLink *
-_readSubLink(void)
-{
-       READ_LOCALS(SubLink);
-
-       READ_ENUM_FIELD(subLinkType, SubLinkType);
-       READ_INT_FIELD(subLinkId);
-       READ_NODE_FIELD(testexpr);
-       READ_NODE_FIELD(operName);
-       READ_NODE_FIELD(subselect);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readSubPlan is not needed since it doesn't appear in stored rules.
- */
-
-/*
- * _readFieldSelect
- */
-static FieldSelect *
-_readFieldSelect(void)
-{
-       READ_LOCALS(FieldSelect);
-
-       READ_NODE_FIELD(arg);
-       READ_INT_FIELD(fieldnum);
-       READ_OID_FIELD(resulttype);
-       READ_INT_FIELD(resulttypmod);
-       READ_OID_FIELD(resultcollid);
-
-       READ_DONE();
-}
-
-/*
- * _readFieldStore
- */
-static FieldStore *
-_readFieldStore(void)
-{
-       READ_LOCALS(FieldStore);
-
-       READ_NODE_FIELD(arg);
-       READ_NODE_FIELD(newvals);
-       READ_NODE_FIELD(fieldnums);
-       READ_OID_FIELD(resulttype);
-
-       READ_DONE();
-}
-
-/*
- * _readRelabelType
- */
-static RelabelType *
-_readRelabelType(void)
-{
-       READ_LOCALS(RelabelType);
-
-       READ_NODE_FIELD(arg);
-       READ_OID_FIELD(resulttype);
-       READ_INT_FIELD(resulttypmod);
-       READ_OID_FIELD(resultcollid);
-       READ_ENUM_FIELD(relabelformat, CoercionForm);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCoerceViaIO
- */
-static CoerceViaIO *
-_readCoerceViaIO(void)
-{
-       READ_LOCALS(CoerceViaIO);
-
-       READ_NODE_FIELD(arg);
-       READ_OID_FIELD(resulttype);
-       READ_OID_FIELD(resultcollid);
-       READ_ENUM_FIELD(coerceformat, CoercionForm);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readArrayCoerceExpr
- */
-static ArrayCoerceExpr *
-_readArrayCoerceExpr(void)
-{
-       READ_LOCALS(ArrayCoerceExpr);
-
-       READ_NODE_FIELD(arg);
-       READ_NODE_FIELD(elemexpr);
-       READ_OID_FIELD(resulttype);
-       READ_INT_FIELD(resulttypmod);
-       READ_OID_FIELD(resultcollid);
-       READ_ENUM_FIELD(coerceformat, CoercionForm);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readConvertRowtypeExpr
- */
-static ConvertRowtypeExpr *
-_readConvertRowtypeExpr(void)
-{
-       READ_LOCALS(ConvertRowtypeExpr);
-
-       READ_NODE_FIELD(arg);
-       READ_OID_FIELD(resulttype);
-       READ_ENUM_FIELD(convertformat, CoercionForm);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCollateExpr
- */
-static CollateExpr *
-_readCollateExpr(void)
-{
-       READ_LOCALS(CollateExpr);
-
-       READ_NODE_FIELD(arg);
-       READ_OID_FIELD(collOid);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCaseExpr
- */
-static CaseExpr *
-_readCaseExpr(void)
-{
-       READ_LOCALS(CaseExpr);
-
-       READ_OID_FIELD(casetype);
-       READ_OID_FIELD(casecollid);
-       READ_NODE_FIELD(arg);
-       READ_NODE_FIELD(args);
-       READ_NODE_FIELD(defresult);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCaseWhen
- */
-static CaseWhen *
-_readCaseWhen(void)
-{
-       READ_LOCALS(CaseWhen);
-
-       READ_NODE_FIELD(expr);
-       READ_NODE_FIELD(result);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCaseTestExpr
- */
-static CaseTestExpr *
-_readCaseTestExpr(void)
-{
-       READ_LOCALS(CaseTestExpr);
-
-       READ_OID_FIELD(typeId);
-       READ_INT_FIELD(typeMod);
-       READ_OID_FIELD(collation);
-
-       READ_DONE();
-}
-
-/*
- * _readArrayExpr
- */
-static ArrayExpr *
-_readArrayExpr(void)
-{
-       READ_LOCALS(ArrayExpr);
-
-       READ_OID_FIELD(array_typeid);
-       READ_OID_FIELD(array_collid);
-       READ_OID_FIELD(element_typeid);
-       READ_NODE_FIELD(elements);
-       READ_BOOL_FIELD(multidims);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readRowExpr
- */
-static RowExpr *
-_readRowExpr(void)
-{
-       READ_LOCALS(RowExpr);
-
-       READ_NODE_FIELD(args);
-       READ_OID_FIELD(row_typeid);
-       READ_ENUM_FIELD(row_format, CoercionForm);
-       READ_NODE_FIELD(colnames);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readRowCompareExpr
- */
-static RowCompareExpr *
-_readRowCompareExpr(void)
-{
-       READ_LOCALS(RowCompareExpr);
-
-       READ_ENUM_FIELD(rctype, RowCompareType);
-       READ_NODE_FIELD(opnos);
-       READ_NODE_FIELD(opfamilies);
-       READ_NODE_FIELD(inputcollids);
-       READ_NODE_FIELD(largs);
-       READ_NODE_FIELD(rargs);
-
-       READ_DONE();
-}
-
-/*
- * _readCoalesceExpr
- */
-static CoalesceExpr *
-_readCoalesceExpr(void)
-{
-       READ_LOCALS(CoalesceExpr);
-
-       READ_OID_FIELD(coalescetype);
-       READ_OID_FIELD(coalescecollid);
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readMinMaxExpr
- */
-static MinMaxExpr *
-_readMinMaxExpr(void)
-{
-       READ_LOCALS(MinMaxExpr);
-
-       READ_OID_FIELD(minmaxtype);
-       READ_OID_FIELD(minmaxcollid);
-       READ_OID_FIELD(inputcollid);
-       READ_ENUM_FIELD(op, MinMaxOp);
-       READ_NODE_FIELD(args);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readSQLValueFunction
- */
-static SQLValueFunction *
-_readSQLValueFunction(void)
-{
-       READ_LOCALS(SQLValueFunction);
-
-       READ_ENUM_FIELD(op, SQLValueFunctionOp);
-       READ_OID_FIELD(type);
-       READ_INT_FIELD(typmod);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readXmlExpr
- */
-static XmlExpr *
-_readXmlExpr(void)
-{
-       READ_LOCALS(XmlExpr);
-
-       READ_ENUM_FIELD(op, XmlExprOp);
-       READ_STRING_FIELD(name);
-       READ_NODE_FIELD(named_args);
-       READ_NODE_FIELD(arg_names);
-       READ_NODE_FIELD(args);
-       READ_ENUM_FIELD(xmloption, XmlOptionType);
-       READ_OID_FIELD(type);
-       READ_INT_FIELD(typmod);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readNullTest
- */
-static NullTest *
-_readNullTest(void)
-{
-       READ_LOCALS(NullTest);
-
-       READ_NODE_FIELD(arg);
-       READ_ENUM_FIELD(nulltesttype, NullTestType);
-       READ_BOOL_FIELD(argisrow);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readBooleanTest
- */
-static BooleanTest *
-_readBooleanTest(void)
-{
-       READ_LOCALS(BooleanTest);
-
-       READ_NODE_FIELD(arg);
-       READ_ENUM_FIELD(booltesttype, BoolTestType);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCoerceToDomain
- */
-static CoerceToDomain *
-_readCoerceToDomain(void)
-{
-       READ_LOCALS(CoerceToDomain);
-
-       READ_NODE_FIELD(arg);
-       READ_OID_FIELD(resulttype);
-       READ_INT_FIELD(resulttypmod);
-       READ_OID_FIELD(resultcollid);
-       READ_ENUM_FIELD(coercionformat, CoercionForm);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCoerceToDomainValue
- */
-static CoerceToDomainValue *
-_readCoerceToDomainValue(void)
-{
-       READ_LOCALS(CoerceToDomainValue);
-
-       READ_OID_FIELD(typeId);
-       READ_INT_FIELD(typeMod);
-       READ_OID_FIELD(collation);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readSetToDefault
- */
-static SetToDefault *
-_readSetToDefault(void)
-{
-       READ_LOCALS(SetToDefault);
-
-       READ_OID_FIELD(typeId);
-       READ_INT_FIELD(typeMod);
-       READ_OID_FIELD(collation);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readCurrentOfExpr
- */
-static CurrentOfExpr *
-_readCurrentOfExpr(void)
-{
-       READ_LOCALS(CurrentOfExpr);
-
-       READ_UINT_FIELD(cvarno);
-       READ_STRING_FIELD(cursor_name);
-       READ_INT_FIELD(cursor_param);
-
-       READ_DONE();
-}
-
-/*
- * _readNextValueExpr
- */
-static NextValueExpr *
-_readNextValueExpr(void)
-{
-       READ_LOCALS(NextValueExpr);
-
-       READ_OID_FIELD(seqid);
-       READ_OID_FIELD(typeId);
-
-       READ_DONE();
-}
-
-/*
- * _readInferenceElem
- */
-static InferenceElem *
-_readInferenceElem(void)
-{
-       READ_LOCALS(InferenceElem);
-
-       READ_NODE_FIELD(expr);
-       READ_OID_FIELD(infercollid);
-       READ_OID_FIELD(inferopclass);
-
-       READ_DONE();
-}
-
-/*
- * _readTargetEntry
- */
-static TargetEntry *
-_readTargetEntry(void)
-{
-       READ_LOCALS(TargetEntry);
-
-       READ_NODE_FIELD(expr);
-       READ_INT_FIELD(resno);
-       READ_STRING_FIELD(resname);
-       READ_UINT_FIELD(ressortgroupref);
-       READ_OID_FIELD(resorigtbl);
-       READ_INT_FIELD(resorigcol);
-       READ_BOOL_FIELD(resjunk);
-
-       READ_DONE();
-}
-
-/*
- * _readRangeTblRef
- */
-static RangeTblRef *
-_readRangeTblRef(void)
-{
-       READ_LOCALS(RangeTblRef);
-
-       READ_INT_FIELD(rtindex);
-
-       READ_DONE();
-}
-
-/*
- * _readJoinExpr
- */
-static JoinExpr *
-_readJoinExpr(void)
-{
-       READ_LOCALS(JoinExpr);
-
-       READ_ENUM_FIELD(jointype, JoinType);
-       READ_BOOL_FIELD(isNatural);
-       READ_NODE_FIELD(larg);
-       READ_NODE_FIELD(rarg);
-       READ_NODE_FIELD(usingClause);
-       READ_NODE_FIELD(join_using_alias);
-       READ_NODE_FIELD(quals);
-       READ_NODE_FIELD(alias);
-       READ_INT_FIELD(rtindex);
-
-       READ_DONE();
-}
-
-/*
- * _readFromExpr
- */
-static FromExpr *
-_readFromExpr(void)
-{
-       READ_LOCALS(FromExpr);
-
-       READ_NODE_FIELD(fromlist);
-       READ_NODE_FIELD(quals);
-
-       READ_DONE();
-}
-
-/*
- * _readOnConflictExpr
- */
-static OnConflictExpr *
-_readOnConflictExpr(void)
-{
-       READ_LOCALS(OnConflictExpr);
-
-       READ_ENUM_FIELD(action, OnConflictAction);
-       READ_NODE_FIELD(arbiterElems);
-       READ_NODE_FIELD(arbiterWhere);
-       READ_OID_FIELD(constraint);
-       READ_NODE_FIELD(onConflictSet);
-       READ_NODE_FIELD(onConflictWhere);
-       READ_INT_FIELD(exclRelIndex);
-       READ_NODE_FIELD(exclRelTlist);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonFormat
- */
-static JsonFormat *
-_readJsonFormat(void)
-{
-       READ_LOCALS(JsonFormat);
-
-       READ_ENUM_FIELD(format_type, JsonFormatType);
-       READ_ENUM_FIELD(encoding, JsonEncoding);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonReturning
- */
-static JsonReturning *
-_readJsonReturning(void)
-{
-       READ_LOCALS(JsonReturning);
-
-       READ_NODE_FIELD(format);
-       READ_OID_FIELD(typid);
-       READ_INT_FIELD(typmod);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonValueExpr
- */
-static JsonValueExpr *
-_readJsonValueExpr(void)
-{
-       READ_LOCALS(JsonValueExpr);
-
-       READ_NODE_FIELD(raw_expr);
-       READ_NODE_FIELD(formatted_expr);
-       READ_NODE_FIELD(format);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonConstructorExpr
- */
-static JsonConstructorExpr *
-_readJsonConstructorExpr(void)
-{
-       READ_LOCALS(JsonConstructorExpr);
-
-       READ_ENUM_FIELD(type, JsonConstructorType);
-       READ_NODE_FIELD(args);
-       READ_NODE_FIELD(func);
-       READ_NODE_FIELD(coercion);
-       READ_NODE_FIELD(returning);
-       READ_BOOL_FIELD(absent_on_null);
-       READ_BOOL_FIELD(unique);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonBehavior
- */
-static JsonBehavior *
-_readJsonBehavior(void)
-{
-       READ_LOCALS(JsonBehavior);
-
-       READ_ENUM_FIELD(btype, JsonBehaviorType);
-       READ_NODE_FIELD(default_expr);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonExpr
- */
-static JsonExpr *
-_readJsonExpr(void)
-{
-       READ_LOCALS(JsonExpr);
-
-       READ_ENUM_FIELD(op, JsonExprOp);
-       READ_NODE_FIELD(formatted_expr);
-       READ_NODE_FIELD(result_coercion);
-       READ_NODE_FIELD(format);
-       READ_NODE_FIELD(path_spec);
-       READ_NODE_FIELD(passing_names);
-       READ_NODE_FIELD(passing_values);
-       READ_NODE_FIELD(returning);
-       READ_NODE_FIELD(on_empty);
-       READ_NODE_FIELD(on_error);
-       READ_NODE_FIELD(coercions);
-       READ_ENUM_FIELD(wrapper, JsonWrapper);
-       READ_BOOL_FIELD(omit_quotes);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-static JsonTableParent *
-_readJsonTableParent(void)
-{
-       READ_LOCALS(JsonTableParent);
-
-       READ_NODE_FIELD(path);
-       READ_STRING_FIELD(name);
-       READ_NODE_FIELD(child);
-       READ_BOOL_FIELD(outerJoin);
-       READ_INT_FIELD(colMin);
-       READ_INT_FIELD(colMax);
-       READ_BOOL_FIELD(errorOnError);
-
-       READ_DONE();
-}
-
-static JsonTableSibling *
-_readJsonTableSibling(void)
-{
-       READ_LOCALS(JsonTableSibling);
-
-       READ_NODE_FIELD(larg);
-       READ_NODE_FIELD(rarg);
-       READ_BOOL_FIELD(cross);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonCoercion
- */
-static JsonCoercion *
-_readJsonCoercion(void)
-{
-       READ_LOCALS(JsonCoercion);
-
-       READ_NODE_FIELD(expr);
-       READ_BOOL_FIELD(via_populate);
-       READ_BOOL_FIELD(via_io);
-       READ_OID_FIELD(collation);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonItemCoercions
- */
-static JsonItemCoercions *
-_readJsonItemCoercions(void)
-{
-       READ_LOCALS(JsonItemCoercions);
-
-       READ_NODE_FIELD(null);
-       READ_NODE_FIELD(string);
-       READ_NODE_FIELD(numeric);
-       READ_NODE_FIELD(boolean);
-       READ_NODE_FIELD(date);
-       READ_NODE_FIELD(time);
-       READ_NODE_FIELD(timetz);
-       READ_NODE_FIELD(timestamp);
-       READ_NODE_FIELD(timestamptz);
-       READ_NODE_FIELD(composite);
-
-       READ_DONE();
-}
-
-/*
- * _readJsonIsPredicate
- */
-static JsonIsPredicate *
-_readJsonIsPredicate()
-{
-       READ_LOCALS(JsonIsPredicate);
-
-       READ_NODE_FIELD(expr);
-       READ_NODE_FIELD(format);
-       READ_ENUM_FIELD(item_type, JsonValueType);
-       READ_BOOL_FIELD(unique_keys);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- *     Stuff from pathnodes.h.
- *
- * Mostly we don't need to read planner nodes back in again, but some
- * of these also end up in plan trees.
- */
-
-/*
- * _readAppendRelInfo
- */
-static AppendRelInfo *
-_readAppendRelInfo(void)
-{
-       READ_LOCALS(AppendRelInfo);
-
-       READ_UINT_FIELD(parent_relid);
-       READ_UINT_FIELD(child_relid);
-       READ_OID_FIELD(parent_reltype);
-       READ_OID_FIELD(child_reltype);
-       READ_NODE_FIELD(translated_vars);
-       READ_INT_FIELD(num_child_cols);
-       READ_ATTRNUMBER_ARRAY(parent_colnos, local_node->num_child_cols);
-       READ_OID_FIELD(parent_reloid);
-
-       READ_DONE();
-}
-
-/*
- *     Stuff from parsenodes.h.
- */
-#endif                                                 /* OBSOLETE */
-
-/*
- * _readRangeTblEntry
- */
-static RangeTblEntry *
-_readRangeTblEntry(void)
-{
-       READ_LOCALS(RangeTblEntry);
-
-       /* put alias + eref first to make dump more legible */
-       READ_NODE_FIELD(alias);
-       READ_NODE_FIELD(eref);
-       READ_ENUM_FIELD(rtekind, RTEKind);
-
-       switch (local_node->rtekind)
-       {
-               case RTE_RELATION:
-                       READ_OID_FIELD(relid);
-                       READ_CHAR_FIELD(relkind);
-                       READ_INT_FIELD(rellockmode);
-                       READ_NODE_FIELD(tablesample);
-                       break;
-               case RTE_SUBQUERY:
-                       READ_NODE_FIELD(subquery);
-                       READ_BOOL_FIELD(security_barrier);
-                       break;
-               case RTE_JOIN:
-                       READ_ENUM_FIELD(jointype, JoinType);
-                       READ_INT_FIELD(joinmergedcols);
-                       READ_NODE_FIELD(joinaliasvars);
-                       READ_NODE_FIELD(joinleftcols);
-                       READ_NODE_FIELD(joinrightcols);
-                       READ_NODE_FIELD(join_using_alias);
-                       break;
-               case RTE_FUNCTION:
-                       READ_NODE_FIELD(functions);
-                       READ_BOOL_FIELD(funcordinality);
-                       break;
-               case RTE_TABLEFUNC:
-                       READ_NODE_FIELD(tablefunc);
-                       /* The RTE must have a copy of the column type info, if any */
-                       if (local_node->tablefunc)
-                       {
-                               TableFunc  *tf = local_node->tablefunc;
-
-                               local_node->coltypes = tf->coltypes;
-                               local_node->coltypmods = tf->coltypmods;
-                               local_node->colcollations = tf->colcollations;
-                       }
-                       break;
-               case RTE_VALUES:
-                       READ_NODE_FIELD(values_lists);
-                       READ_NODE_FIELD(coltypes);
-                       READ_NODE_FIELD(coltypmods);
-                       READ_NODE_FIELD(colcollations);
-                       break;
-               case RTE_CTE:
-                       READ_STRING_FIELD(ctename);
-                       READ_UINT_FIELD(ctelevelsup);
-                       READ_BOOL_FIELD(self_reference);
-                       READ_NODE_FIELD(coltypes);
-                       READ_NODE_FIELD(coltypmods);
-                       READ_NODE_FIELD(colcollations);
-                       break;
-               case RTE_NAMEDTUPLESTORE:
-                       READ_STRING_FIELD(enrname);
-                       READ_FLOAT_FIELD(enrtuples);
-                       READ_OID_FIELD(relid);
-                       READ_NODE_FIELD(coltypes);
-                       READ_NODE_FIELD(coltypmods);
-                       READ_NODE_FIELD(colcollations);
-                       break;
-               case RTE_RESULT:
-                       /* no extra fields */
-                       break;
-               default:
-                       elog(ERROR, "unrecognized RTE kind: %d",
-                                (int) local_node->rtekind);
-                       break;
-       }
-
-       READ_BOOL_FIELD(lateral);
-       READ_BOOL_FIELD(inh);
-       READ_BOOL_FIELD(inFromCl);
-       READ_UINT_FIELD(requiredPerms);
-       READ_OID_FIELD(checkAsUser);
-       READ_BITMAPSET_FIELD(selectedCols);
-       READ_BITMAPSET_FIELD(insertedCols);
-       READ_BITMAPSET_FIELD(updatedCols);
-       READ_BITMAPSET_FIELD(extraUpdatedCols);
-       READ_NODE_FIELD(securityQuals);
-
-       READ_DONE();
-}
-
-#ifdef OBSOLETE
-/*
- * _readRangeTblFunction
- */
-static RangeTblFunction *
-_readRangeTblFunction(void)
-{
-       READ_LOCALS(RangeTblFunction);
-
-       READ_NODE_FIELD(funcexpr);
-       READ_INT_FIELD(funccolcount);
-       READ_NODE_FIELD(funccolnames);
-       READ_NODE_FIELD(funccoltypes);
-       READ_NODE_FIELD(funccoltypmods);
-       READ_NODE_FIELD(funccolcollations);
-       READ_BITMAPSET_FIELD(funcparams);
-
-       READ_DONE();
-}
-
-/*
- * _readTableSampleClause
- */
-static TableSampleClause *
-_readTableSampleClause(void)
-{
-       READ_LOCALS(TableSampleClause);
-
-       READ_OID_FIELD(tsmhandler);
-       READ_NODE_FIELD(args);
-       READ_NODE_FIELD(repeatable);
-
-       READ_DONE();
-}
-
-/*
- * _readDefElem
- */
-static DefElem *
-_readDefElem(void)
-{
-       READ_LOCALS(DefElem);
-
-       READ_STRING_FIELD(defnamespace);
-       READ_STRING_FIELD(defname);
-       READ_NODE_FIELD(arg);
-       READ_ENUM_FIELD(defaction, DefElemAction);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- *     Stuff from plannodes.h.
- */
-
-/*
- * _readPlannedStmt
- */
-static PlannedStmt *
-_readPlannedStmt(void)
-{
-       READ_LOCALS(PlannedStmt);
-
-       READ_ENUM_FIELD(commandType, CmdType);
-       READ_UINT64_FIELD(queryId);
-       READ_BOOL_FIELD(hasReturning);
-       READ_BOOL_FIELD(hasModifyingCTE);
-       READ_BOOL_FIELD(canSetTag);
-       READ_BOOL_FIELD(transientPlan);
-       READ_BOOL_FIELD(dependsOnRole);
-       READ_BOOL_FIELD(parallelModeNeeded);
-       READ_INT_FIELD(jitFlags);
-       READ_NODE_FIELD(planTree);
-       READ_NODE_FIELD(rtable);
-       READ_NODE_FIELD(resultRelations);
-       READ_NODE_FIELD(appendRelations);
-       READ_NODE_FIELD(subplans);
-       READ_BITMAPSET_FIELD(rewindPlanIDs);
-       READ_NODE_FIELD(rowMarks);
-       READ_NODE_FIELD(relationOids);
-       READ_NODE_FIELD(invalItems);
-       READ_NODE_FIELD(paramExecTypes);
-       READ_NODE_FIELD(utilityStmt);
-       READ_LOCATION_FIELD(stmt_location);
-       READ_INT_FIELD(stmt_len);
-
-       READ_DONE();
-}
-
-/*
- * ReadCommonPlan
- *     Assign the basic stuff of all nodes that inherit from Plan
- */
-static void
-ReadCommonPlan(Plan *local_node)
-{
-       READ_TEMP_LOCALS();
-
-       READ_FLOAT_FIELD(startup_cost);
-       READ_FLOAT_FIELD(total_cost);
-       READ_FLOAT_FIELD(plan_rows);
-       READ_INT_FIELD(plan_width);
-       READ_BOOL_FIELD(parallel_aware);
-       READ_BOOL_FIELD(parallel_safe);
-       READ_BOOL_FIELD(async_capable);
-       READ_INT_FIELD(plan_node_id);
-       READ_NODE_FIELD(targetlist);
-       READ_NODE_FIELD(qual);
-       READ_NODE_FIELD(lefttree);
-       READ_NODE_FIELD(righttree);
-       READ_NODE_FIELD(initPlan);
-       READ_BITMAPSET_FIELD(extParam);
-       READ_BITMAPSET_FIELD(allParam);
-}
-
-/*
- * _readResult
- */
-static Result *
-_readResult(void)
-{
-       READ_LOCALS(Result);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_NODE_FIELD(resconstantqual);
-
-       READ_DONE();
-}
-
-/*
- * _readProjectSet
- */
-static ProjectSet *
-_readProjectSet(void)
-{
-       READ_LOCALS_NO_FIELDS(ProjectSet);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_DONE();
-}
-
-/*
- * _readModifyTable
- */
-static ModifyTable *
-_readModifyTable(void)
-{
-       READ_LOCALS(ModifyTable);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_ENUM_FIELD(operation, CmdType);
-       READ_BOOL_FIELD(canSetTag);
-       READ_UINT_FIELD(nominalRelation);
-       READ_UINT_FIELD(rootRelation);
-       READ_BOOL_FIELD(partColsUpdated);
-       READ_NODE_FIELD(resultRelations);
-       READ_NODE_FIELD(updateColnosLists);
-       READ_NODE_FIELD(withCheckOptionLists);
-       READ_NODE_FIELD(returningLists);
-       READ_NODE_FIELD(fdwPrivLists);
-       READ_BITMAPSET_FIELD(fdwDirectModifyPlans);
-       READ_NODE_FIELD(rowMarks);
-       READ_INT_FIELD(epqParam);
-       READ_ENUM_FIELD(onConflictAction, OnConflictAction);
-       READ_NODE_FIELD(arbiterIndexes);
-       READ_NODE_FIELD(onConflictSet);
-       READ_NODE_FIELD(onConflictCols);
-       READ_NODE_FIELD(onConflictWhere);
-       READ_UINT_FIELD(exclRelRTI);
-       READ_NODE_FIELD(exclRelTlist);
-       READ_NODE_FIELD(mergeActionLists);
-
-       READ_DONE();
-}
-
-/*
- * _readAppend
- */
-static Append *
-_readAppend(void)
-{
-       READ_LOCALS(Append);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_BITMAPSET_FIELD(apprelids);
-       READ_NODE_FIELD(appendplans);
-       READ_INT_FIELD(nasyncplans);
-       READ_INT_FIELD(first_partial_plan);
-       READ_NODE_FIELD(part_prune_info);
-
-       READ_DONE();
-}
-
-/*
- * _readMergeAppend
- */
-static MergeAppend *
-_readMergeAppend(void)
-{
-       READ_LOCALS(MergeAppend);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_BITMAPSET_FIELD(apprelids);
-       READ_NODE_FIELD(mergeplans);
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(sortColIdx, local_node->numCols);
-       READ_OID_ARRAY(sortOperators, local_node->numCols);
-       READ_OID_ARRAY(collations, local_node->numCols);
-       READ_BOOL_ARRAY(nullsFirst, local_node->numCols);
-       READ_NODE_FIELD(part_prune_info);
-
-       READ_DONE();
-}
-
-/*
- * _readRecursiveUnion
- */
-static RecursiveUnion *
-_readRecursiveUnion(void)
-{
-       READ_LOCALS(RecursiveUnion);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_INT_FIELD(wtParam);
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(dupColIdx, local_node->numCols);
-       READ_OID_ARRAY(dupOperators, local_node->numCols);
-       READ_OID_ARRAY(dupCollations, local_node->numCols);
-       READ_LONG_FIELD(numGroups);
-
-       READ_DONE();
-}
-
-/*
- * _readBitmapAnd
- */
-static BitmapAnd *
-_readBitmapAnd(void)
-{
-       READ_LOCALS(BitmapAnd);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_NODE_FIELD(bitmapplans);
-
-       READ_DONE();
-}
-
-/*
- * _readBitmapOr
- */
-static BitmapOr *
-_readBitmapOr(void)
-{
-       READ_LOCALS(BitmapOr);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_BOOL_FIELD(isshared);
-       READ_NODE_FIELD(bitmapplans);
-
-       READ_DONE();
-}
-
-/*
- * ReadCommonScan
- *     Assign the basic stuff of all nodes that inherit from Scan
- */
-static void
-ReadCommonScan(Scan *local_node)
-{
-       READ_TEMP_LOCALS();
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_UINT_FIELD(scanrelid);
-}
-
-/*
- * _readScan
- */
-static Scan *
-_readScan(void)
-{
-       READ_LOCALS_NO_FIELDS(Scan);
-
-       ReadCommonScan(local_node);
-
-       READ_DONE();
-}
-
-/*
- * _readSeqScan
- */
-static SeqScan *
-_readSeqScan(void)
-{
-       READ_LOCALS_NO_FIELDS(SeqScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_DONE();
-}
-
-/*
- * _readSampleScan
- */
-static SampleScan *
-_readSampleScan(void)
-{
-       READ_LOCALS(SampleScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(tablesample);
-
-       READ_DONE();
-}
-
-/*
- * _readIndexScan
- */
-static IndexScan *
-_readIndexScan(void)
-{
-       READ_LOCALS(IndexScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_OID_FIELD(indexid);
-       READ_NODE_FIELD(indexqual);
-       READ_NODE_FIELD(indexqualorig);
-       READ_NODE_FIELD(indexorderby);
-       READ_NODE_FIELD(indexorderbyorig);
-       READ_NODE_FIELD(indexorderbyops);
-       READ_ENUM_FIELD(indexorderdir, ScanDirection);
-
-       READ_DONE();
-}
-
-/*
- * _readIndexOnlyScan
- */
-static IndexOnlyScan *
-_readIndexOnlyScan(void)
-{
-       READ_LOCALS(IndexOnlyScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_OID_FIELD(indexid);
-       READ_NODE_FIELD(indexqual);
-       READ_NODE_FIELD(recheckqual);
-       READ_NODE_FIELD(indexorderby);
-       READ_NODE_FIELD(indextlist);
-       READ_ENUM_FIELD(indexorderdir, ScanDirection);
-
-       READ_DONE();
-}
-
-/*
- * _readBitmapIndexScan
- */
-static BitmapIndexScan *
-_readBitmapIndexScan(void)
-{
-       READ_LOCALS(BitmapIndexScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_OID_FIELD(indexid);
-       READ_BOOL_FIELD(isshared);
-       READ_NODE_FIELD(indexqual);
-       READ_NODE_FIELD(indexqualorig);
-
-       READ_DONE();
-}
-
-/*
- * _readBitmapHeapScan
- */
-static BitmapHeapScan *
-_readBitmapHeapScan(void)
-{
-       READ_LOCALS(BitmapHeapScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(bitmapqualorig);
-
-       READ_DONE();
-}
-
-/*
- * _readTidScan
- */
-static TidScan *
-_readTidScan(void)
-{
-       READ_LOCALS(TidScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(tidquals);
-
-       READ_DONE();
-}
-
-/*
- * _readTidRangeScan
- */
-static TidRangeScan *
-_readTidRangeScan(void)
-{
-       READ_LOCALS(TidRangeScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(tidrangequals);
-
-       READ_DONE();
-}
-
-/*
- * _readSubqueryScan
- */
-static SubqueryScan *
-_readSubqueryScan(void)
-{
-       READ_LOCALS(SubqueryScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(subplan);
-       READ_ENUM_FIELD(scanstatus, SubqueryScanStatus);
-
-       READ_DONE();
-}
-
-/*
- * _readFunctionScan
- */
-static FunctionScan *
-_readFunctionScan(void)
-{
-       READ_LOCALS(FunctionScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(functions);
-       READ_BOOL_FIELD(funcordinality);
-
-       READ_DONE();
-}
-
-/*
- * _readValuesScan
- */
-static ValuesScan *
-_readValuesScan(void)
-{
-       READ_LOCALS(ValuesScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(values_lists);
-
-       READ_DONE();
-}
-
-/*
- * _readTableFuncScan
- */
-static TableFuncScan *
-_readTableFuncScan(void)
-{
-       READ_LOCALS(TableFuncScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_NODE_FIELD(tablefunc);
-
-       READ_DONE();
-}
-
-/*
- * _readCteScan
- */
-static CteScan *
-_readCteScan(void)
-{
-       READ_LOCALS(CteScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_INT_FIELD(ctePlanId);
-       READ_INT_FIELD(cteParam);
-
-       READ_DONE();
-}
-
-/*
- * _readNamedTuplestoreScan
- */
-static NamedTuplestoreScan *
-_readNamedTuplestoreScan(void)
-{
-       READ_LOCALS(NamedTuplestoreScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_STRING_FIELD(enrname);
-
-       READ_DONE();
-}
-
-/*
- * _readWorkTableScan
- */
-static WorkTableScan *
-_readWorkTableScan(void)
-{
-       READ_LOCALS(WorkTableScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_INT_FIELD(wtParam);
-
-       READ_DONE();
-}
-
-/*
- * _readForeignScan
- */
-static ForeignScan *
-_readForeignScan(void)
-{
-       READ_LOCALS(ForeignScan);
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_ENUM_FIELD(operation, CmdType);
-       READ_UINT_FIELD(resultRelation);
-       READ_OID_FIELD(fs_server);
-       READ_NODE_FIELD(fdw_exprs);
-       READ_NODE_FIELD(fdw_private);
-       READ_NODE_FIELD(fdw_scan_tlist);
-       READ_NODE_FIELD(fdw_recheck_quals);
-       READ_BITMAPSET_FIELD(fs_relids);
-       READ_BOOL_FIELD(fsSystemCol);
-
-       READ_DONE();
-}
-
-/*
- * _readCustomScan
- */
-static CustomScan *
-_readCustomScan(void)
-{
-       READ_LOCALS(CustomScan);
-       char       *custom_name;
-       const CustomScanMethods *methods;
-
-       ReadCommonScan(&local_node->scan);
-
-       READ_UINT_FIELD(flags);
-       READ_NODE_FIELD(custom_plans);
-       READ_NODE_FIELD(custom_exprs);
-       READ_NODE_FIELD(custom_private);
-       READ_NODE_FIELD(custom_scan_tlist);
-       READ_BITMAPSET_FIELD(custom_relids);
-
-       /* Lookup CustomScanMethods by CustomName */
-       token = pg_strtok(&length); /* skip methods: */
-       token = pg_strtok(&length); /* CustomName */
-       custom_name = nullable_string(token, length);
-       methods = GetCustomScanMethods(custom_name, false);
-       local_node->methods = methods;
-
-       READ_DONE();
-}
-
-/*
- * ReadCommonJoin
- *     Assign the basic stuff of all nodes that inherit from Join
- */
-static void
-ReadCommonJoin(Join *local_node)
-{
-       READ_TEMP_LOCALS();
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_ENUM_FIELD(jointype, JoinType);
-       READ_BOOL_FIELD(inner_unique);
-       READ_NODE_FIELD(joinqual);
-}
-
-/*
- * _readNestLoop
- */
-static NestLoop *
-_readNestLoop(void)
-{
-       READ_LOCALS(NestLoop);
-
-       ReadCommonJoin(&local_node->join);
-
-       READ_NODE_FIELD(nestParams);
-
-       READ_DONE();
-}
-
-/*
- * _readMergeJoin
- */
-static MergeJoin *
-_readMergeJoin(void)
-{
-       int                     numCols;
-
-       READ_LOCALS(MergeJoin);
-
-       ReadCommonJoin(&local_node->join);
-
-       READ_BOOL_FIELD(skip_mark_restore);
-       READ_NODE_FIELD(mergeclauses);
-
-       numCols = list_length(local_node->mergeclauses);
-
-       READ_OID_ARRAY(mergeFamilies, numCols);
-       READ_OID_ARRAY(mergeCollations, numCols);
-       READ_INT_ARRAY(mergeStrategies, numCols);
-       READ_BOOL_ARRAY(mergeNullsFirst, numCols);
-
-       READ_DONE();
-}
-
-/*
- * _readHashJoin
- */
-static HashJoin *
-_readHashJoin(void)
-{
-       READ_LOCALS(HashJoin);
-
-       ReadCommonJoin(&local_node->join);
-
-       READ_NODE_FIELD(hashclauses);
-       READ_NODE_FIELD(hashoperators);
-       READ_NODE_FIELD(hashcollations);
-       READ_NODE_FIELD(hashkeys);
-
-       READ_DONE();
-}
-
-/*
- * _readMaterial
- */
-static Material *
-_readMaterial(void)
-{
-       READ_LOCALS_NO_FIELDS(Material);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_DONE();
-}
-
-/*
- * _readMemoize
- */
-static Memoize *
-_readMemoize(void)
-{
-       READ_LOCALS(Memoize);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_INT_FIELD(numKeys);
-       READ_OID_ARRAY(hashOperators, local_node->numKeys);
-       READ_OID_ARRAY(collations, local_node->numKeys);
-       READ_NODE_FIELD(param_exprs);
-       READ_BOOL_FIELD(singlerow);
-       READ_BOOL_FIELD(binary_mode);
-       READ_UINT_FIELD(est_entries);
-       READ_BITMAPSET_FIELD(keyparamids);
-
-       READ_DONE();
-}
-
-/*
- * ReadCommonSort
- *     Assign the basic stuff of all nodes that inherit from Sort
- */
-static void
-ReadCommonSort(Sort *local_node)
-{
-       READ_TEMP_LOCALS();
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(sortColIdx, local_node->numCols);
-       READ_OID_ARRAY(sortOperators, local_node->numCols);
-       READ_OID_ARRAY(collations, local_node->numCols);
-       READ_BOOL_ARRAY(nullsFirst, local_node->numCols);
-}
-
-/*
- * _readSort
- */
-static Sort *
-_readSort(void)
-{
-       READ_LOCALS_NO_FIELDS(Sort);
-
-       ReadCommonSort(local_node);
-
-       READ_DONE();
-}
-
-/*
- * _readIncrementalSort
- */
-static IncrementalSort *
-_readIncrementalSort(void)
-{
-       READ_LOCALS(IncrementalSort);
-
-       ReadCommonSort(&local_node->sort);
-
-       READ_INT_FIELD(nPresortedCols);
-
-       READ_DONE();
-}
-
-/*
- * _readGroup
- */
-static Group *
-_readGroup(void)
-{
-       READ_LOCALS(Group);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(grpColIdx, local_node->numCols);
-       READ_OID_ARRAY(grpOperators, local_node->numCols);
-       READ_OID_ARRAY(grpCollations, local_node->numCols);
-
-       READ_DONE();
-}
-
-/*
- * _readAgg
- */
-static Agg *
-_readAgg(void)
-{
-       READ_LOCALS(Agg);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_ENUM_FIELD(aggstrategy, AggStrategy);
-       READ_ENUM_FIELD(aggsplit, AggSplit);
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(grpColIdx, local_node->numCols);
-       READ_OID_ARRAY(grpOperators, local_node->numCols);
-       READ_OID_ARRAY(grpCollations, local_node->numCols);
-       READ_LONG_FIELD(numGroups);
-       READ_UINT64_FIELD(transitionSpace);
-       READ_BITMAPSET_FIELD(aggParams);
-       READ_NODE_FIELD(groupingSets);
-       READ_NODE_FIELD(chain);
-
-       READ_DONE();
-}
-
-/*
- * _readWindowAgg
- */
-static WindowAgg *
-_readWindowAgg(void)
-{
-       READ_LOCALS(WindowAgg);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_UINT_FIELD(winref);
-       READ_INT_FIELD(partNumCols);
-       READ_ATTRNUMBER_ARRAY(partColIdx, local_node->partNumCols);
-       READ_OID_ARRAY(partOperators, local_node->partNumCols);
-       READ_OID_ARRAY(partCollations, local_node->partNumCols);
-       READ_INT_FIELD(ordNumCols);
-       READ_ATTRNUMBER_ARRAY(ordColIdx, local_node->ordNumCols);
-       READ_OID_ARRAY(ordOperators, local_node->ordNumCols);
-       READ_OID_ARRAY(ordCollations, local_node->ordNumCols);
-       READ_INT_FIELD(frameOptions);
-       READ_NODE_FIELD(startOffset);
-       READ_NODE_FIELD(endOffset);
-       READ_NODE_FIELD(runCondition);
-       READ_NODE_FIELD(runConditionOrig);
-       READ_OID_FIELD(startInRangeFunc);
-       READ_OID_FIELD(endInRangeFunc);
-       READ_OID_FIELD(inRangeColl);
-       READ_BOOL_FIELD(inRangeAsc);
-       READ_BOOL_FIELD(inRangeNullsFirst);
-       READ_BOOL_FIELD(topWindow);
-
-       READ_DONE();
-}
-
-/*
- * _readUnique
- */
-static Unique *
-_readUnique(void)
-{
-       READ_LOCALS(Unique);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(uniqColIdx, local_node->numCols);
-       READ_OID_ARRAY(uniqOperators, local_node->numCols);
-       READ_OID_ARRAY(uniqCollations, local_node->numCols);
-
-       READ_DONE();
-}
-
-/*
- * _readGather
- */
-static Gather *
-_readGather(void)
-{
-       READ_LOCALS(Gather);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_INT_FIELD(num_workers);
-       READ_INT_FIELD(rescan_param);
-       READ_BOOL_FIELD(single_copy);
-       READ_BOOL_FIELD(invisible);
-       READ_BITMAPSET_FIELD(initParam);
-
-       READ_DONE();
-}
-
-/*
- * _readGatherMerge
- */
-static GatherMerge *
-_readGatherMerge(void)
-{
-       READ_LOCALS(GatherMerge);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_INT_FIELD(num_workers);
-       READ_INT_FIELD(rescan_param);
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(sortColIdx, local_node->numCols);
-       READ_OID_ARRAY(sortOperators, local_node->numCols);
-       READ_OID_ARRAY(collations, local_node->numCols);
-       READ_BOOL_ARRAY(nullsFirst, local_node->numCols);
-       READ_BITMAPSET_FIELD(initParam);
-
-       READ_DONE();
-}
-
-/*
- * _readHash
- */
-static Hash *
-_readHash(void)
-{
-       READ_LOCALS(Hash);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_NODE_FIELD(hashkeys);
-       READ_OID_FIELD(skewTable);
-       READ_INT_FIELD(skewColumn);
-       READ_BOOL_FIELD(skewInherit);
-       READ_FLOAT_FIELD(rows_total);
-
-       READ_DONE();
-}
-
-/*
- * _readSetOp
- */
-static SetOp *
-_readSetOp(void)
-{
-       READ_LOCALS(SetOp);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_ENUM_FIELD(cmd, SetOpCmd);
-       READ_ENUM_FIELD(strategy, SetOpStrategy);
-       READ_INT_FIELD(numCols);
-       READ_ATTRNUMBER_ARRAY(dupColIdx, local_node->numCols);
-       READ_OID_ARRAY(dupOperators, local_node->numCols);
-       READ_OID_ARRAY(dupCollations, local_node->numCols);
-       READ_INT_FIELD(flagColIdx);
-       READ_INT_FIELD(firstFlag);
-       READ_LONG_FIELD(numGroups);
-
-       READ_DONE();
-}
-
-/*
- * _readLockRows
- */
-static LockRows *
-_readLockRows(void)
-{
-       READ_LOCALS(LockRows);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_NODE_FIELD(rowMarks);
-       READ_INT_FIELD(epqParam);
-
-       READ_DONE();
-}
-
-/*
- * _readLimit
- */
-static Limit *
-_readLimit(void)
-{
-       READ_LOCALS(Limit);
-
-       ReadCommonPlan(&local_node->plan);
-
-       READ_NODE_FIELD(limitOffset);
-       READ_NODE_FIELD(limitCount);
-       READ_ENUM_FIELD(limitOption, LimitOption);
-       READ_INT_FIELD(uniqNumCols);
-       READ_ATTRNUMBER_ARRAY(uniqColIdx, local_node->uniqNumCols);
-       READ_OID_ARRAY(uniqOperators, local_node->uniqNumCols);
-       READ_OID_ARRAY(uniqCollations, local_node->uniqNumCols);
-
-       READ_DONE();
-}
-
-/*
- * _readNestLoopParam
- */
-static NestLoopParam *
-_readNestLoopParam(void)
-{
-       READ_LOCALS(NestLoopParam);
-
-       READ_INT_FIELD(paramno);
-       READ_NODE_FIELD(paramval);
-
-       READ_DONE();
-}
-
-/*
- * _readPlanRowMark
- */
-static PlanRowMark *
-_readPlanRowMark(void)
-{
-       READ_LOCALS(PlanRowMark);
-
-       READ_UINT_FIELD(rti);
-       READ_UINT_FIELD(prti);
-       READ_UINT_FIELD(rowmarkId);
-       READ_ENUM_FIELD(markType, RowMarkType);
-       READ_INT_FIELD(allMarkTypes);
-       READ_ENUM_FIELD(strength, LockClauseStrength);
-       READ_ENUM_FIELD(waitPolicy, LockWaitPolicy);
-       READ_BOOL_FIELD(isParent);
-
-       READ_DONE();
-}
-
-static PartitionPruneInfo *
-_readPartitionPruneInfo(void)
-{
-       READ_LOCALS(PartitionPruneInfo);
-
-       READ_NODE_FIELD(prune_infos);
-       READ_BITMAPSET_FIELD(other_subplans);
-
-       READ_DONE();
-}
-
-static PartitionedRelPruneInfo *
-_readPartitionedRelPruneInfo(void)
-{
-       READ_LOCALS(PartitionedRelPruneInfo);
-
-       READ_UINT_FIELD(rtindex);
-       READ_BITMAPSET_FIELD(present_parts);
-       READ_INT_FIELD(nparts);
-       READ_INT_ARRAY(subplan_map, local_node->nparts);
-       READ_INT_ARRAY(subpart_map, local_node->nparts);
-       READ_OID_ARRAY(relid_map, local_node->nparts);
-       READ_NODE_FIELD(initial_pruning_steps);
-       READ_NODE_FIELD(exec_pruning_steps);
-       READ_BITMAPSET_FIELD(execparamids);
-
-       READ_DONE();
-}
-
-static PartitionPruneStepOp *
-_readPartitionPruneStepOp(void)
-{
-       READ_LOCALS(PartitionPruneStepOp);
-
-       READ_INT_FIELD(step.step_id);
-       READ_INT_FIELD(opstrategy);
-       READ_NODE_FIELD(exprs);
-       READ_NODE_FIELD(cmpfns);
-       READ_BITMAPSET_FIELD(nullkeys);
-
-       READ_DONE();
-}
-
-static PartitionPruneStepCombine *
-_readPartitionPruneStepCombine(void)
-{
-       READ_LOCALS(PartitionPruneStepCombine);
-
-       READ_INT_FIELD(step.step_id);
-       READ_ENUM_FIELD(combineOp, PartitionPruneCombineOp);
-       READ_NODE_FIELD(source_stepids);
-
-       READ_DONE();
-}
-
-/*
- * _readPlanInvalItem
- */
-static PlanInvalItem *
-_readPlanInvalItem(void)
-{
-       READ_LOCALS(PlanInvalItem);
-
-       READ_INT_FIELD(cacheId);
-       READ_UINT_FIELD(hashValue);
-
-       READ_DONE();
-}
-
-/*
- * _readSubPlan
- */
-static SubPlan *
-_readSubPlan(void)
-{
-       READ_LOCALS(SubPlan);
-
-       READ_ENUM_FIELD(subLinkType, SubLinkType);
-       READ_NODE_FIELD(testexpr);
-       READ_NODE_FIELD(paramIds);
-       READ_INT_FIELD(plan_id);
-       READ_STRING_FIELD(plan_name);
-       READ_OID_FIELD(firstColType);
-       READ_INT_FIELD(firstColTypmod);
-       READ_OID_FIELD(firstColCollation);
-       READ_BOOL_FIELD(useHashTable);
-       READ_BOOL_FIELD(unknownEqFalse);
-       READ_BOOL_FIELD(parallel_safe);
-       READ_NODE_FIELD(setParam);
-       READ_NODE_FIELD(parParam);
-       READ_NODE_FIELD(args);
-       READ_FLOAT_FIELD(startup_cost);
-       READ_FLOAT_FIELD(per_call_cost);
-
-       READ_DONE();
-}
-
-/*
- * _readAlternativeSubPlan
- */
-static AlternativeSubPlan *
-_readAlternativeSubPlan(void)
-{
-       READ_LOCALS(AlternativeSubPlan);
-
-       READ_NODE_FIELD(subplans);
-
-       READ_DONE();
-}
-#endif                                                 /* OBSOLETE */
-
-/*
- * _readExtensibleNode
- */
-static ExtensibleNode *
-_readExtensibleNode(void)
-{
-       const ExtensibleNodeMethods *methods;
-       ExtensibleNode *local_node;
-       const char *extnodename;
-
-       READ_TEMP_LOCALS();
-
-       token = pg_strtok(&length); /* skip :extnodename */
-       token = pg_strtok(&length); /* get extnodename */
-
-       extnodename = nullable_string(token, length);
-       if (!extnodename)
-               elog(ERROR, "extnodename has to be supplied");
-       methods = GetExtensibleNodeMethods(extnodename, false);
-
-       local_node = (ExtensibleNode *) newNode(methods->node_size,
-                                                                                       T_ExtensibleNode);
-       local_node->extnodename = extnodename;
-
-       /* deserialize the private fields */
-       methods->nodeRead(local_node);
-
-       READ_DONE();
-}
-
-#ifdef OBSOLETE
-/*
- * _readPartitionBoundSpec
- */
-static PartitionBoundSpec *
-_readPartitionBoundSpec(void)
-{
-       READ_LOCALS(PartitionBoundSpec);
-
-       READ_CHAR_FIELD(strategy);
-       READ_BOOL_FIELD(is_default);
-       READ_INT_FIELD(modulus);
-       READ_INT_FIELD(remainder);
-       READ_NODE_FIELD(listdatums);
-       READ_NODE_FIELD(lowerdatums);
-       READ_NODE_FIELD(upperdatums);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-
-/*
- * _readPartitionRangeDatum
- */
-static PartitionRangeDatum *
-_readPartitionRangeDatum(void)
-{
-       READ_LOCALS(PartitionRangeDatum);
-
-       READ_ENUM_FIELD(kind, PartitionRangeDatumKind);
-       READ_NODE_FIELD(value);
-       READ_LOCATION_FIELD(location);
-
-       READ_DONE();
-}
-#endif                                                 /* OBSOLETE */
 
 /*
  * parseNodeString
@@ -2948,278 +484,6 @@ parseNodeString(void)
        if (false)
                ;
 #include "readfuncs.switch.c"
-#ifdef OBSOLETE
-       else if (MATCH("QUERY", 5))
-               return_value = _readQuery();
-       else if (MATCH("WITHCHECKOPTION", 15))
-               return_value = _readWithCheckOption();
-       else if (MATCH("SORTGROUPCLAUSE", 15))
-               return_value = _readSortGroupClause();
-       else if (MATCH("GROUPINGSET", 11))
-               return_value = _readGroupingSet();
-       else if (MATCH("WINDOWCLAUSE", 12))
-               return_value = _readWindowClause();
-       else if (MATCH("ROWMARKCLAUSE", 13))
-               return_value = _readRowMarkClause();
-       else if (MATCH("CTESEARCHCLAUSE", 15))
-               return_value = _readCTESearchClause();
-       else if (MATCH("CTECYCLECLAUSE", 14))
-               return_value = _readCTECycleClause();
-       else if (MATCH("COMMONTABLEEXPR", 15))
-               return_value = _readCommonTableExpr();
-       else if (MATCH("MERGEWHENCLAUSE", 15))
-               return_value = _readMergeWhenClause();
-       else if (MATCH("MERGEACTION", 11))
-               return_value = _readMergeAction();
-       else if (MATCH("SETOPERATIONSTMT", 16))
-               return_value = _readSetOperationStmt();
-       else if (MATCH("ALIAS", 5))
-               return_value = _readAlias();
-       else if (MATCH("RANGEVAR", 8))
-               return_value = _readRangeVar();
-       else if (MATCH("INTOCLAUSE", 10))
-               return_value = _readIntoClause();
-       else if (MATCH("TABLEFUNC", 9))
-               return_value = _readTableFunc();
-       else if (MATCH("VAR", 3))
-               return_value = _readVar();
-       else if (MATCH("CONST", 5))
-               return_value = _readConst();
-       else if (MATCH("PARAM", 5))
-               return_value = _readParam();
-       else if (MATCH("AGGREF", 6))
-               return_value = _readAggref();
-       else if (MATCH("GROUPINGFUNC", 12))
-               return_value = _readGroupingFunc();
-       else if (MATCH("WINDOWFUNC", 10))
-               return_value = _readWindowFunc();
-       else if (MATCH("SUBSCRIPTINGREF", 15))
-               return_value = _readSubscriptingRef();
-       else if (MATCH("FUNCEXPR", 8))
-               return_value = _readFuncExpr();
-       else if (MATCH("NAMEDARGEXPR", 12))
-               return_value = _readNamedArgExpr();
-       else if (MATCH("OPEXPR", 6))
-               return_value = _readOpExpr();
-       else if (MATCH("DISTINCTEXPR", 12))
-               return_value = _readDistinctExpr();
-       else if (MATCH("NULLIFEXPR", 10))
-               return_value = _readNullIfExpr();
-       else if (MATCH("SCALARARRAYOPEXPR", 17))
-               return_value = _readScalarArrayOpExpr();
-       else if (MATCH("BOOLEXPR", 8))
-               return_value = _readBoolExpr();
-       else if (MATCH("SUBLINK", 7))
-               return_value = _readSubLink();
-       else if (MATCH("FIELDSELECT", 11))
-               return_value = _readFieldSelect();
-       else if (MATCH("FIELDSTORE", 10))
-               return_value = _readFieldStore();
-       else if (MATCH("RELABELTYPE", 11))
-               return_value = _readRelabelType();
-       else if (MATCH("COERCEVIAIO", 11))
-               return_value = _readCoerceViaIO();
-       else if (MATCH("ARRAYCOERCEEXPR", 15))
-               return_value = _readArrayCoerceExpr();
-       else if (MATCH("CONVERTROWTYPEEXPR", 18))
-               return_value = _readConvertRowtypeExpr();
-       else if (MATCH("COLLATEEXPR", 11))
-               return_value = _readCollateExpr();
-       else if (MATCH("CASEEXPR", 8))
-               return_value = _readCaseExpr();
-       else if (MATCH("CASEWHEN", 8))
-               return_value = _readCaseWhen();
-       else if (MATCH("CASETESTEXPR", 12))
-               return_value = _readCaseTestExpr();
-       else if (MATCH("ARRAYEXPR", 9))
-               return_value = _readArrayExpr();
-       else if (MATCH("ROWEXPR", 7))
-               return_value = _readRowExpr();
-       else if (MATCH("ROWCOMPAREEXPR", 14))
-               return_value = _readRowCompareExpr();
-       else if (MATCH("COALESCEEXPR", 12))
-               return_value = _readCoalesceExpr();
-       else if (MATCH("MINMAXEXPR", 10))
-               return_value = _readMinMaxExpr();
-       else if (MATCH("SQLVALUEFUNCTION", 16))
-               return_value = _readSQLValueFunction();
-       else if (MATCH("XMLEXPR", 7))
-               return_value = _readXmlExpr();
-       else if (MATCH("NULLTEST", 8))
-               return_value = _readNullTest();
-       else if (MATCH("BOOLEANTEST", 11))
-               return_value = _readBooleanTest();
-       else if (MATCH("COERCETODOMAIN", 14))
-               return_value = _readCoerceToDomain();
-       else if (MATCH("COERCETODOMAINVALUE", 19))
-               return_value = _readCoerceToDomainValue();
-       else if (MATCH("SETTODEFAULT", 12))
-               return_value = _readSetToDefault();
-       else if (MATCH("CURRENTOFEXPR", 13))
-               return_value = _readCurrentOfExpr();
-       else if (MATCH("NEXTVALUEEXPR", 13))
-               return_value = _readNextValueExpr();
-       else if (MATCH("INFERENCEELEM", 13))
-               return_value = _readInferenceElem();
-       else if (MATCH("TARGETENTRY", 11))
-               return_value = _readTargetEntry();
-       else if (MATCH("RANGETBLREF", 11))
-               return_value = _readRangeTblRef();
-       else if (MATCH("JOINEXPR", 8))
-               return_value = _readJoinExpr();
-       else if (MATCH("FROMEXPR", 8))
-               return_value = _readFromExpr();
-       else if (MATCH("ONCONFLICTEXPR", 14))
-               return_value = _readOnConflictExpr();
-       else if (MATCH("APPENDRELINFO", 13))
-               return_value = _readAppendRelInfo();
-       else if (MATCH("RANGETBLENTRY", 13))
-               return_value = _readRangeTblEntry();
-       else if (MATCH("RANGETBLFUNCTION", 16))
-               return_value = _readRangeTblFunction();
-       else if (MATCH("TABLESAMPLECLAUSE", 17))
-               return_value = _readTableSampleClause();
-       else if (MATCH("NOTIFYSTMT", 10))
-               return_value = _readNotifyStmt();
-       else if (MATCH("DEFELEM", 7))
-               return_value = _readDefElem();
-       else if (MATCH("DECLARECURSORSTMT", 17))
-               return_value = _readDeclareCursorStmt();
-       else if (MATCH("PLANNEDSTMT", 11))
-               return_value = _readPlannedStmt();
-       else if (MATCH("RESULT", 6))
-               return_value = _readResult();
-       else if (MATCH("PROJECTSET", 10))
-               return_value = _readProjectSet();
-       else if (MATCH("MODIFYTABLE", 11))
-               return_value = _readModifyTable();
-       else if (MATCH("APPEND", 6))
-               return_value = _readAppend();
-       else if (MATCH("MERGEAPPEND", 11))
-               return_value = _readMergeAppend();
-       else if (MATCH("RECURSIVEUNION", 14))
-               return_value = _readRecursiveUnion();
-       else if (MATCH("BITMAPAND", 9))
-               return_value = _readBitmapAnd();
-       else if (MATCH("BITMAPOR", 8))
-               return_value = _readBitmapOr();
-       else if (MATCH("SCAN", 4))
-               return_value = _readScan();
-       else if (MATCH("SEQSCAN", 7))
-               return_value = _readSeqScan();
-       else if (MATCH("SAMPLESCAN", 10))
-               return_value = _readSampleScan();
-       else if (MATCH("INDEXSCAN", 9))
-               return_value = _readIndexScan();
-       else if (MATCH("INDEXONLYSCAN", 13))
-               return_value = _readIndexOnlyScan();
-       else if (MATCH("BITMAPINDEXSCAN", 15))
-               return_value = _readBitmapIndexScan();
-       else if (MATCH("BITMAPHEAPSCAN", 14))
-               return_value = _readBitmapHeapScan();
-       else if (MATCH("TIDSCAN", 7))
-               return_value = _readTidScan();
-       else if (MATCH("TIDRANGESCAN", 12))
-               return_value = _readTidRangeScan();
-       else if (MATCH("SUBQUERYSCAN", 12))
-               return_value = _readSubqueryScan();
-       else if (MATCH("FUNCTIONSCAN", 12))
-               return_value = _readFunctionScan();
-       else if (MATCH("VALUESSCAN", 10))
-               return_value = _readValuesScan();
-       else if (MATCH("TABLEFUNCSCAN", 13))
-               return_value = _readTableFuncScan();
-       else if (MATCH("CTESCAN", 7))
-               return_value = _readCteScan();
-       else if (MATCH("NAMEDTUPLESTORESCAN", 19))
-               return_value = _readNamedTuplestoreScan();
-       else if (MATCH("WORKTABLESCAN", 13))
-               return_value = _readWorkTableScan();
-       else if (MATCH("FOREIGNSCAN", 11))
-               return_value = _readForeignScan();
-       else if (MATCH("CUSTOMSCAN", 10))
-               return_value = _readCustomScan();
-       else if (MATCH("NESTLOOP", 8))
-               return_value = _readNestLoop();
-       else if (MATCH("MERGEJOIN", 9))
-               return_value = _readMergeJoin();
-       else if (MATCH("HASHJOIN", 8))
-               return_value = _readHashJoin();
-       else if (MATCH("MATERIAL", 8))
-               return_value = _readMaterial();
-       else if (MATCH("MEMOIZE", 7))
-               return_value = _readMemoize();
-       else if (MATCH("SORT", 4))
-               return_value = _readSort();
-       else if (MATCH("INCREMENTALSORT", 15))
-               return_value = _readIncrementalSort();
-       else if (MATCH("GROUP", 5))
-               return_value = _readGroup();
-       else if (MATCH("AGG", 3))
-               return_value = _readAgg();
-       else if (MATCH("WINDOWAGG", 9))
-               return_value = _readWindowAgg();
-       else if (MATCH("UNIQUE", 6))
-               return_value = _readUnique();
-       else if (MATCH("GATHER", 6))
-               return_value = _readGather();
-       else if (MATCH("GATHERMERGE", 11))
-               return_value = _readGatherMerge();
-       else if (MATCH("HASH", 4))
-               return_value = _readHash();
-       else if (MATCH("SETOP", 5))
-               return_value = _readSetOp();
-       else if (MATCH("LOCKROWS", 8))
-               return_value = _readLockRows();
-       else if (MATCH("LIMIT", 5))
-               return_value = _readLimit();
-       else if (MATCH("NESTLOOPPARAM", 13))
-               return_value = _readNestLoopParam();
-       else if (MATCH("PLANROWMARK", 11))
-               return_value = _readPlanRowMark();
-       else if (MATCH("PARTITIONPRUNEINFO", 18))
-               return_value = _readPartitionPruneInfo();
-       else if (MATCH("PARTITIONEDRELPRUNEINFO", 23))
-               return_value = _readPartitionedRelPruneInfo();
-       else if (MATCH("PARTITIONPRUNESTEPOP", 20))
-               return_value = _readPartitionPruneStepOp();
-       else if (MATCH("PARTITIONPRUNESTEPCOMBINE", 25))
-               return_value = _readPartitionPruneStepCombine();
-       else if (MATCH("PLANINVALITEM", 13))
-               return_value = _readPlanInvalItem();
-       else if (MATCH("SUBPLAN", 7))
-               return_value = _readSubPlan();
-       else if (MATCH("ALTERNATIVESUBPLAN", 18))
-               return_value = _readAlternativeSubPlan();
-       else if (MATCH("EXTENSIBLENODE", 14))
-               return_value = _readExtensibleNode();
-       else if (MATCH("PARTITIONBOUNDSPEC", 18))
-               return_value = _readPartitionBoundSpec();
-       else if (MATCH("PARTITIONRANGEDATUM", 19))
-               return_value = _readPartitionRangeDatum();
-       else if (MATCH("JSONFORMAT", 10))
-               return_value = _readJsonFormat();
-       else if (MATCH("JSONRETURNING", 13))
-               return_value = _readJsonReturning();
-       else if (MATCH("JSONVALUEEXPR", 13))
-               return_value = _readJsonValueExpr();
-       else if (MATCH("JSONCONSTRUCTOREXPR", 19))
-               return_value = _readJsonConstructorExpr();
-       else if (MATCH("JSONISPREDICATE", 15))
-               return_value = _readJsonIsPredicate();
-       else if (MATCH("JSONBEHAVIOR", 12))
-               return_value = _readJsonBehavior();
-       else if (MATCH("JSONEXPR", 8))
-               return_value = _readJsonExpr();
-       else if (MATCH("JSONCOERCION", 12))
-               return_value = _readJsonCoercion();
-       else if (MATCH("JSONITEMCOERCIONS", 17))
-               return_value = _readJsonItemCoercions();
-       else if (MATCH("JSONTABLEPARENT", 15))
-               return_value = _readJsonTableParent();
-       else if (MATCH("JSONTABLESIBLING", 16))
-               return_value = _readJsonTableSibling();
-#endif                                                 /* OBSOLETE */
        else
        {
                elog(ERROR, "badly formatted node string \"%.32s\"...", token);
index 9999336eb45b4d0bb2cccdf5db9ba16cd994d5a7..adc549002a692d60ed7143cf3483a82ed227a3a1 100644 (file)
@@ -28,537 +28,6 @@ typedef enum NodeTag
        T_Invalid = 0,
 
 #include "nodes/nodetags.h"
-#ifdef OBSOLETE
-
-       /*
-        * TAGS FOR EXECUTOR NODES (execnodes.h)
-        */
-       T_IndexInfo,
-       T_ExprContext,
-       T_ProjectionInfo,
-       T_JunkFilter,
-       T_OnConflictSetState,
-       T_MergeActionState,
-       T_ResultRelInfo,
-       T_EState,
-       T_TupleTableSlot,
-
-       /*
-        * TAGS FOR PLAN NODES (plannodes.h)
-        */
-       T_Result,
-       T_ProjectSet,
-       T_ModifyTable,
-       T_Append,
-       T_MergeAppend,
-       T_RecursiveUnion,
-       T_BitmapAnd,
-       T_BitmapOr,
-       T_Scan,
-       T_SeqScan,
-       T_SampleScan,
-       T_IndexScan,
-       T_IndexOnlyScan,
-       T_BitmapIndexScan,
-       T_BitmapHeapScan,
-       T_TidScan,
-       T_TidRangeScan,
-       T_SubqueryScan,
-       T_FunctionScan,
-       T_ValuesScan,
-       T_TableFuncScan,
-       T_CteScan,
-       T_NamedTuplestoreScan,
-       T_WorkTableScan,
-       T_ForeignScan,
-       T_CustomScan,
-       T_NestLoop,
-       T_MergeJoin,
-       T_HashJoin,
-       T_Material,
-       T_Memoize,
-       T_Sort,
-       T_IncrementalSort,
-       T_Group,
-       T_Agg,
-       T_WindowAgg,
-       T_Unique,
-       T_Gather,
-       T_GatherMerge,
-       T_Hash,
-       T_SetOp,
-       T_LockRows,
-       T_Limit,
-       /* these aren't subclasses of Plan: */
-       T_NestLoopParam,
-       T_PlanRowMark,
-       T_PartitionPruneInfo,
-       T_PartitionedRelPruneInfo,
-       T_PartitionPruneStepOp,
-       T_PartitionPruneStepCombine,
-       T_PlanInvalItem,
-
-       /*
-        * TAGS FOR PLAN STATE NODES (execnodes.h)
-        *
-        * These should correspond one-to-one with Plan node types.
-        */
-       T_PlanState,
-       T_ResultState,
-       T_ProjectSetState,
-       T_ModifyTableState,
-       T_AppendState,
-       T_MergeAppendState,
-       T_RecursiveUnionState,
-       T_BitmapAndState,
-       T_BitmapOrState,
-       T_ScanState,
-       T_SeqScanState,
-       T_SampleScanState,
-       T_IndexScanState,
-       T_IndexOnlyScanState,
-       T_BitmapIndexScanState,
-       T_BitmapHeapScanState,
-       T_TidScanState,
-       T_TidRangeScanState,
-       T_SubqueryScanState,
-       T_FunctionScanState,
-       T_TableFuncScanState,
-       T_ValuesScanState,
-       T_CteScanState,
-       T_NamedTuplestoreScanState,
-       T_WorkTableScanState,
-       T_ForeignScanState,
-       T_CustomScanState,
-       T_JoinState,
-       T_NestLoopState,
-       T_MergeJoinState,
-       T_HashJoinState,
-       T_MaterialState,
-       T_MemoizeState,
-       T_SortState,
-       T_IncrementalSortState,
-       T_GroupState,
-       T_AggState,
-       T_WindowAggState,
-       T_UniqueState,
-       T_GatherState,
-       T_GatherMergeState,
-       T_HashState,
-       T_SetOpState,
-       T_LockRowsState,
-       T_LimitState,
-
-       /*
-        * TAGS FOR PRIMITIVE NODES (primnodes.h)
-        */
-       T_Alias,
-       T_RangeVar,
-       T_TableFunc,
-       T_Var,
-       T_Const,
-       T_Param,
-       T_Aggref,
-       T_GroupingFunc,
-       T_WindowFunc,
-       T_SubscriptingRef,
-       T_FuncExpr,
-       T_NamedArgExpr,
-       T_OpExpr,
-       T_DistinctExpr,
-       T_NullIfExpr,
-       T_ScalarArrayOpExpr,
-       T_BoolExpr,
-       T_SubLink,
-       T_SubPlan,
-       T_AlternativeSubPlan,
-       T_FieldSelect,
-       T_FieldStore,
-       T_RelabelType,
-       T_CoerceViaIO,
-       T_ArrayCoerceExpr,
-       T_ConvertRowtypeExpr,
-       T_CollateExpr,
-       T_CaseExpr,
-       T_CaseWhen,
-       T_CaseTestExpr,
-       T_ArrayExpr,
-       T_RowExpr,
-       T_RowCompareExpr,
-       T_CoalesceExpr,
-       T_MinMaxExpr,
-       T_SQLValueFunction,
-       T_XmlExpr,
-       T_NullTest,
-       T_BooleanTest,
-       T_CoerceToDomain,
-       T_CoerceToDomainValue,
-       T_SetToDefault,
-       T_CurrentOfExpr,
-       T_NextValueExpr,
-       T_InferenceElem,
-       T_TargetEntry,
-       T_RangeTblRef,
-       T_JoinExpr,
-       T_FromExpr,
-       T_OnConflictExpr,
-       T_IntoClause,
-       T_JsonFormat,
-       T_JsonReturning,
-       T_JsonValueExpr,
-       T_JsonParseExpr,
-       T_JsonScalarExpr,
-       T_JsonSerializeExpr,
-       T_JsonConstructorExpr,
-       T_JsonExpr,
-       T_JsonCoercion,
-       T_JsonItemCoercions,
-       T_JsonTableParent,
-       T_JsonTableSibling,
-
-       /*
-        * TAGS FOR EXPRESSION STATE NODES (execnodes.h)
-        */
-       T_ExprState,
-       T_WindowFuncExprState,
-       T_SetExprState,
-       T_SubPlanState,
-       T_DomainConstraintState,
-
-       /*
-        * TAGS FOR PLANNER NODES (pathnodes.h)
-        */
-       T_PlannerInfo,
-       T_PlannerGlobal,
-       T_RelOptInfo,
-       T_IndexOptInfo,
-       T_ForeignKeyOptInfo,
-       T_ParamPathInfo,
-       T_Path,
-       T_IndexPath,
-       T_BitmapHeapPath,
-       T_BitmapAndPath,
-       T_BitmapOrPath,
-       T_TidPath,
-       T_TidRangePath,
-       T_SubqueryScanPath,
-       T_ForeignPath,
-       T_CustomPath,
-       T_NestPath,
-       T_MergePath,
-       T_HashPath,
-       T_AppendPath,
-       T_MergeAppendPath,
-       T_GroupResultPath,
-       T_MaterialPath,
-       T_MemoizePath,
-       T_UniquePath,
-       T_GatherPath,
-       T_GatherMergePath,
-       T_ProjectionPath,
-       T_ProjectSetPath,
-       T_SortPath,
-       T_IncrementalSortPath,
-       T_GroupPath,
-       T_UpperUniquePath,
-       T_AggPath,
-       T_GroupingSetsPath,
-       T_MinMaxAggPath,
-       T_WindowAggPath,
-       T_SetOpPath,
-       T_RecursiveUnionPath,
-       T_LockRowsPath,
-       T_ModifyTablePath,
-       T_LimitPath,
-       /* these aren't subclasses of Path: */
-       T_EquivalenceClass,
-       T_EquivalenceMember,
-       T_PathKey,
-       T_PathKeyInfo,
-       T_PathTarget,
-       T_RestrictInfo,
-       T_IndexClause,
-       T_PlaceHolderVar,
-       T_SpecialJoinInfo,
-       T_AppendRelInfo,
-       T_RowIdentityVarInfo,
-       T_PlaceHolderInfo,
-       T_MinMaxAggInfo,
-       T_PlannerParamItem,
-       T_RollupData,
-       T_GroupingSetData,
-       T_StatisticExtInfo,
-       T_MergeAction,
-
-       /*
-        * TAGS FOR MEMORY NODES (memnodes.h)
-        */
-       T_AllocSetContext,
-       T_SlabContext,
-       T_GenerationContext,
-
-       /*
-        * TAGS FOR VALUE NODES (value.h)
-        */
-       T_Integer,
-       T_Float,
-       T_Boolean,
-       T_String,
-       T_BitString,
-
-       /*
-        * TAGS FOR LIST NODES (pg_list.h)
-        */
-       T_List,
-       T_IntList,
-       T_OidList,
-       T_XidList,
-
-       /*
-        * TAGS FOR EXTENSIBLE NODES (extensible.h)
-        */
-       T_ExtensibleNode,
-
-       /*
-        * TAGS FOR STATEMENT NODES (mostly in parsenodes.h)
-        */
-       T_RawStmt,
-       T_Query,
-       T_PlannedStmt,
-       T_InsertStmt,
-       T_DeleteStmt,
-       T_UpdateStmt,
-       T_MergeStmt,
-       T_SelectStmt,
-       T_ReturnStmt,
-       T_PLAssignStmt,
-       T_AlterTableStmt,
-       T_AlterTableCmd,
-       T_AlterDomainStmt,
-       T_SetOperationStmt,
-       T_GrantStmt,
-       T_GrantRoleStmt,
-       T_AlterDefaultPrivilegesStmt,
-       T_ClosePortalStmt,
-       T_ClusterStmt,
-       T_CopyStmt,
-       T_CreateStmt,
-       T_DefineStmt,
-       T_DropStmt,
-       T_TruncateStmt,
-       T_CommentStmt,
-       T_FetchStmt,
-       T_IndexStmt,
-       T_CreateFunctionStmt,
-       T_AlterFunctionStmt,
-       T_DoStmt,
-       T_RenameStmt,
-       T_RuleStmt,
-       T_NotifyStmt,
-       T_ListenStmt,
-       T_UnlistenStmt,
-       T_TransactionStmt,
-       T_ViewStmt,
-       T_LoadStmt,
-       T_CreateDomainStmt,
-       T_CreatedbStmt,
-       T_DropdbStmt,
-       T_VacuumStmt,
-       T_ExplainStmt,
-       T_CreateTableAsStmt,
-       T_CreateSeqStmt,
-       T_AlterSeqStmt,
-       T_VariableSetStmt,
-       T_VariableShowStmt,
-       T_DiscardStmt,
-       T_CreateTrigStmt,
-       T_CreatePLangStmt,
-       T_CreateRoleStmt,
-       T_AlterRoleStmt,
-       T_DropRoleStmt,
-       T_LockStmt,
-       T_ConstraintsSetStmt,
-       T_ReindexStmt,
-       T_CheckPointStmt,
-       T_CreateSchemaStmt,
-       T_AlterDatabaseStmt,
-       T_AlterDatabaseRefreshCollStmt,
-       T_AlterDatabaseSetStmt,
-       T_AlterRoleSetStmt,
-       T_CreateConversionStmt,
-       T_CreateCastStmt,
-       T_CreateOpClassStmt,
-       T_CreateOpFamilyStmt,
-       T_AlterOpFamilyStmt,
-       T_PrepareStmt,
-       T_ExecuteStmt,
-       T_DeallocateStmt,
-       T_DeclareCursorStmt,
-       T_CreateTableSpaceStmt,
-       T_DropTableSpaceStmt,
-       T_AlterObjectDependsStmt,
-       T_AlterObjectSchemaStmt,
-       T_AlterOwnerStmt,
-       T_AlterOperatorStmt,
-       T_AlterTypeStmt,
-       T_DropOwnedStmt,
-       T_ReassignOwnedStmt,
-       T_CompositeTypeStmt,
-       T_CreateEnumStmt,
-       T_CreateRangeStmt,
-       T_AlterEnumStmt,
-       T_AlterTSDictionaryStmt,
-       T_AlterTSConfigurationStmt,
-       T_CreateFdwStmt,
-       T_AlterFdwStmt,
-       T_CreateForeignServerStmt,
-       T_AlterForeignServerStmt,
-       T_CreateUserMappingStmt,
-       T_AlterUserMappingStmt,
-       T_DropUserMappingStmt,
-       T_AlterTableSpaceOptionsStmt,
-       T_AlterTableMoveAllStmt,
-       T_SecLabelStmt,
-       T_CreateForeignTableStmt,
-       T_ImportForeignSchemaStmt,
-       T_CreateExtensionStmt,
-       T_AlterExtensionStmt,
-       T_AlterExtensionContentsStmt,
-       T_CreateEventTrigStmt,
-       T_AlterEventTrigStmt,
-       T_RefreshMatViewStmt,
-       T_ReplicaIdentityStmt,
-       T_AlterSystemStmt,
-       T_CreatePolicyStmt,
-       T_AlterPolicyStmt,
-       T_CreateTransformStmt,
-       T_CreateAmStmt,
-       T_CreatePublicationStmt,
-       T_AlterPublicationStmt,
-       T_CreateSubscriptionStmt,
-       T_AlterSubscriptionStmt,
-       T_DropSubscriptionStmt,
-       T_CreateStatsStmt,
-       T_AlterCollationStmt,
-       T_CallStmt,
-       T_AlterStatsStmt,
-
-       /*
-        * TAGS FOR PARSE TREE NODES (parsenodes.h)
-        */
-       T_A_Expr,
-       T_ColumnRef,
-       T_ParamRef,
-       T_A_Const,
-       T_FuncCall,
-       T_A_Star,
-       T_A_Indices,
-       T_A_Indirection,
-       T_A_ArrayExpr,
-       T_ResTarget,
-       T_MultiAssignRef,
-       T_TypeCast,
-       T_CollateClause,
-       T_SortBy,
-       T_WindowDef,
-       T_RangeSubselect,
-       T_RangeFunction,
-       T_RangeTableSample,
-       T_RangeTableFunc,
-       T_RangeTableFuncCol,
-       T_TypeName,
-       T_ColumnDef,
-       T_IndexElem,
-       T_StatsElem,
-       T_Constraint,
-       T_DefElem,
-       T_RangeTblEntry,
-       T_RangeTblFunction,
-       T_TableSampleClause,
-       T_WithCheckOption,
-       T_SortGroupClause,
-       T_GroupingSet,
-       T_WindowClause,
-       T_ObjectWithArgs,
-       T_AccessPriv,
-       T_CreateOpClassItem,
-       T_TableLikeClause,
-       T_FunctionParameter,
-       T_LockingClause,
-       T_RowMarkClause,
-       T_XmlSerialize,
-       T_WithClause,
-       T_InferClause,
-       T_OnConflictClause,
-       T_CTESearchClause,
-       T_CTECycleClause,
-       T_CommonTableExpr,
-       T_MergeWhenClause,
-       T_RoleSpec,
-       T_TriggerTransition,
-       T_PartitionElem,
-       T_PartitionSpec,
-       T_PartitionBoundSpec,
-       T_PartitionRangeDatum,
-       T_PartitionCmd,
-       T_VacuumRelation,
-       T_PublicationObjSpec,
-       T_PublicationTable,
-       T_JsonObjectConstructor,
-       T_JsonArrayConstructor,
-       T_JsonArrayQueryConstructor,
-       T_JsonAggConstructor,
-       T_JsonObjectAgg,
-       T_JsonArrayAgg,
-       T_JsonFuncExpr,
-       T_JsonIsPredicate,
-       T_JsonTable,
-       T_JsonTableColumn,
-       T_JsonTablePlan,
-       T_JsonCommon,
-       T_JsonArgument,
-       T_JsonKeyValue,
-       T_JsonBehavior,
-       T_JsonOutput,
-
-       /*
-        * TAGS FOR REPLICATION GRAMMAR PARSE NODES (replnodes.h)
-        */
-       T_IdentifySystemCmd,
-       T_BaseBackupCmd,
-       T_CreateReplicationSlotCmd,
-       T_DropReplicationSlotCmd,
-       T_ReadReplicationSlotCmd,
-       T_StartReplicationCmd,
-       T_TimeLineHistoryCmd,
-
-       /*
-        * TAGS FOR RANDOM OTHER STUFF
-        *
-        * These are objects that aren't part of parse/plan/execute node tree
-        * structures, but we give them NodeTags anyway for identification
-        * purposes (usually because they are involved in APIs where we want to
-        * pass multiple object types through the same pointer).
-        */
-       T_TriggerData,                          /* in commands/trigger.h */
-       T_EventTriggerData,                     /* in commands/event_trigger.h */
-       T_ReturnSetInfo,                        /* in nodes/execnodes.h */
-       T_WindowObjectData,                     /* private in nodeWindowAgg.c */
-       T_TIDBitmap,                            /* in nodes/tidbitmap.h */
-       T_InlineCodeBlock,                      /* in nodes/parsenodes.h */
-       T_FdwRoutine,                           /* in foreign/fdwapi.h */
-       T_IndexAmRoutine,                       /* in access/amapi.h */
-       T_TableAmRoutine,                       /* in access/tableam.h */
-       T_TsmRoutine,                           /* in access/tsmapi.h */
-       T_ForeignKeyCacheInfo,          /* in utils/rel.h */
-       T_CallContext,                          /* in nodes/parsenodes.h */
-       T_SupportRequestSimplify,       /* in nodes/supportnodes.h */
-       T_SupportRequestSelectivity,    /* in nodes/supportnodes.h */
-       T_SupportRequestCost,           /* in nodes/supportnodes.h */
-       T_SupportRequestRows,           /* in nodes/supportnodes.h */
-       T_SupportRequestIndexCondition, /* in nodes/supportnodes.h */
-       T_SupportRequestWFuncMonotonic  /* in nodes/supportnodes.h */
-#endif                                                 /* OBSOLETE */
 } NodeTag;
 
 /*