mirror of
https://github.com/postgres/postgres.git
synced 2025-08-27 07:42:10 +03:00
Fix bootstrap parser so that its keywords are unreserved words.
Mark Dilger pointed out that the bootstrap parser does not allow any of its keywords to appear as column values unless they're quoted, and proposed dealing with that by quoting such values in genbki.pl. Looking closer, though, we also have that problem with respect to table, column, and type names appearing in the .bki file: the parser would fail if any of those matched any of its keywords. While so far there have been no conflicts (that I've heard of), this seems like a booby trap waiting to catch somebody. Rather than clutter genbki.pl with enough quoting logic to handle all that, let's make the bootstrap parser grow up a little bit and treat its keywords as unreserved. Experimentation shows that it's fairly easy to do so with the exception of _null_, which I don't have a big problem with keeping as a reserved word. The only change needed is that we can't have the "close" command take an optional table name: it has to either require or forbid the table name to avoid shift/reduce conflicts. genbki.pl has historically always included the table name, so I took that option. The implementation has bootscanner.l passing forward the string value of each keyword, in case bootparse.y needs that. This avoids needing to know the precise spelling of each keyword in bootparse.y, which is good because that's not always obvious from the token name. Discussion: https://postgr.es/m/3024FC91-DB6D-4732-B31C-DF772DF039A0@gmail.com
This commit is contained in:
@@ -105,6 +105,7 @@ static int num_columns_read = 0;
|
||||
List *list;
|
||||
IndexElem *ielem;
|
||||
char *str;
|
||||
const char *kw;
|
||||
int ival;
|
||||
Oid oidval;
|
||||
}
|
||||
@@ -116,17 +117,17 @@ static int num_columns_read = 0;
|
||||
%type <oidval> oidspec optoideq optrowtypeoid
|
||||
|
||||
%token <str> ID
|
||||
%token OPEN XCLOSE XCREATE INSERT_TUPLE
|
||||
%token XDECLARE INDEX ON USING XBUILD INDICES UNIQUE XTOAST
|
||||
%token COMMA EQUALS LPAREN RPAREN
|
||||
%token OBJ_ID XBOOTSTRAP XSHARED_RELATION XWITHOUT_OIDS XROWTYPE_OID NULLVAL
|
||||
%token XFORCE XNOT XNULL
|
||||
/* NULLVAL is a reserved keyword */
|
||||
%token NULLVAL
|
||||
/* All the rest are unreserved, and should be handled in boot_ident! */
|
||||
%token <kw> OPEN XCLOSE XCREATE INSERT_TUPLE
|
||||
%token <kw> XDECLARE INDEX ON USING XBUILD INDICES UNIQUE XTOAST
|
||||
%token <kw> OBJ_ID XBOOTSTRAP XSHARED_RELATION XWITHOUT_OIDS XROWTYPE_OID
|
||||
%token <kw> XFORCE XNOT XNULL
|
||||
|
||||
%start TopLevel
|
||||
|
||||
%nonassoc low
|
||||
%nonassoc high
|
||||
|
||||
%%
|
||||
|
||||
TopLevel:
|
||||
@@ -160,18 +161,12 @@ Boot_OpenStmt:
|
||||
;
|
||||
|
||||
Boot_CloseStmt:
|
||||
XCLOSE boot_ident %prec low
|
||||
XCLOSE boot_ident
|
||||
{
|
||||
do_start();
|
||||
closerel($2);
|
||||
do_end();
|
||||
}
|
||||
| XCLOSE %prec high
|
||||
{
|
||||
do_start();
|
||||
closerel(NULL);
|
||||
do_end();
|
||||
}
|
||||
;
|
||||
|
||||
Boot_CreateStmt:
|
||||
@@ -489,8 +484,28 @@ boot_column_val:
|
||||
{ InsertOneNull(num_columns_read++); }
|
||||
;
|
||||
|
||||
boot_ident :
|
||||
ID { $$ = yylval.str; }
|
||||
boot_ident:
|
||||
ID { $$ = $1; }
|
||||
| OPEN { $$ = pstrdup($1); }
|
||||
| XCLOSE { $$ = pstrdup($1); }
|
||||
| XCREATE { $$ = pstrdup($1); }
|
||||
| INSERT_TUPLE { $$ = pstrdup($1); }
|
||||
| XDECLARE { $$ = pstrdup($1); }
|
||||
| INDEX { $$ = pstrdup($1); }
|
||||
| ON { $$ = pstrdup($1); }
|
||||
| USING { $$ = pstrdup($1); }
|
||||
| XBUILD { $$ = pstrdup($1); }
|
||||
| INDICES { $$ = pstrdup($1); }
|
||||
| UNIQUE { $$ = pstrdup($1); }
|
||||
| XTOAST { $$ = pstrdup($1); }
|
||||
| OBJ_ID { $$ = pstrdup($1); }
|
||||
| XBOOTSTRAP { $$ = pstrdup($1); }
|
||||
| XSHARED_RELATION { $$ = pstrdup($1); }
|
||||
| XWITHOUT_OIDS { $$ = pstrdup($1); }
|
||||
| XROWTYPE_OID { $$ = pstrdup($1); }
|
||||
| XFORCE { $$ = pstrdup($1); }
|
||||
| XNOT { $$ = pstrdup($1); }
|
||||
| XNULL { $$ = pstrdup($1); }
|
||||
;
|
||||
%%
|
||||
|
||||
|
Reference in New Issue
Block a user