diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2007-06-23 22:12:52 +0000 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2007-06-23 22:12:52 +0000 |
commit | 46379d6e60f0f95e127a5045ca1fa74dfdc48a85 (patch) | |
tree | 7d6fe8004575203b40a38184c154dc7f34a20345 /src/include/parser/analyze.h | |
parent | ec0bb02db8452d4098023f82b100ba68d8f7dfab (diff) | |
download | postgresql-46379d6e60f0f95e127a5045ca1fa74dfdc48a85.tar.gz postgresql-46379d6e60f0f95e127a5045ca1fa74dfdc48a85.zip |
Separate parse-analysis for utility commands out of parser/analyze.c
(which now deals only in optimizable statements), and put that code
into a new file parser/parse_utilcmd.c. This helps clarify and enforce
the design rule that utility statements shouldn't be processed during
the regular parse analysis phase; all interpretation of their meaning
should happen after they are given to ProcessUtility to execute.
(We need this because we don't retain any locks for a utility statement
that's in a plan cache, nor have any way to detect that it's stale.)
We are also able to simplify the API for parse_analyze() and related
routines, because they will now always return exactly one Query structure.
In passing, fix bug #3403 concerning trying to add a serial column to
an existing temp table (this is largely Heikki's work, but we needed
all that restructuring to make it safe).
Diffstat (limited to 'src/include/parser/analyze.h')
-rw-r--r-- | src/include/parser/analyze.h | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/src/include/parser/analyze.h b/src/include/parser/analyze.h index 033dce60462..5087d20a60a 100644 --- a/src/include/parser/analyze.h +++ b/src/include/parser/analyze.h @@ -1,12 +1,13 @@ /*------------------------------------------------------------------------- * * analyze.h + * parse analysis for optimizable statements * * * Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $PostgreSQL: pgsql/src/include/parser/analyze.h,v 1.36 2007/03/13 00:33:43 tgl Exp $ + * $PostgreSQL: pgsql/src/include/parser/analyze.h,v 1.37 2007/06/23 22:12:52 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -16,16 +17,14 @@ #include "parser/parse_node.h" -extern List *parse_analyze(Node *parseTree, const char *sourceText, +extern Query *parse_analyze(Node *parseTree, const char *sourceText, Oid *paramTypes, int numParams); -extern List *parse_analyze_varparams(Node *parseTree, const char *sourceText, +extern Query *parse_analyze_varparams(Node *parseTree, const char *sourceText, Oid **paramTypes, int *numParams); -extern List *parse_sub_analyze(Node *parseTree, ParseState *parentParseState); -extern IndexStmt *analyzeIndexStmt(IndexStmt *stmt, const char *queryString); -extern void analyzeRuleStmt(RuleStmt *stmt, const char *queryString, - List **actions, Node **whereClause); -extern List *analyzeCreateSchemaStmt(CreateSchemaStmt *stmt); +extern Query *parse_sub_analyze(Node *parseTree, ParseState *parentParseState); +extern Query *transformStmt(ParseState *pstate, Node *parseTree); + extern void CheckSelectLocking(Query *qry); extern void applyLockingClause(Query *qry, Index rtindex, bool forUpdate, bool noWait); |