]> granicus.if.org Git - python/commitdiff
bpo-30682: Removed a too-strict assertion that failed for certain f-strings. (#2232)
authorericvsmith <ericvsmith@users.noreply.github.com>
Fri, 16 Jun 2017 10:19:32 +0000 (06:19 -0400)
committerSerhiy Storchaka <storchaka@gmail.com>
Fri, 16 Jun 2017 10:19:32 +0000 (13:19 +0300)
This caused a segfault on eval("f'\\\n'") and eval("f'\\\r'") in debug build.

Lib/test/test_fstring.py
Misc/NEWS
Python/ast.c

index b39870457af49268c8c8cad7652a56b71932623c..3d762b5aa9bf6385eeec213f11c09f0d065337ee 100644 (file)
@@ -780,5 +780,11 @@ f'{a * x()}'"""
         self.assertEqual(f'{d["foo"]}', 'bar')
         self.assertEqual(f"{d['foo']}", 'bar')
 
+    def test_backslash_char(self):
+        # Check eval of a backslash followed by a control char.
+        # See bpo-30682: this used to raise an assert in pydebug mode.
+        self.assertEqual(eval('f"\\\n"'), '')
+        self.assertEqual(eval('f"\\\r"'), '')
+
 if __name__ == '__main__':
     unittest.main()
index 8daaeab199401a2df16977bbedbd558c56acd602..bdfe53be957c224c9a8733c4bf0243dfc9d46bea 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,6 +10,9 @@ What's New in Python 3.7.0 alpha 1?
 Core and Builtins
 -----------------
 
+- bpo-30682: Removed a too-strict assertion that failed for certain f-strings,
+  such as eval("f'\\\n'") and eval("f'\\\r'").
+  
 - bpo-30501: The compiler now produces more optimal code for complex condition
   expressions in the "if", "while" and "assert" statement, the "if" expression,
   and generator expressions and comprehensions.
index 7551b6f5655ea38d5b9de1ee0f0582868f3d22d6..becf0addef2139be46d57b9dbd7db2d86549f1af 100644 (file)
@@ -4914,6 +4914,8 @@ FstringParser_ConcatFstring(FstringParser *state, const char **str,
             /* Do nothing. Just leave last_str alone (and possibly
                NULL). */
         } else if (!state->last_str) {
+            /*  Note that the literal can be zero length, if the
+                input string is "\\\n" or "\\\r", among others. */
             state->last_str = literal;
             literal = NULL;
         } else {
@@ -4923,8 +4925,6 @@ FstringParser_ConcatFstring(FstringParser *state, const char **str,
                 return -1;
             literal = NULL;
         }
-        assert(!state->last_str ||
-               PyUnicode_GET_LENGTH(state->last_str) != 0);
 
         /* We've dealt with the literal now. It can't be leaked on further
            errors. */