diff options
Diffstat (limited to 'src/include')
| -rw-r--r-- | src/include/executor/executor.h | 4 | ||||
| -rw-r--r-- | src/include/nodes/makefuncs.h | 6 | ||||
| -rw-r--r-- | src/include/nodes/primnodes.h | 15 | 
3 files changed, 13 insertions, 12 deletions
| diff --git a/src/include/executor/executor.h b/src/include/executor/executor.h index 3dc03c913e3..cd57a704adc 100644 --- a/src/include/executor/executor.h +++ b/src/include/executor/executor.h @@ -459,7 +459,7 @@ typedef bool (*ExecScanRecheckMtd) (ScanState *node, TupleTableSlot *slot);  extern TupleTableSlot *ExecScan(ScanState *node, ExecScanAccessMtd accessMtd,  								ExecScanRecheckMtd recheckMtd);  extern void ExecAssignScanProjectionInfo(ScanState *node); -extern void ExecAssignScanProjectionInfoWithVarno(ScanState *node, Index varno); +extern void ExecAssignScanProjectionInfoWithVarno(ScanState *node, int varno);  extern void ExecScanReScan(ScanState *node);  /* @@ -552,7 +552,7 @@ extern const TupleTableSlotOps *ExecGetResultSlotOps(PlanState *planstate,  extern void ExecAssignProjectionInfo(PlanState *planstate,  									 TupleDesc inputDesc);  extern void ExecConditionalAssignProjectionInfo(PlanState *planstate, -												TupleDesc inputDesc, Index varno); +												TupleDesc inputDesc, int varno);  extern void ExecFreeExprContext(PlanState *planstate);  extern void ExecAssignScanType(ScanState *scanstate, TupleDesc tupDesc);  extern void ExecCreateScanSlotFromOuterPlan(EState *estate, diff --git a/src/include/nodes/makefuncs.h b/src/include/nodes/makefuncs.h index 48a7ebfe450..eea87f847d8 100644 --- a/src/include/nodes/makefuncs.h +++ b/src/include/nodes/makefuncs.h @@ -24,18 +24,18 @@ extern A_Expr *makeA_Expr(A_Expr_Kind kind, List *name,  extern A_Expr *makeSimpleA_Expr(A_Expr_Kind kind, char *name,  								Node *lexpr, Node *rexpr, int location); -extern Var *makeVar(Index varno, +extern Var *makeVar(int varno,  					AttrNumber varattno,  					Oid vartype,  					int32 vartypmod,  					Oid varcollid,  					Index varlevelsup); -extern Var *makeVarFromTargetEntry(Index varno, +extern Var *makeVarFromTargetEntry(int varno,  								   TargetEntry *tle);  extern Var *makeWholeRowVar(RangeTblEntry *rte, -							Index varno, +							int varno,  							Index varlevelsup,  							bool allowScalar); diff --git a/src/include/nodes/primnodes.h b/src/include/nodes/primnodes.h index 7b125904b4d..433437643e0 100644 --- a/src/include/nodes/primnodes.h +++ b/src/include/nodes/primnodes.h @@ -172,12 +172,12 @@ typedef struct Expr   * in the planner and doesn't correspond to any simple relation column may   * have varnosyn = varattnosyn = 0.   */ -#define    INNER_VAR		65000	/* reference to inner subplan */ -#define    OUTER_VAR		65001	/* reference to outer subplan */ -#define    INDEX_VAR		65002	/* reference to index column */ -#define    ROWID_VAR		65003	/* row identity column during planning */ +#define    INNER_VAR		(-1)	/* reference to inner subplan */ +#define    OUTER_VAR		(-2)	/* reference to outer subplan */ +#define    INDEX_VAR		(-3)	/* reference to index column */ +#define    ROWID_VAR		(-4)	/* row identity column during planning */ -#define IS_SPECIAL_VARNO(varno)		((varno) >= INNER_VAR) +#define IS_SPECIAL_VARNO(varno)		((int) (varno) < 0)  /* Symbols for the indexes of the special RTE entries in rules */  #define    PRS2_OLD_VARNO			1 @@ -186,8 +186,8 @@ typedef struct Expr  typedef struct Var  {  	Expr		xpr; -	Index		varno;			/* index of this var's relation in the range -								 * table, or INNER_VAR/OUTER_VAR/INDEX_VAR */ +	int			varno;			/* index of this var's relation in the range +								 * table, or INNER_VAR/OUTER_VAR/etc */  	AttrNumber	varattno;		/* attribute number of this var, or zero for  								 * all attrs ("whole-row Var") */  	Oid			vartype;		/* pg_type OID for the type of this var */ @@ -1351,6 +1351,7 @@ typedef struct SetToDefault   * of the target relation being constrained; this aids placing the expression   * correctly during planning.  We can assume however that its "levelsup" is   * always zero, due to the syntactic constraints on where it can appear. + * Also, cvarno will always be a true RT index, never INNER_VAR etc.   *   * The referenced cursor can be represented either as a hardwired string   * or as a reference to a run-time parameter of type REFCURSOR.  The latter | 
