summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnthony Sottile <asottile@umich.edu>2019-07-29 13:59:13 (GMT)
committerPablo Galindo <Pablogsal@gmail.com>2019-07-29 13:59:13 (GMT)
commit5b94f3578c662d5f1ee90c0e6b81481d9ec82d89 (patch)
tree3f57146c75113283e71a598108cfb4d7295443bb
parente1b900247227dad49d8231f1d028872412230ab4 (diff)
downloadcpython-5b94f3578c662d5f1ee90c0e6b81481d9ec82d89.zip
cpython-5b94f3578c662d5f1ee90c0e6b81481d9ec82d89.tar.gz
cpython-5b94f3578c662d5f1ee90c0e6b81481d9ec82d89.tar.bz2
Fix `SyntaxError` indicator printing too many spaces for multi-line strings (GH-14433)
-rw-r--r--Lib/test/test_cmd_line_script.py14
-rw-r--r--Misc/NEWS.d/next/Core and Builtins/2019-06-27-15-01-14.bpo-37433.amNGqr.rst1
-rw-r--r--Parser/tokenizer.c2
3 files changed, 17 insertions, 0 deletions
diff --git a/Lib/test/test_cmd_line_script.py b/Lib/test/test_cmd_line_script.py
index 4677e60..633e0fd 100644
--- a/Lib/test/test_cmd_line_script.py
+++ b/Lib/test/test_cmd_line_script.py
@@ -613,6 +613,20 @@ class CmdLineTest(unittest.TestCase):
self.assertNotIn("\f", text)
self.assertIn("\n 1 + 1 = 2\n ^", text)
+ def test_syntaxerror_multi_line_fstring(self):
+ script = 'foo = f"""{}\nfoo"""\n'
+ with support.temp_dir() as script_dir:
+ script_name = _make_test_script(script_dir, 'script', script)
+ exitcode, stdout, stderr = assert_python_failure(script_name)
+ self.assertEqual(
+ stderr.splitlines()[-3:],
+ [
+ b' foo = f"""{}',
+ b' ^',
+ b'SyntaxError: f-string: empty expression not allowed',
+ ],
+ )
+
def test_consistent_sys_path_for_direct_execution(self):
# This test case ensures that the following all give the same
# sys.path configuration:
diff --git a/Misc/NEWS.d/next/Core and Builtins/2019-06-27-15-01-14.bpo-37433.amNGqr.rst b/Misc/NEWS.d/next/Core and Builtins/2019-06-27-15-01-14.bpo-37433.amNGqr.rst
new file mode 100644
index 0000000..794ddbb
--- /dev/null
+++ b/Misc/NEWS.d/next/Core and Builtins/2019-06-27-15-01-14.bpo-37433.amNGqr.rst
@@ -0,0 +1 @@
+Fix ``SyntaxError`` indicator printing too many spaces for multi-line strings - by Anthony Sottile.
diff --git a/Parser/tokenizer.c b/Parser/tokenizer.c
index c2ec659..31fe970 100644
--- a/Parser/tokenizer.c
+++ b/Parser/tokenizer.c
@@ -956,6 +956,7 @@ tok_nextc(struct tok_state *tok)
while (!done) {
Py_ssize_t curstart = tok->start == NULL ? -1 :
tok->start - tok->buf;
+ Py_ssize_t cur_multi_line_start = tok->multi_line_start - tok->buf;
Py_ssize_t curvalid = tok->inp - tok->buf;
Py_ssize_t newsize = curvalid + BUFSIZ;
char *newbuf = tok->buf;
@@ -968,6 +969,7 @@ tok_nextc(struct tok_state *tok)
}
tok->buf = newbuf;
tok->cur = tok->buf + cur;
+ tok->multi_line_start = tok->buf + cur_multi_line_start;
tok->line_start = tok->cur;
tok->inp = tok->buf + curvalid;
tok->end = tok->buf + newsize;