postgresql/src/backend/parser
Tom Lane fb8697b31a Avoid unnecessary use of pg_strcasecmp for already-downcased identifiers.
We have a lot of code in which option names, which from the user's
viewpoint are logically keywords, are passed through the grammar as plain
identifiers, and then matched to string literals during command execution.
This approach avoids making words into lexer keywords unnecessarily.  Some
places matched these strings using plain strcmp, some using pg_strcasecmp.
But the latter should be unnecessary since identifiers would have been
downcased on their way through the parser.  Aside from any efficiency
concerns (probably not a big factor), the lack of consistency in this area
creates a hazard of subtle bugs due to different places coming to different
conclusions about whether two option names are the same or different.
Hence, standardize on using strcmp() to match any option names that are
expected to have been fed through the parser.

This does create a user-visible behavioral change, which is that while
formerly all of these would work:
	alter table foo set (fillfactor = 50);
	alter table foo set (FillFactor = 50);
	alter table foo set ("fillfactor" = 50);
	alter table foo set ("FillFactor" = 50);
now the last case will fail because that double-quoted identifier is
different from the others.  However, none of our documentation says that
you can use a quoted identifier in such contexts at all, and we should
discourage doing so since it would break if we ever decide to parse such
constructs as true lexer keywords rather than poor man's substitutes.
So this shouldn't create a significant compatibility issue for users.

Daniel Gustafsson, reviewed by Michael Paquier, small changes by me

Discussion: https://postgr.es/m/29405B24-564E-476B-98C0-677A29805B84@yesql.se
2018-01-26 18:25:14 -05:00
..
.gitignore Convert cvsignore to gitignore, and add .gitignore for build targets. 2010-09-22 12:57:04 +02:00
Makefile Add infrastructure to support EphemeralNamedRelation references. 2017-03-31 23:17:18 -05:00
README Move keywords.c/kwlookup.c into src/common/. 2016-03-23 20:22:08 -04:00
analyze.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
check_keywords.pl Update copyright for 2018 2018-01-02 23:30:12 -05:00
gram.y Remove the obsolete WITH clause of CREATE FUNCTION. 2018-01-26 12:25:44 -05:00
parse_agg.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_clause.c Avoid unnecessary use of pg_strcasecmp for already-downcased identifiers. 2018-01-26 18:25:14 -05:00
parse_coerce.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_collate.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_cte.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_enr.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_expr.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_func.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_node.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_oper.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_param.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_relation.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_target.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_type.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
parse_utilcmd.c Replace AclObjectKind with ObjectType 2018-01-19 14:01:15 -05:00
parser.c Update copyright for 2018 2018-01-02 23:30:12 -05:00
scan.l Update copyright for 2018 2018-01-02 23:30:12 -05:00
scansup.c Update copyright for 2018 2018-01-02 23:30:12 -05:00

README

src/backend/parser/README

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
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_collate.c	assign collation information in completed expressions
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)

See also src/common/keywords.c, which contains the table of standard
keywords and the keyword lookup function.  We separated that out because
various frontend code wants to use it too.