diff options
author | Tom Lane | 2002-12-13 19:46:01 +0000 |
---|---|---|
committer | Tom Lane | 2002-12-13 19:46:01 +0000 |
commit | 3a4f7dde16ad81b2319b9a4924a6023710a2fefd (patch) | |
tree | 248cf66fd94d40072b5ba8bb8e5437a6ea8399e5 /src/backend/executor/nodeTidscan.c | |
parent | 77b7a740f95250af7d78f69e9c906c3e53f32e7b (diff) |
Phase 3 of read-only-plans project: ExecInitExpr now builds expression
execution state trees, and ExecEvalExpr takes an expression state tree
not an expression plan tree. The plan tree is now read-only as far as
the executor is concerned. Next step is to begin actually exploiting
this property.
Diffstat (limited to 'src/backend/executor/nodeTidscan.c')
-rw-r--r-- | src/backend/executor/nodeTidscan.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/src/backend/executor/nodeTidscan.c b/src/backend/executor/nodeTidscan.c index 53b3c26d35a..ba2793407ce 100644 --- a/src/backend/executor/nodeTidscan.c +++ b/src/backend/executor/nodeTidscan.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/executor/nodeTidscan.c,v 1.28 2002/12/05 15:50:34 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/executor/nodeTidscan.c,v 1.29 2002/12/13 19:45:56 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -380,10 +380,10 @@ ExecInitTidScan(TidScan *node, EState *estate) * initialize child expressions */ tidstate->ss.ps.targetlist = (List *) - ExecInitExpr((Node *) node->scan.plan.targetlist, + ExecInitExpr((Expr *) node->scan.plan.targetlist, (PlanState *) tidstate); tidstate->ss.ps.qual = (List *) - ExecInitExpr((Node *) node->scan.plan.qual, + ExecInitExpr((Expr *) node->scan.plan.qual, (PlanState *) tidstate); #define TIDSCAN_NSLOTS 2 @@ -404,7 +404,10 @@ ExecInitTidScan(TidScan *node, EState *estate) * get the tid node information */ tidList = (ItemPointerData *) palloc(length(node->tideval) * sizeof(ItemPointerData)); - numTids = TidListCreate(node->tideval, + tidstate->tss_tideval = (List *) + ExecInitExpr((Expr *) node->tideval, + (PlanState *) tidstate); + numTids = TidListCreate(tidstate->tss_tideval, tidstate->ss.ps.ps_ExprContext, tidList); tidPtr = -1; |