You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
postgres/src/backend/parser
Tom Lane e49ae8d3bc Recognize functional dependency on primary keys. This allows a table's 16 years ago
..
.cvsignore Remove all traces that suggest that a non-Bison yacc might be supported, and 18 years ago
Makefile Fix a few places where we needed -I. in CPPFLAGS to work properly in 16 years ago
README Implement parser hooks for processing ColumnRef and ParamRef nodes, as per my 16 years ago
analyze.c pgindent run for 9.0 16 years ago
gram.y Add xmlexists function 16 years ago
keywords.c Update copyright for the year 2010. 16 years ago
kwlookup.c Update copyright for the year 2010. 16 years ago
parse_agg.c Recognize functional dependency on primary keys. This allows a table's 16 years ago
parse_clause.c Allow ORDER BY/GROUP BY/etc items to match targetlist items regardless of 16 years ago
parse_coerce.c Fix IsBinaryCoercible to not confuse a cast using in/out functions 16 years ago
parse_cte.c Update copyright for the year 2010. 16 years ago
parse_expr.c Improved version of patch to protect pg_get_expr() against misuse: 16 years ago
parse_func.c Add a very specific hint for the case that we're unable to locate a function 16 years ago
parse_node.c Wrap calls to SearchSysCache and related functions using macros. 16 years ago
parse_oper.c Improved version of patch to protect pg_get_expr() against misuse: 16 years ago
parse_param.c pgindent run for 9.0 16 years ago
parse_relation.c Fix stupid typo in refnameRangeTblEntry() --- mea maxima culpa. 16 years ago
parse_target.c pgindent run for 9.0 16 years ago
parse_type.c Wrap calls to SearchSysCache and related functions using macros. 16 years ago
parse_utilcmd.c Standardize get_whatever_oid functions for other object types. 16 years ago
parser.c Update copyright for the year 2010. 16 years ago
scan.l Change the default value of standard_conforming_strings to on. 16 years ago
scansup.c pgindent run for 9.0, second run 16 years ago

README

$PostgreSQL: pgsql/src/backend/parser/README,v 1.11 2009/10/31 01:41:31 tgl Exp $

Parser
======

This directory does more than tokenize and parse SQL queries. It also
creates Query structures for the various complex queries that are passed
to the optimizer and then executor.

parser.c things start here
scan.l break query into tokens
scansup.c handle escapes in input strings
kwlookup.c turn keywords into specific tokens
keywords.c table of standard keywords (passed to kwlookup.c)
gram.y parse the tokens and produce a "raw" parse tree
analyze.c top level of parse analysis for optimizable queries
parse_agg.c handle aggregates, like SUM(col1), AVG(col2), ...
parse_clause.c handle clauses like WHERE, ORDER BY, GROUP BY, ...
parse_coerce.c handle coercing expressions to different data types
parse_cte.c handle Common Table Expressions (WITH clauses)
parse_expr.c handle expressions like col, col + 3, x = 3 or x = 4
parse_func.c handle functions, table.column and column identifiers
parse_node.c create nodes for various structures
parse_oper.c handle operators in expressions
parse_param.c handle Params (for the cases used in the core backend)
parse_relation.c support routines for tables and column handling
parse_target.c handle the result list of the query
parse_type.c support routines for data type handling
parse_utilcmd.c parse analysis for utility commands (done at execution time)