diff options
Diffstat (limited to 'src/backend/bootstrap/bootscanner.l')
-rw-r--r-- | src/backend/bootstrap/bootscanner.l | 127 |
1 files changed, 127 insertions, 0 deletions
diff --git a/src/backend/bootstrap/bootscanner.l b/src/backend/bootstrap/bootscanner.l new file mode 100644 index 0000000..7aecd89 --- /dev/null +++ b/src/backend/bootstrap/bootscanner.l @@ -0,0 +1,127 @@ +%{ +/*------------------------------------------------------------------------- + * + * bootscanner.l + * a lexical scanner for the bootstrap parser + * + * Portions Copyright (c) 1996-2021, PostgreSQL Global Development Group + * Portions Copyright (c) 1994, Regents of the University of California + * + * + * IDENTIFICATION + * src/backend/bootstrap/bootscanner.l + * + *------------------------------------------------------------------------- + */ +#include "postgres.h" + +#include "bootstrap/bootstrap.h" +#include "utils/guc.h" + +/* Not needed now that this file is compiled as part of bootparse. */ +/* #include "bootparse.h" */ + +/* LCOV_EXCL_START */ + +/* Avoid exit() on fatal scanner errors (a bit ugly -- see yy_fatal_error) */ +#undef fprintf +#define fprintf(file, fmt, msg) fprintf_to_ereport(fmt, msg) + +static void +fprintf_to_ereport(const char *fmt, const char *msg) +{ + ereport(ERROR, (errmsg_internal("%s", msg))); +} + + +static int yyline = 1; /* line number for error reporting */ + +%} + +%option 8bit +%option never-interactive +%option nodefault +%option noinput +%option nounput +%option noyywrap +%option warn +%option prefix="boot_yy" + + +id [-A-Za-z0-9_]+ +sid \'([^']|\'\')*\' + +/* + * Keyword tokens return the keyword text (as a constant string) in yylval.kw, + * just in case that's needed because we want to treat the keyword as an + * unreserved identifier. Note that _null_ is not treated as a keyword + * for this purpose; it's the one "reserved word" in the bootstrap syntax. + * + * Notice that all the keywords are case-sensitive, and for historical + * reasons some must be upper case. + * + * String tokens return a palloc'd string in yylval.str. + */ + +%% + +open { yylval.kw = "open"; return OPEN; } + +close { yylval.kw = "close"; return XCLOSE; } + +create { yylval.kw = "create"; return XCREATE; } + +OID { yylval.kw = "OID"; return OBJ_ID; } +bootstrap { yylval.kw = "bootstrap"; return XBOOTSTRAP; } +shared_relation { yylval.kw = "shared_relation"; return XSHARED_RELATION; } +rowtype_oid { yylval.kw = "rowtype_oid"; return XROWTYPE_OID; } + +insert { yylval.kw = "insert"; return INSERT_TUPLE; } + +_null_ { return NULLVAL; } + +"," { return COMMA; } +"=" { return EQUALS; } +"(" { return LPAREN; } +")" { return RPAREN; } + +[\n] { yyline++; } +[\r\t ] ; + +^\#[^\n]* ; /* drop everything after "#" for comments */ + +declare { yylval.kw = "declare"; return XDECLARE; } +build { yylval.kw = "build"; return XBUILD; } +indices { yylval.kw = "indices"; return INDICES; } +unique { yylval.kw = "unique"; return UNIQUE; } +index { yylval.kw = "index"; return INDEX; } +on { yylval.kw = "on"; return ON; } +using { yylval.kw = "using"; return USING; } +toast { yylval.kw = "toast"; return XTOAST; } +FORCE { yylval.kw = "FORCE"; return XFORCE; } +NOT { yylval.kw = "NOT"; return XNOT; } +NULL { yylval.kw = "NULL"; return XNULL; } + +{id} { + yylval.str = pstrdup(yytext); + return ID; + } +{sid} { + /* strip quotes and escapes */ + yylval.str = DeescapeQuotedString(yytext); + return ID; + } + +. { + elog(ERROR, "syntax error at line %d: unexpected character \"%s\"", yyline, yytext); + } + +%% + +/* LCOV_EXCL_STOP */ + +void +yyerror(const char *message) +{ + elog(ERROR, "%s at line %d", message, yyline); +} |