Commit c1bc907f authored by Marc G. Fournier's avatar Marc G. Fournier

parent 66d64b72
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: outfuncs.c,v 1.52 1998/12/14 08:11:09 scrappy Exp $ * $Id: outfuncs.c,v 1.53 1998/12/15 02:24:15 scrappy Exp $
* *
* NOTES * NOTES
* Every (plan) node in POSTGRES has an associated "out" routine which * Every (plan) node in POSTGRES has an associated "out" routine which
...@@ -129,19 +129,13 @@ _outColumnDef(StringInfo str, ColumnDef *node) ...@@ -129,19 +129,13 @@ _outColumnDef(StringInfo str, ColumnDef *node)
static void static void
_outTypeName(StringInfo str, TypeName *node) _outTypeName(StringInfo str, TypeName *node)
{ {
char buf[500]; appendStringInfo(str,
" TYPENAME :name %s :timezone %s :setof %s typmod %d :arrayBounds ",
appendStringInfo(str, " TYPENAME "); node->name,
node->timezone ? "true" : "false,
node->setof ? "true" : "false",
node->typemod);
appendStringInfo(str, " :name ");
appendStringInfo(str, node->name);
appendStringInfo(str, " :timezone ");
appendStringInfo(str, (node->timezone ? "true" : "false"));
appendStringInfo(str, " :setof ");
appendStringInfo(str, (node->setof ? "true" : "false"));
appendStringInfo(str, " :typmod ");
snprintf(buf, 500, " %d ", node->typmod);
appendStringInfo(str, buf);
appendStringInfo(str, " :arrayBounds "); appendStringInfo(str, " :arrayBounds ");
_outNode(str, node->arrayBounds); _outNode(str, node->arrayBounds);
} }
...@@ -149,50 +143,38 @@ _outTypeName(StringInfo str, TypeName *node) ...@@ -149,50 +143,38 @@ _outTypeName(StringInfo str, TypeName *node)
static void static void
_outIndexElem(StringInfo str, IndexElem *node) _outIndexElem(StringInfo str, IndexElem *node)
{ {
appendStringInfo(str, " INDEXELEM "); appendStringInfo(str, " INDEXELEM :name %s :args ", node->name);
appendStringInfo(str, " :name ");
appendStringInfo(str, node->name);
appendStringInfo(str, " :args ");
_outNode(str, node->args); _outNode(str, node->args);
appendStringInfo(str, " :class ");
appendStringInfo(str, node->class); appendStringInfo(str, " :class %s :typename ", node->class);
appendStringInfo(str, " :typename ");
_outNode(str, node->typename); _outNode(str, node->typename);
} }
static void static void
_outQuery(StringInfo str, Query *node) _outQuery(StringInfo str, Query *node)
{ {
char buf[500]; appendStringInfo(str, " QUERY :command %d ", node->commandType);
appendStringInfo(str, " QUERY ");
appendStringInfo(str, " :command ");
snprintf(buf, 500, " %d ", node->commandType);
appendStringInfo(str, buf);
if (node->utilityStmt) if (node->utilityStmt)
{ {
switch (nodeTag(node->utilityStmt)) switch (nodeTag(node->utilityStmt))
{ {
case T_CreateStmt: case T_CreateStmt:
appendStringInfo(str, " :create "); appendStringInfo(str, " :create %s ",
appendStringInfo(str, ((CreateStmt *) (node->utilityStmt))->relname); ((CreateStmt *) (node->utilityStmt))->relname);
_outNode(str, node->utilityStmt); _outNode(str, node->utilityStmt);
break; break;
case T_IndexStmt: case T_IndexStmt:
appendStringInfo(str, " :index "); appendStringInfo(str, " :index %s on %s ",
appendStringInfo(str, ((IndexStmt *) (node->utilityStmt))->idxname); ((IndexStmt *) (node->utilityStmt))->idxname,
appendStringInfo(str, " on "); ((IndexStmt *) (node->utilityStmt))->relname);
appendStringInfo(str, ((IndexStmt *) (node->utilityStmt))->relname);
_outNode(str, node->utilityStmt); _outNode(str, node->utilityStmt);
break; break;
case T_NotifyStmt: case T_NotifyStmt:
appendStringInfo(str, " :utility "); appendStringInfo(str, " :utility %s ",
appendStringInfo(str, ((NotifyStmt *) (node->utilityStmt))->relname); ((NotifyStmt *) (node->utilityStmt))->relname);
break; break;
default: default:
...@@ -201,43 +183,43 @@ _outQuery(StringInfo str, Query *node) ...@@ -201,43 +183,43 @@ _outQuery(StringInfo str, Query *node)
} }
else else
{ {
appendStringInfo(str, " :utility "); appendStringInfo(str, " :utility %s", NULL);
appendStringInfo(str, NULL);
} }
appendStringInfo(str, " :resultRelation "); appendStringInfo(str,
snprintf(buf, 500, " %d ", node->resultRelation); " :resultRelation %d :into %s :isPortal %s :isBinary %s :unionall %s ",
appendStringInfo(str, buf); node->resultRelation,
appendStringInfo(str, " :into "); node->into,
appendStringInfo(str, node->into); node->isPortal ? "true" : "false",
appendStringInfo(str, " :isPortal "); node->isBinary ? "true" : "false",
appendStringInfo(str, (node->isPortal ? "true" : "false")); node->unionall ? "true" : "false");
appendStringInfo(str, " :isBinary ");
appendStringInfo(str, (node->isBinary ? "true" : "false")); appendStringInfo(str, " :unique %s :sortClause ", node->uniqueFlag);
appendStringInfo(str, " :unionall ");
appendStringInfo(str, (node->unionall ? "true" : "false"));
appendStringInfo(str, " :unique ");
appendStringInfo(str, node->uniqueFlag);
appendStringInfo(str, " :sortClause ");
_outNode(str, node->sortClause); _outNode(str, node->sortClause);
appendStringInfo(str, " :rtable "); appendStringInfo(str, " :rtable ");
_outNode(str, node->rtable); _outNode(str, node->rtable);
appendStringInfo(str, " :targetlist "); appendStringInfo(str, " :targetlist ");
_outNode(str, node->targetList); _outNode(str, node->targetList);
appendStringInfo(str, " :qual "); appendStringInfo(str, " :qual ");
_outNode(str, node->qual); _outNode(str, node->qual);
appendStringInfo(str, " :groupClause "); appendStringInfo(str, " :groupClause ");
_outNode(str, node->groupClause); _outNode(str, node->groupClause);
appendStringInfo(str, " :havingQual "); appendStringInfo(str, " :havingQual ");
_outNode(str, node->havingQual); _outNode(str, node->havingQual);
appendStringInfo(str, " :hasAggs ");
appendStringInfo(str, (node->hasAggs ? "true" : "false")); appendStringInfo(str, " :hasAggs %s :hasSubLinks %s :unionClause ",
appendStringInfo(str, " :hasSubLinks "); node->hasAggs ? "true" : "false",
appendStringInfo(str, (node->hasSubLinks ? "true" : "false")); node->hasSubLinks ? "true" : "false");
appendStringInfo(str, " :unionClause ");
_outNode(str, node->unionClause); _outNode(str, node->unionClause);
appendStringInfo(str, " :limitOffset "); appendStringInfo(str, " :limitOffset ");
_outNode(str, node->limitOffset); _outNode(str, node->limitOffset);
appendStringInfo(str, " :limitCount "); appendStringInfo(str, " :limitCount ");
_outNode(str, node->limitCount); _outNode(str, node->limitCount);
} }
...@@ -245,29 +227,19 @@ _outQuery(StringInfo str, Query *node) ...@@ -245,29 +227,19 @@ _outQuery(StringInfo str, Query *node)
static void static void
_outSortClause(StringInfo str, SortClause *node) _outSortClause(StringInfo str, SortClause *node)
{ {
char buf[500]; appendStringInfo(str, " SORTCLAUSE :resdom ");
appendStringInfo(str, " SORTCLAUSE ");
appendStringInfo(str, " :resdom ");
_outNode(str, node->resdom); _outNode(str, node->resdom);
appendStringInfo(str, " :opoid ");
snprintf(buf, 500, " %u ", node->opoid); appendStringInfo(str, " :opoid %u ", node->opoid);
appendStringInfo(str, buf);
} }
static void static void
_outGroupClause(StringInfo str, GroupClause *node) _outGroupClause(StringInfo str, GroupClause *node)
{ {
char buf[500]; appendStringInfo(str, " GROUPCLAUSE :entry ");
appendStringInfo(str, " GROUPCLAUSE ");
appendStringInfo(str, " :entry ");
_outNode(str, node->entry); _outNode(str, node->entry);
appendStringInfo(str, " :grpOpoid ");
snprintf(buf, 500, " %u ", node->grpOpoid); appendStringInfo(str, " :grpOpoid %u ", node->grpOpoid);
appendStringInfo(str, buf);
} }
/* /*
...@@ -276,32 +248,33 @@ _outGroupClause(StringInfo str, GroupClause *node) ...@@ -276,32 +248,33 @@ _outGroupClause(StringInfo str, GroupClause *node)
static void static void
_outPlanInfo(StringInfo str, Plan *node) _outPlanInfo(StringInfo str, Plan *node)
{ {
char buf[500]; appendStringInfo(str,
":cost %g :size %d :width %d :state %s :qptargetlist ",
snprintf(buf, 500, " :cost %g ", node->cost); node->cost,
appendStringInfo(str, buf); node->plan_size,
snprintf(buf, 500, " :size %d ", node->plan_size); node->plan_width,
appendStringInfo(str, buf); node->state ? "not-NULL" : "<>");
snprintf(buf, 500, " :width %d ", node->plan_width);
appendStringInfo(str, buf);
appendStringInfo(str, " :state ");
appendStringInfo(str, node->state ? "not-NULL" : "<>");
appendStringInfo(str, " :qptargetlist ");
_outNode(str, node->targetlist); _outNode(str, node->targetlist);
appendStringInfo(str, " :qpqual "); appendStringInfo(str, " :qpqual ");
_outNode(str, node->qual); _outNode(str, node->qual);
appendStringInfo(str, " :lefttree "); appendStringInfo(str, " :lefttree ");
_outNode(str, node->lefttree); _outNode(str, node->lefttree);
appendStringInfo(str, " :righttree "); appendStringInfo(str, " :righttree ");
_outNode(str, node->righttree); _outNode(str, node->righttree);
appendStringInfo(str, " :extprm "); appendStringInfo(str, " :extprm ");
_outIntList(str, node->extParam); _outIntList(str, node->extParam);
appendStringInfo(str, " :locprm "); appendStringInfo(str, " :locprm ");
_outIntList(str, node->locParam); _outIntList(str, node->locParam);
appendStringInfo(str, " :initplan "); appendStringInfo(str, " :initplan ");
_outNode(str, node->initPlan); _outNode(str, node->initPlan);
snprintf(buf, 500, " :nprm %d ", node->nParamExec);
appendStringInfo(str, buf); appendStringInfo(str, " :nprm %d ", node-nParamExec);
} }
/* /*
...@@ -331,8 +304,6 @@ _outResult(StringInfo str, Result *node) ...@@ -331,8 +304,6 @@ _outResult(StringInfo str, Result *node)
static void static void
_outAppend(StringInfo str, Append *node) _outAppend(StringInfo str, Append *node)
{ {
char buf[500];
appendStringInfo(str, " APPEND "); appendStringInfo(str, " APPEND ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
...@@ -342,10 +313,9 @@ _outAppend(StringInfo str, Append *node) ...@@ -342,10 +313,9 @@ _outAppend(StringInfo str, Append *node)
appendStringInfo(str, " :unionrtables "); appendStringInfo(str, " :unionrtables ");
_outNode(str, node->unionrtables); _outNode(str, node->unionrtables);
snprintf(buf, 500, " :inheritrelid %d ", node->inheritrelid); appendStringInfo(str,
appendStringInfo(str, buf); " :inheritrelid %d :inheritrtable ",
node->inheritrelid);
appendStringInfo(str, " :inheritrtable ");
_outNode(str, node->inheritrtable); _outNode(str, node->inheritrtable);
} }
...@@ -377,8 +347,6 @@ _outNestLoop(StringInfo str, NestLoop *node) ...@@ -377,8 +347,6 @@ _outNestLoop(StringInfo str, NestLoop *node)
static void static void
_outMergeJoin(StringInfo str, MergeJoin *node) _outMergeJoin(StringInfo str, MergeJoin *node)
{ {
char buf[500];
appendStringInfo(str, " MERGEJOIN "); appendStringInfo(str, " MERGEJOIN ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
...@@ -386,13 +354,11 @@ _outMergeJoin(StringInfo str, MergeJoin *node) ...@@ -386,13 +354,11 @@ _outMergeJoin(StringInfo str, MergeJoin *node)
_outNode(str, node->mergeclauses); _outNode(str, node->mergeclauses);
snprintf(buf, 500, " :mergejoinop %u ", node->mergejoinop); snprintf(buf, 500, " :mergejoinop %u ", node->mergejoinop);
appendStringInfo(str, buf); appendStringInfo(str,
" :mergejoinop %u :mergerightorder %u :mergeleftorder %u ",
snprintf(buf, 500, " :mergerightorder %u ", node->mergerightorder[0]); node->mergejoinop,
appendStringInfo(str, buf); node->mergerightorder,
node->mergeleftorder);
snprintf(buf, 500, " :mergeleftorder %u ", node->mergeleftorder[0]);
appendStringInfo(str, buf);
} }
/* /*
...@@ -401,42 +367,39 @@ _outMergeJoin(StringInfo str, MergeJoin *node) ...@@ -401,42 +367,39 @@ _outMergeJoin(StringInfo str, MergeJoin *node)
static void static void
_outHashJoin(StringInfo str, HashJoin *node) _outHashJoin(StringInfo str, HashJoin *node)
{ {
char buf[500];
appendStringInfo(str, " HASHJOIN "); appendStringInfo(str, " HASHJOIN ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
appendStringInfo(str, " :hashclauses "); appendStringInfo(str, " :hashclauses ");
_outNode(str, node->hashclauses); _outNode(str, node->hashclauses);
sprintf(buf, " :hashjoinop %u ", node->hashjoinop); appendStringInfo(str,
appendStringInfo(str, buf); " :hashjoinop %u :hashjointable 0x%x :hashjointablekey %d ",
sprintf(buf, " :hashjointable 0x%x ", (int) node->hashjointable); node->hashjoinop,
appendStringInfo(str, buf); (int) node->hashjointable,
sprintf(buf, " :hashjointablekey %d ", node->hashjointablekey); node->hashjointablekey);
appendStringInfo(str, buf);
sprintf(buf, " :hashjointablesize %d ", node->hashjointablesize); appendStringInfo(str,
appendStringInfo(str, buf); " :hashjointablesize %d :hashdone %d ",
sprintf(buf, " :hashdone %d ", node->hashdone); node->hashjointablesize,
appendStringInfo(str, buf); node->hashdone);
} }
static void static void
_outSubPlan(StringInfo str, SubPlan *node) _outSubPlan(StringInfo str, SubPlan *node)
{ {
char buf[500]; appendStringInfo(str, " SUBPLAN :plan ");
appendStringInfo(str, " SUBPLAN ");
appendStringInfo(str, " :plan ");
_outNode(str, node->plan); _outNode(str, node->plan);
sprintf(buf, " :planid %u ", node->plan_id);
appendStringInfo(str, buf); appendStringInfo(str, " :planid %u :rtable ", node->plan_id);
appendStringInfo(str, " :rtable ");
_outNode(str, node->rtable); _outNode(str, node->rtable);
appendStringInfo(str, " :setprm "); appendStringInfo(str, " :setprm ");
_outIntList(str, node->setParam); _outIntList(str, node->setParam);
appendStringInfo(str, " :parprm "); appendStringInfo(str, " :parprm ");
_outIntList(str, node->parParam); _outIntList(str, node->parParam);
appendStringInfo(str, " :slink "); appendStringInfo(str, " :slink ");
_outNode(str, node->sublink); _outNode(str, node->sublink);
} }
...@@ -447,14 +410,10 @@ _outSubPlan(StringInfo str, SubPlan *node) ...@@ -447,14 +410,10 @@ _outSubPlan(StringInfo str, SubPlan *node)
static void static void
_outScan(StringInfo str, Scan *node) _outScan(StringInfo str, Scan *node)
{ {
char buf[500];
appendStringInfo(str, " SCAN "); appendStringInfo(str, " SCAN ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
sprintf(buf, " :scanrelid %d ", node->scanrelid); appendStringInfo(str, " :scanrelid %d ", node->scanrelid);
appendStringInfo(str, buf);
} }
/* /*
...@@ -463,15 +422,10 @@ _outScan(StringInfo str, Scan *node) ...@@ -463,15 +422,10 @@ _outScan(StringInfo str, Scan *node)
static void static void
_outSeqScan(StringInfo str, SeqScan *node) _outSeqScan(StringInfo str, SeqScan *node)
{ {
char buf[500];
appendStringInfo(str, " SEQSCAN "); appendStringInfo(str, " SEQSCAN ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
sprintf(buf, " :scanrelid %d ", node->scanrelid); appendStringInfo(str, " :scanrelid %d ", node->scanrelid);
appendStringInfo(str, buf);
} }
/* /*
...@@ -480,15 +434,10 @@ _outSeqScan(StringInfo str, SeqScan *node) ...@@ -480,15 +434,10 @@ _outSeqScan(StringInfo str, SeqScan *node)
static void static void
_outIndexScan(StringInfo str, IndexScan *node) _outIndexScan(StringInfo str, IndexScan *node)
{ {
char buf[500];
appendStringInfo(str, " INDEXSCAN "); appendStringInfo(str, " INDEXSCAN ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
sprintf(buf, " :scanrelid %d ", node->scan.scanrelid); appendStringInfo(str, " :scanrelid %d :indxid ", node->scan.scanrelid);
appendStringInfo(str, buf);
appendStringInfo(str, " :indxid ");
_outIntList(str, node->indxid); _outIntList(str, node->indxid);
appendStringInfo(str, " :indxqual "); appendStringInfo(str, " :indxqual ");
...@@ -505,16 +454,12 @@ _outIndexScan(StringInfo str, IndexScan *node) ...@@ -505,16 +454,12 @@ _outIndexScan(StringInfo str, IndexScan *node)
static void static void
_outTemp(StringInfo str, Temp *node) _outTemp(StringInfo str, Temp *node)
{ {
char buf[500];
appendStringInfo(str, " TEMP "); appendStringInfo(str, " TEMP ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
sprintf(buf, " :tempid %u ", node->tempid); appendStringInfo(str, " :tempid %u :keycount %d ",
appendStringInfo(str, buf); node->tempid,
sprintf(buf, " :keycount %d ", node->keycount); node->keycount);
appendStringInfo(str, buf);
} }
/* /*
...@@ -523,16 +468,12 @@ _outTemp(StringInfo str, Temp *node) ...@@ -523,16 +468,12 @@ _outTemp(StringInfo str, Temp *node)
static void static void
_outSort(StringInfo str, Sort *node) _outSort(StringInfo str, Sort *node)
{ {
char buf[500];
appendStringInfo(str, " SORT "); appendStringInfo(str, " SORT ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
sprintf(buf, " :tempid %u ", node->tempid); appendStringInfo(str, " :tempid %u :keycount %d ",
appendStringInfo(str, buf); node->tempid,
sprintf(buf, " :keycount %d ", node->keycount); node->keycount);
appendStringInfo(str, buf);
} }
static void static void
...@@ -549,35 +490,27 @@ _outAgg(StringInfo str, Agg *node) ...@@ -549,35 +490,27 @@ _outAgg(StringInfo str, Agg *node)
static void static void
_outGroup(StringInfo str, Group *node) _outGroup(StringInfo str, Group *node)
{ {
char buf[500];
appendStringInfo(str, " GRP "); appendStringInfo(str, " GRP ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
/* the actual Group fields */ /* the actual Group fields */
sprintf(buf, " :numCols %d ", node->numCols); appendStringInfo(str, " :numCols %d :tuplePerGroup %s,
appendStringInfo(str, buf); node->numCols,
appendStringInfo(str, " :tuplePerGroup "); node->tuplePerGroup ? "true" : "false");
appendStringInfo(str, node->tuplePerGroup ? "true" : "false");
} }
/* /*
* For some reason, unique is a subclass of Temp. * For some reason, unique is a subclass of Temp.
*/ */
static void static void
_outUnique(StringInfo str, Unique *node) _outUnique(StringInfo str, Unique *node)
{ {
char buf[500];
appendStringInfo(str, " UNIQUE "); appendStringInfo(str, " UNIQUE ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
sprintf(buf, " :tempid %u ", node->tempid); appendStringInfo(str, " :tempid %u :keycount %d ",
appendStringInfo(str, buf); node->tempid,
sprintf(buf, " :keycount %d ", node->keycount); node->keycount);
appendStringInfo(str, buf);
} }
...@@ -587,8 +520,6 @@ _outUnique(StringInfo str, Unique *node) ...@@ -587,8 +520,6 @@ _outUnique(StringInfo str, Unique *node)
static void static void
_outHash(StringInfo str, Hash *node) _outHash(StringInfo str, Hash *node)
{ {
char buf[500];
appendStringInfo(str, " HASH "); appendStringInfo(str, " HASH ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
...@@ -596,86 +527,65 @@ _outHash(StringInfo str, Hash *node) ...@@ -596,86 +527,65 @@ _outHash(StringInfo str, Hash *node)
_outNode(str, node->hashkey); _outNode(str, node->hashkey);
sprintf(buf, " :hashtable 0x%x ", (int) (node->hashtable)); sprintf(buf, " :hashtable 0x%x ", (int) (node->hashtable));
appendStringInfo(str, buf); appendStringInfo(str, " :hashtable 0x%x :hashtablekey %d :hashtablesize %d ",
sprintf(buf, " :hashtablekey %d ", node->hashtablekey); (int) node->hashtable,
appendStringInfo(str, buf); node->hashtablekey,
sprintf(buf, " :hashtablesize %d ", node->hashtablesize); node->hashtablesize);
appendStringInfo(str, buf);
} }
static void static void
_outTee(StringInfo str, Tee *node) _outTee(StringInfo str, Tee *node)
{ {
char buf[500];
appendStringInfo(str, " TEE "); appendStringInfo(str, " TEE ");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
sprintf(buf, " :leftParent %X ", (int) (node->leftParent)); appendStringInfo(str, " :leftParent %X :rightParent %X ",
appendStringInfo(str, buf); (int) node->leftParent,
sprintf(buf, " :rightParent %X ", (int) (node->rightParent)); (int) node->rightParent);
appendStringInfo(str, buf);
appendStringInfo(str, " :rtentries "); appendStringInfo(str, " :rtentries ");
_outNode(str, node->rtentries); _outNode(str, node->rtentries);
} }
/***************************************************************************** /*****************************************************************************
* *
* Stuff from primnodes.h. * Stuff from primnodes.h.
* *
*****************************************************************************/ *****************************************************************************/
/* /*
* Resdom is a subclass of Node * Resdom is a subclass of Node
*/ */
static void static void
_outResdom(StringInfo str, Resdom *node) _outResdom(StringInfo str, Resdom *node)
{ {
char buf[500]; appendStringInfo(str, " RESDOM :resno %d :restype %u :restypmod %d ",
node->resno,
appendStringInfo(str, " RESDOM "); node->restype,
sprintf(buf, " :resno %d ", node->resno); node->restypmod);
appendStringInfo(str, buf);
sprintf(buf, " :restype %u ", node->restype);
appendStringInfo(str, buf);
sprintf(buf, " :restypmod %d ", node->restypmod);
appendStringInfo(str, buf);
appendStringInfo(str, " :resname ");
sprintf(buf, "\"%s\"", node->resname); /* fix for SELECT col AS
* "my name" */
appendStringInfo(str, buf);
sprintf(buf, " :reskey %d ", node->reskey);
appendStringInfo(str, buf);
sprintf(buf, " :reskeyop %u ", node->reskeyop);
appendStringInfo(str, buf);
sprintf(buf, " :resjunk %d ", node->resjunk);
appendStringInfo(str, buf);
appendStringInfo(str, " :resname \"%s\" :reskey %d :reskeyop %u :resjunk %d",
node->resname,
node->reskey,
node->reskeyop,
node->resjunk);
} }
static void static void
_outFjoin(StringInfo str, Fjoin *node) _outFjoin(StringInfo str, Fjoin *node)
{ {
char buf[500];
int i; int i;
appendStringInfo(str, " FJOIN "); appendStringInfo(str, " FJOIN :initialized %s :nNodes %d ",
appendStringInfo(str, " :initialized "); node->fj_initialized ? "true" : "false",
appendStringInfo(str, node->fj_initialized ? "true" : "false"); node->fj_nNodes);
sprintf(buf, " :nNodes %d ", node->fj_nNodes);
appendStringInfo(str, buf);
appendStringInfo(str, " :innerNode "); appendStringInfo(str, " :innerNode ");
_outNode(str, node->fj_innerNode); _outNode(str, node->fj_innerNode);
sprintf(buf, " :results @ 0x%x ", (int) (node->fj_results)); appendStringInfo(str, " :results @ 0x%x :alwaysdone",
appendStringInfo(str, buf); (int) node->fj_results);
appendStringInfo(str, " :alwaysdone ");
for (i = 0; i < node->fj_nNodes; i++) for (i = 0; i < node->fj_nNodes; i++)
appendStringInfo(str, (node->fj_alwaysDone[i]) ? "true" : "false"); appendStringInfo(str, (node->fj_alwaysDone[i]) ? "true" : "false");
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment