[Python-checkins] gh-91308: Simplify parsing inline flag "x" (verbose) (GH-91855)

serhiy-storchaka webhook-mailer at python.org
Sat Apr 23 05:50:46 EDT 2022


https://github.com/python/cpython/commit/130a8c386bc1a8de49eadf784fa178869ce01f37
commit: 130a8c386bc1a8de49eadf784fa178869ce01f37
branch: main
author: Serhiy Storchaka <storchaka at gmail.com>
committer: serhiy-storchaka <storchaka at gmail.com>
date: 2022-04-23T12:50:42+03:00
summary:

gh-91308: Simplify parsing inline flag "x" (verbose) (GH-91855)

files:
M Lib/re/_parser.py

diff --git a/Lib/re/_parser.py b/Lib/re/_parser.py
index 60ec3e8ba8bd5..b864bf2b108a6 100644
--- a/Lib/re/_parser.py
+++ b/Lib/re/_parser.py
@@ -67,9 +67,6 @@
 TYPE_FLAGS = SRE_FLAG_ASCII | SRE_FLAG_LOCALE | SRE_FLAG_UNICODE
 GLOBAL_FLAGS = SRE_FLAG_DEBUG
 
-class Verbose(Exception):
-    pass
-
 class State:
     # keeps track of state for parsing
     def __init__(self):
@@ -448,6 +445,8 @@ def _parse_sub(source, state, verbose, nested):
                            not nested and not items))
         if not sourcematch("|"):
             break
+        if not nested:
+            verbose = state.flags & SRE_FLAG_VERBOSE
 
     if len(items) == 1:
         return items[0]
@@ -826,8 +825,7 @@ def _parse(source, state, verbose, nested, first=False):
                             raise source.error('global flags not at the start '
                                                'of the expression',
                                                source.tell() - start)
-                        if (state.flags & SRE_FLAG_VERBOSE) and not verbose:
-                            raise Verbose
+                        verbose = state.flags & SRE_FLAG_VERBOSE
                         continue
 
                     add_flags, del_flags = flags
@@ -963,17 +961,7 @@ def parse(str, flags=0, state=None):
     state.flags = flags
     state.str = str
 
-    try:
-        p = _parse_sub(source, state, flags & SRE_FLAG_VERBOSE, 0)
-    except Verbose:
-        # the VERBOSE flag was switched on inside the pattern.  to be
-        # on the safe side, we'll parse the whole thing again...
-        state = State()
-        state.flags = flags | SRE_FLAG_VERBOSE
-        state.str = str
-        source.seek(0)
-        p = _parse_sub(source, state, True, 0)
-
+    p = _parse_sub(source, state, flags & SRE_FLAG_VERBOSE, 0)
     p.state.flags = fix_flags(str, p.state.flags)
 
     if source.next is not None:



More information about the Python-checkins mailing list