mirror of
https://github.com/python/cpython.git
synced 2025-10-22 22:53:06 +00:00
Issue #17825: Cursor ^ is correctly positioned for SyntaxError and IndentationError.
This commit is contained in:
parent
6b2e5597e1
commit
758fa5ea81
3 changed files with 21 additions and 7 deletions
|
@ -35,6 +35,9 @@ class SyntaxTracebackCases(unittest.TestCase):
|
||||||
def syntax_error_with_caret_non_ascii(self):
|
def syntax_error_with_caret_non_ascii(self):
|
||||||
compile('Python = "\u1e54\xfd\u0163\u0125\xf2\xf1" +', "?", "exec")
|
compile('Python = "\u1e54\xfd\u0163\u0125\xf2\xf1" +', "?", "exec")
|
||||||
|
|
||||||
|
def syntax_error_bad_indentation2(self):
|
||||||
|
compile(" print(2)", "?", "exec")
|
||||||
|
|
||||||
def test_caret(self):
|
def test_caret(self):
|
||||||
err = self.get_exception_format(self.syntax_error_with_caret,
|
err = self.get_exception_format(self.syntax_error_with_caret,
|
||||||
SyntaxError)
|
SyntaxError)
|
||||||
|
@ -46,14 +49,14 @@ class SyntaxTracebackCases(unittest.TestCase):
|
||||||
err = self.get_exception_format(self.syntax_error_with_caret_2,
|
err = self.get_exception_format(self.syntax_error_with_caret_2,
|
||||||
SyntaxError)
|
SyntaxError)
|
||||||
self.assertIn("^", err[2]) # third line has caret
|
self.assertIn("^", err[2]) # third line has caret
|
||||||
self.assertTrue(err[2].count('\n') == 1) # and no additional newline
|
self.assertEqual(err[2].count('\n'), 1) # and no additional newline
|
||||||
self.assertTrue(err[1].find("+") == err[2].find("^")) # in the right place
|
self.assertEqual(err[1].find("+"), err[2].find("^")) # in the right place
|
||||||
|
|
||||||
err = self.get_exception_format(self.syntax_error_with_caret_non_ascii,
|
err = self.get_exception_format(self.syntax_error_with_caret_non_ascii,
|
||||||
SyntaxError)
|
SyntaxError)
|
||||||
self.assertIn("^", err[2]) # third line has caret
|
self.assertIn("^", err[2]) # third line has caret
|
||||||
self.assertTrue(err[2].count('\n') == 1) # and no additional newline
|
self.assertEqual(err[2].count('\n'), 1) # and no additional newline
|
||||||
self.assertTrue(err[1].find("+") == err[2].find("^")) # in the right place
|
self.assertEqual(err[1].find("+"), err[2].find("^")) # in the right place
|
||||||
|
|
||||||
def test_nocaret(self):
|
def test_nocaret(self):
|
||||||
exc = SyntaxError("error", ("x.py", 23, None, "bad syntax"))
|
exc = SyntaxError("error", ("x.py", 23, None, "bad syntax"))
|
||||||
|
@ -69,6 +72,13 @@ class SyntaxTracebackCases(unittest.TestCase):
|
||||||
self.assertIn("^", err[2])
|
self.assertIn("^", err[2])
|
||||||
self.assertEqual(err[1].find(")"), err[2].find("^"))
|
self.assertEqual(err[1].find(")"), err[2].find("^"))
|
||||||
|
|
||||||
|
err = self.get_exception_format(self.syntax_error_bad_indentation2,
|
||||||
|
IndentationError)
|
||||||
|
self.assertEqual(len(err), 4)
|
||||||
|
self.assertEqual(err[1].strip(), "print(2)")
|
||||||
|
self.assertIn("^", err[2])
|
||||||
|
self.assertEqual(err[1].find("p"), err[2].find("^"))
|
||||||
|
|
||||||
def test_base_exception(self):
|
def test_base_exception(self):
|
||||||
# Test that exceptions derived from BaseException are formatted right
|
# Test that exceptions derived from BaseException are formatted right
|
||||||
e = KeyboardInterrupt()
|
e = KeyboardInterrupt()
|
||||||
|
|
|
@ -227,11 +227,12 @@ def format_exception_only(etype, value):
|
||||||
if badline is not None:
|
if badline is not None:
|
||||||
lines.append(' %s\n' % badline.strip())
|
lines.append(' %s\n' % badline.strip())
|
||||||
if offset is not None:
|
if offset is not None:
|
||||||
caretspace = badline.rstrip('\n')[:offset].lstrip()
|
caretspace = badline.rstrip('\n')
|
||||||
|
offset = min(len(caretspace), offset) - 1
|
||||||
|
caretspace = caretspace[:offset].lstrip()
|
||||||
# non-space whitespace (likes tabs) must be kept for alignment
|
# non-space whitespace (likes tabs) must be kept for alignment
|
||||||
caretspace = ((c.isspace() and c or ' ') for c in caretspace)
|
caretspace = ((c.isspace() and c or ' ') for c in caretspace)
|
||||||
# only three spaces to account for offset1 == pos 0
|
lines.append(' %s^\n' % ''.join(caretspace))
|
||||||
lines.append(' %s^\n' % ''.join(caretspace))
|
|
||||||
msg = value.msg or "<no detail available>"
|
msg = value.msg or "<no detail available>"
|
||||||
lines.append("%s: %s\n" % (stype, msg))
|
lines.append("%s: %s\n" % (stype, msg))
|
||||||
return lines
|
return lines
|
||||||
|
|
|
@ -10,6 +10,9 @@ What's New in Python 3.3.4 release candidate 1?
|
||||||
Core and Builtins
|
Core and Builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- Issue #17825: Cursor "^" is correctly positioned for SyntaxError and
|
||||||
|
IndentationError.
|
||||||
|
|
||||||
- Issue #2382: SyntaxError cursor "^" is now written at correct position in most
|
- Issue #2382: SyntaxError cursor "^" is now written at correct position in most
|
||||||
cases when multibyte characters are in line (before "^"). This still not
|
cases when multibyte characters are in line (before "^"). This still not
|
||||||
works correctly with wide East Asian characters.
|
works correctly with wide East Asian characters.
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue