[3.9] bpo-41215: Don't use NULL by default in the PEG parser keyword list (GH-21355) (GH-21356)
(cherry picked from commit 39e76c0fb0
)
Co-authored-by: Pablo Galindo <pablogsal@gmail.com>
Automerge-Triggered-By: @lysnikolaou
This commit is contained in:
parent
4981fe36c7
commit
54f115dd53
|
@ -0,0 +1,2 @@
|
|||
Use non-NULL default values in the PEG parser keyword list to overcome a bug that was preventing
|
||||
Python from being properly compiled when using the XLC compiler. Patch by Pablo Galindo.
|
|
@ -9,8 +9,8 @@ extern int Py_DebugFlag;
|
|||
#endif
|
||||
static const int n_keyword_lists = 15;
|
||||
static KeywordToken *reserved_keywords[] = {
|
||||
NULL,
|
||||
NULL,
|
||||
(KeywordToken[]) {{NULL, -1}},
|
||||
(KeywordToken[]) {{NULL, -1}},
|
||||
(KeywordToken[]) {
|
||||
{"if", 510},
|
||||
{"in", 518},
|
||||
|
@ -65,11 +65,11 @@ static KeywordToken *reserved_keywords[] = {
|
|||
{"nonlocal", 509},
|
||||
{NULL, -1},
|
||||
},
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
(KeywordToken[]) {{NULL, -1}},
|
||||
(KeywordToken[]) {{NULL, -1}},
|
||||
(KeywordToken[]) {{NULL, -1}},
|
||||
(KeywordToken[]) {{NULL, -1}},
|
||||
(KeywordToken[]) {{NULL, -1}},
|
||||
(KeywordToken[]) {
|
||||
{"__peg_parser__", 531},
|
||||
{NULL, -1},
|
||||
|
|
|
@ -525,10 +525,13 @@ _PyPegen_dummy_name(Parser *p, ...)
|
|||
static int
|
||||
_get_keyword_or_name_type(Parser *p, const char *name, int name_len)
|
||||
{
|
||||
if (name_len >= p->n_keyword_lists || p->keywords[name_len] == NULL) {
|
||||
assert(name_len != 0);
|
||||
if (name_len >= p->n_keyword_lists ||
|
||||
p->keywords[name_len] == NULL ||
|
||||
p->keywords[name_len]->type == -1) {
|
||||
return NAME;
|
||||
}
|
||||
for (KeywordToken *k = p->keywords[name_len]; k->type != -1; k++) {
|
||||
for (KeywordToken *k = p->keywords[name_len]; k != NULL && k->type != -1; k++) {
|
||||
if (strncmp(k->str, name, name_len) == 0) {
|
||||
return k->type;
|
||||
}
|
||||
|
|
|
@ -440,7 +440,7 @@ class CParserGenerator(ParserGenerator, GrammarVisitor):
|
|||
num_groups = max(groups) + 1 if groups else 1
|
||||
for keywords_length in range(num_groups):
|
||||
if keywords_length not in groups.keys():
|
||||
self.print("NULL,")
|
||||
self.print("(KeywordToken[]) {{NULL, -1}},")
|
||||
else:
|
||||
self.print("(KeywordToken[]) {")
|
||||
with self.indent():
|
||||
|
|
Loading…
Reference in New Issue