1997-11-25 23:07:18 +01:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
*
|
|
|
|
* parse_node.h
|
2003-04-30 00:13:11 +02:00
|
|
|
* Internal definitions for parser
|
1997-11-25 23:07:18 +01:00
|
|
|
*
|
|
|
|
*
|
2004-12-31 23:04:05 +01:00
|
|
|
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
|
2000-01-26 06:58:53 +01:00
|
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
1997-11-25 23:07:18 +01:00
|
|
|
*
|
2005-10-15 04:49:52 +02:00
|
|
|
* $PostgreSQL: pgsql/src/include/parser/parse_node.h,v 1.46 2005/10/15 02:49:45 momjian Exp $
|
1997-11-25 23:07:18 +01:00
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
#ifndef PARSE_NODE_H
|
|
|
|
#define PARSE_NODE_H
|
|
|
|
|
1999-07-16 01:04:24 +02:00
|
|
|
#include "nodes/parsenodes.h"
|
|
|
|
#include "utils/rel.h"
|
1997-11-25 23:07:18 +01:00
|
|
|
|
2000-09-12 23:07:18 +02:00
|
|
|
/*
|
|
|
|
* State information used during parse analysis
|
2001-02-14 22:35:07 +01:00
|
|
|
*
|
|
|
|
* p_rtable: list of RTEs that will become the rangetable of the query.
|
|
|
|
* Note that neither relname nor refname of these entries are necessarily
|
|
|
|
* unique; searching the rtable by name is a bad idea.
|
|
|
|
*
|
|
|
|
* p_joinlist: list of join items (RangeTblRef and JoinExpr nodes) that
|
|
|
|
* will become the fromlist of the query's top-level FromExpr node.
|
|
|
|
*
|
2005-06-05 02:38:11 +02:00
|
|
|
* p_relnamespace: list of RTEs that represents the current namespace for
|
|
|
|
* table lookup, ie, those RTEs that are accessible by qualified names.
|
|
|
|
* This may be just a subset of the rtable + joinlist, and/or may contain
|
|
|
|
* entries that are not yet added to the main joinlist.
|
|
|
|
*
|
|
|
|
* p_varnamespace: list of RTEs that represents the current namespace for
|
|
|
|
* column lookup, ie, those RTEs that are accessible by unqualified names.
|
|
|
|
* This is different from p_relnamespace because a JOIN without an alias does
|
|
|
|
* not hide the contained tables (so they must still be in p_relnamespace)
|
|
|
|
* but it does hide their columns (unqualified references to the columns must
|
|
|
|
* refer to the JOIN, not the member tables). Also, we put POSTQUEL-style
|
|
|
|
* implicit RTEs into p_relnamespace but not p_varnamespace, so that they
|
|
|
|
* do not affect the set of columns available for unqualified references.
|
2003-04-30 00:13:11 +02:00
|
|
|
*
|
|
|
|
* p_paramtypes: an array of p_numparams type OIDs for $n parameter symbols
|
|
|
|
* (zeroth entry in array corresponds to $1). If p_variableparams is true, the
|
|
|
|
* set of param types is not predetermined; in that case, a zero array entry
|
|
|
|
* means that parameter number hasn't been seen, and UNKNOWNOID means the
|
|
|
|
* parameter has been used but its type is not yet known. NOTE: in a stack
|
|
|
|
* of ParseStates, only the topmost ParseState contains paramtype info; but
|
|
|
|
* we copy the p_variableparams flag down to the child nodes for speed in
|
|
|
|
* coerce_type.
|
2000-02-15 04:38:29 +01:00
|
|
|
*/
|
1997-11-25 23:07:18 +01:00
|
|
|
typedef struct ParseState
|
|
|
|
{
|
2001-03-22 05:01:46 +01:00
|
|
|
struct ParseState *parentParseState; /* stack link */
|
2000-09-12 23:07:18 +02:00
|
|
|
List *p_rtable; /* range table so far */
|
2001-03-22 05:01:46 +01:00
|
|
|
List *p_joinlist; /* join items so far (will become FromExpr
|
|
|
|
* node's fromlist) */
|
2005-10-15 04:49:52 +02:00
|
|
|
List *p_relnamespace; /* current namespace for relations */
|
|
|
|
List *p_varnamespace; /* current namespace for columns */
|
2003-04-30 00:13:11 +02:00
|
|
|
Oid *p_paramtypes; /* OIDs of types for $n parameter symbols */
|
|
|
|
int p_numparams; /* allocated size of p_paramtypes[] */
|
|
|
|
int p_next_resno; /* next targetlist resno to assign */
|
2005-08-01 22:31:16 +02:00
|
|
|
LockingClause *p_locking_clause; /* FOR UPDATE/FOR SHARE info */
|
2005-10-15 04:49:52 +02:00
|
|
|
Node *p_value_substitute; /* what to replace VALUE with, if any */
|
2003-04-30 00:13:11 +02:00
|
|
|
bool p_variableparams;
|
1998-01-15 20:00:16 +01:00
|
|
|
bool p_hasAggs;
|
1998-01-17 05:53:46 +01:00
|
|
|
bool p_hasSubLinks;
|
1998-01-15 20:00:16 +01:00
|
|
|
bool p_is_insert;
|
1997-11-25 23:07:18 +01:00
|
|
|
bool p_is_update;
|
|
|
|
Relation p_target_relation;
|
|
|
|
RangeTblEntry *p_target_rangetblentry;
|
|
|
|
} ParseState;
|
|
|
|
|
1998-01-19 06:06:41 +01:00
|
|
|
extern ParseState *make_parsestate(ParseState *parentParseState);
|
2000-09-12 23:07:18 +02:00
|
|
|
extern Var *make_var(ParseState *pstate, RangeTblEntry *rte, int attrno);
|
2004-08-29 07:07:03 +02:00
|
|
|
extern Oid transformArrayType(Oid arrayType);
|
1999-07-19 02:26:20 +02:00
|
|
|
extern ArrayRef *transformArraySubscripts(ParseState *pstate,
|
2000-04-12 19:17:23 +02:00
|
|
|
Node *arrayBase,
|
2001-02-14 22:35:07 +01:00
|
|
|
Oid arrayType,
|
2004-06-09 21:08:20 +02:00
|
|
|
Oid elementType,
|
|
|
|
int32 elementTypMod,
|
2000-04-12 19:17:23 +02:00
|
|
|
List *indirection,
|
|
|
|
Node *assignFrom);
|
1997-11-26 02:14:33 +01:00
|
|
|
extern Const *make_const(Value *value);
|
2001-10-28 07:26:15 +01:00
|
|
|
|
2001-11-05 18:46:40 +01:00
|
|
|
#endif /* PARSE_NODE_H */
|