Commit d5e7556e authored by Serhiy Storchaka's avatar Serhiy Storchaka Committed by GitHub

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.
parent 9994eff1
......@@ -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
......
Fixed an "unknown parsing error" on parsing the "<>" operator when run
Python with both options ``-3`` and ``-We``.
......@@ -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;
}
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment