|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
*
|
|
|
|
* parse_node.h
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group
|
|
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
|
|
*
|
|
|
|
* $Id: parse_node.h,v 1.34 2003/04/08 23:20:04 tgl Exp $
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
#ifndef PARSE_NODE_H
|
|
|
|
#define PARSE_NODE_H
|
|
|
|
|
|
|
|
#include "nodes/parsenodes.h"
|
|
|
|
#include "utils/rel.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* State information used during parse analysis
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* p_namespace: list of join items that represents the current namespace
|
|
|
|
* for table and column lookup. This may be just a subset of the rtable +
|
|
|
|
* joinlist, and/or may contain entries that are not yet added to the main
|
|
|
|
* joinlist. Note that an RTE that is present in p_namespace, but does not
|
|
|
|
* have its inFromCl flag set, is accessible only with an explicit qualifier;
|
|
|
|
* lookups of unqualified column names should ignore it.
|
|
|
|
*/
|
|
|
|
typedef struct ParseState
|
|
|
|
{
|
|
|
|
struct ParseState *parentParseState; /* stack link */
|
|
|
|
List *p_rtable; /* range table so far */
|
|
|
|
List *p_joinlist; /* join items so far (will become FromExpr
|
|
|
|
* node's fromlist) */
|
|
|
|
List *p_namespace; /* current lookup namespace (join items) */
|
|
|
|
int p_last_resno; /* last targetlist resno assigned */
|
|
|
|
List *p_forUpdate; /* FOR UPDATE clause, if any (see gram.y) */
|
|
|
|
Node *p_value_substitute; /* what to replace VALUE with, if any */
|
|
|
|
bool p_hasAggs;
|
|
|
|
bool p_hasSubLinks;
|
|
|
|
bool p_is_insert;
|
|
|
|
bool p_is_update;
|
|
|
|
Relation p_target_relation;
|
|
|
|
RangeTblEntry *p_target_rangetblentry;
|
|
|
|
} ParseState;
|
|
|
|
|
|
|
|
extern ParseState *make_parsestate(ParseState *parentParseState);
|
|
|
|
extern Var *make_var(ParseState *pstate, RangeTblEntry *rte, int attrno);
|
|
|
|
extern ArrayRef *transformArraySubscripts(ParseState *pstate,
|
|
|
|
Node *arrayBase,
|
|
|
|
Oid arrayType,
|
Extend pg_cast castimplicit column to a three-way value; this allows us
to be flexible about assignment casts without introducing ambiguity in
operator/function resolution. Introduce a well-defined promotion hierarchy
for numeric datatypes (int2->int4->int8->numeric->float4->float8).
Change make_const to initially label numeric literals as int4, int8, or
numeric (never float8 anymore).
Explicitly mark Func and RelabelType nodes to indicate whether they came
from a function call, explicit cast, or implicit cast; use this to do
reverse-listing more accurately and without so many heuristics.
Explicit casts to char, varchar, bit, varbit will truncate or pad without
raising an error (the pre-7.2 behavior), while assigning to a column without
any explicit cast will still raise an error for wrong-length data like 7.3.
This more nearly follows the SQL spec than 7.2 behavior (we should be
reporting a 'completion condition' in the explicit-cast cases, but we have
no mechanism for that, so just do silent truncation).
Fix some problems with enforcement of typmod for array elements;
it didn't work at all in 'UPDATE ... SET array[n] = foo', for example.
Provide a generalized array_length_coerce() function to replace the
specialized per-array-type functions that used to be needed (and were
missing for NUMERIC as well as all the datetime types).
Add missing conversions int8<->float4, text<->numeric, oid<->int8.
initdb forced.
23 years ago
|
|
|
int32 arrayTypMod,
|
|
|
|
List *indirection,
|
|
|
|
bool forceSlice,
|
|
|
|
Node *assignFrom);
|
|
|
|
extern Const *make_const(Value *value);
|
|
|
|
|
|
|
|
#endif /* PARSE_NODE_H */
|