bpo-33645: Fix an "unknown parsing error" in the parser. (GH-7119)

It is reproduced when parse the "<>" operator and run
Python with both options -3 and -We.
This commit is contained in:
Serhiy Storchaka 2018-05-31 07:35:39 +03:00 committed by GitHub
parent 9994eff17f
commit d5e7556e52
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 12 additions and 1 deletions

View File

@ -5,6 +5,7 @@ from test.test_support import run_unittest, check_syntax_error, \
check_py3k_warnings
import unittest
import sys
import warnings
# testing import *
from sys import *
@ -628,7 +629,6 @@ hello world
with check_py3k_warnings((warntext, DeprecationWarning)):
compile(code, '<test string>', 'exec')
if sys.py3kwarning:
import warnings
with warnings.catch_warnings():
warnings.filterwarnings('error', category=DeprecationWarning)
with self.assertRaises(SyntaxError) as cm:
@ -883,6 +883,13 @@ hello world
with check_py3k_warnings(('<> not supported in 3.x; use !=',
DeprecationWarning)):
if eval('1 < 1 > 1 == 1 >= 1 <= 1 <> 1 != 1 in 1 not in 1 is 1 is not 1'): pass
if sys.py3kwarning:
with warnings.catch_warnings():
warnings.filterwarnings('error', category=DeprecationWarning)
with self.assertRaises(DeprecationWarning) as cm:
compile('1 <> 1', '<test string>', 'eval')
self.assertIn('<> not supported in 3.x; use !=',
str(cm.exception))
def test_binary_mask_ops(self):
x = 1 & 1

View File

@ -0,0 +1,2 @@
Fixed an "unknown parsing error" on parsing the "<>" operator when run
Python with both options ``-3`` and ``-We``.

View File

@ -1636,6 +1636,8 @@ tok_get(register struct tok_state *tok, char **p_start, char **p_end)
"<> not supported in 3.x; use !=",
tok->filename, tok->lineno,
NULL, NULL)) {
tok->done = E_ERROR;
tok->cur = tok->inp;
return ERRORTOKEN;
}
}