diff options
Diffstat (limited to 'src/include/parser')
-rw-r--r-- | src/include/parser/analyze.h | 15 | ||||
-rw-r--r-- | src/include/parser/parse_node.h | 3 | ||||
-rw-r--r-- | src/include/parser/parse_utilcmd.h | 28 |
3 files changed, 37 insertions, 9 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); diff --git a/src/include/parser/parse_node.h b/src/include/parser/parse_node.h index 7382a4f531c..a1d84801fc5 100644 --- a/src/include/parser/parse_node.h +++ b/src/include/parser/parse_node.h @@ -7,7 +7,7 @@ * Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * - * $PostgreSQL: pgsql/src/include/parser/parse_node.h,v 1.51 2007/01/05 22:19:57 momjian Exp $ + * $PostgreSQL: pgsql/src/include/parser/parse_node.h,v 1.52 2007/06/23 22:12:52 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -83,6 +83,7 @@ typedef struct ParseState } ParseState; extern ParseState *make_parsestate(ParseState *parentParseState); +extern void free_parsestate(ParseState *pstate); extern int parser_errposition(ParseState *pstate, int location); extern Var *make_var(ParseState *pstate, RangeTblEntry *rte, int attrno); diff --git a/src/include/parser/parse_utilcmd.h b/src/include/parser/parse_utilcmd.h new file mode 100644 index 00000000000..f9ca398e253 --- /dev/null +++ b/src/include/parser/parse_utilcmd.h @@ -0,0 +1,28 @@ +/*------------------------------------------------------------------------- + * + * parse_utilcmd.h + * parse analysis for utility commands + * + * + * Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group + * Portions Copyright (c) 1994, Regents of the University of California + * + * $PostgreSQL: pgsql/src/include/parser/parse_utilcmd.h,v 1.1 2007/06/23 22:12:52 tgl Exp $ + * + *------------------------------------------------------------------------- + */ +#ifndef PARSE_UTILCMD_H +#define PARSE_UTILCMD_H + +#include "parser/parse_node.h" + + +extern List *transformCreateStmt(CreateStmt *stmt, const char *queryString); +extern List *transformAlterTableStmt(AlterTableStmt *stmt, + const char *queryString); +extern IndexStmt *transformIndexStmt(IndexStmt *stmt, const char *queryString); +extern void transformRuleStmt(RuleStmt *stmt, const char *queryString, + List **actions, Node **whereClause); +extern List *transformCreateSchemaStmt(CreateSchemaStmt *stmt); + +#endif /* PARSE_UTILCMD_H */ |