diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2022-03-19 12:13:31 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-03-19 12:13:31 (GMT) |
commit | 4142961b9f5ad3bf93976a6a7162f8049e354018 (patch) | |
tree | 67f64a7584a131766a4015425264d00317fda614 | |
parent | 0a8b8e0d262eae83ffbc6b414a1f5747cdbd1d88 (diff) | |
download | cpython-4142961b9f5ad3bf93976a6a7162f8049e354018.zip cpython-4142961b9f5ad3bf93976a6a7162f8049e354018.tar.gz cpython-4142961b9f5ad3bf93976a6a7162f8049e354018.tar.bz2 |
bpo-39394: Improve warning message in the re module (GH-31988)
A warning about inline flags not at the start of the regular
expression now contains the position of the flag.
-rw-r--r-- | Lib/sre_parse.py | 4 | ||||
-rw-r--r-- | Lib/test/test_re.py | 9 | ||||
-rw-r--r-- | Misc/NEWS.d/next/Library/2022-03-19-13-38-29.bpo-39394.7j6WL6.rst | 2 |
3 files changed, 11 insertions, 4 deletions
diff --git a/Lib/sre_parse.py b/Lib/sre_parse.py index 8311916..5370667 100644 --- a/Lib/sre_parse.py +++ b/Lib/sre_parse.py @@ -807,9 +807,11 @@ def _parse(source, state, verbose, nested, first=False): if not first or subpattern: import warnings warnings.warn( - 'Flags not at the start of the expression %r%s' % ( + 'Flags not at the start of the expression %r%s' + ' but at position %d' % ( source.string[:20], # truncate long regexes ' (truncated)' if len(source.string) > 20 else '', + start, ), DeprecationWarning, stacklevel=nested + 6 ) diff --git a/Lib/test/test_re.py b/Lib/test/test_re.py index 5957596..48dcb16 100644 --- a/Lib/test/test_re.py +++ b/Lib/test/test_re.py @@ -1444,7 +1444,8 @@ class ReTests(unittest.TestCase): self.assertTrue(re.match(p, lower_char)) self.assertEqual( str(warns.warnings[0].message), - 'Flags not at the start of the expression %r' % p + 'Flags not at the start of the expression %r' + ' but at position 1' % p ) self.assertEqual(warns.warnings[0].filename, __file__) @@ -1453,7 +1454,8 @@ class ReTests(unittest.TestCase): self.assertTrue(re.match(p, lower_char)) self.assertEqual( str(warns.warnings[0].message), - 'Flags not at the start of the expression %r (truncated)' % p[:20] + 'Flags not at the start of the expression %r (truncated)' + ' but at position 1' % p[:20] ) self.assertEqual(warns.warnings[0].filename, __file__) @@ -1465,7 +1467,8 @@ class ReTests(unittest.TestCase): self.assertTrue(re.match(p, b'a')) self.assertEqual( str(warns.warnings[0].message), - 'Flags not at the start of the expression %r' % p + 'Flags not at the start of the expression %r' + ' but at position 1' % p ) self.assertEqual(warns.warnings[0].filename, __file__) diff --git a/Misc/NEWS.d/next/Library/2022-03-19-13-38-29.bpo-39394.7j6WL6.rst b/Misc/NEWS.d/next/Library/2022-03-19-13-38-29.bpo-39394.7j6WL6.rst new file mode 100644 index 0000000..9285179 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2022-03-19-13-38-29.bpo-39394.7j6WL6.rst @@ -0,0 +1,2 @@ +A warning about inline flags not at the start of the regular expression now +contains the position of the flag. |