Commit 62e895c4 authored by Martin v. Löwis's avatar Martin v. Löwis

Defer compilation of regular expressions until first use.

parent 7fcc46c7
...@@ -209,9 +209,12 @@ def grok_environment_error (exc, prefix="error: "): ...@@ -209,9 +209,12 @@ def grok_environment_error (exc, prefix="error: "):
# Needed by 'split_quoted()' # Needed by 'split_quoted()'
_wordchars_re = re.compile(r'[^\\\'\"%s ]*' % string.whitespace) _wordchars_re = _squote_re = _dquote_re = None
_squote_re = re.compile(r"'(?:[^'\\]|\\.)*'") def _init_regex():
_dquote_re = re.compile(r'"(?:[^"\\]|\\.)*"') global _wordchars_re, _squote_re, _dquote_re
_wordchars_re = re.compile(r'[^\\\'\"%s ]*' % string.whitespace)
_squote_re = re.compile(r"'(?:[^'\\]|\\.)*'")
_dquote_re = re.compile(r'"(?:[^"\\]|\\.)*"')
def split_quoted (s): def split_quoted (s):
"""Split a string up according to Unix shell-like rules for quotes and """Split a string up according to Unix shell-like rules for quotes and
...@@ -227,6 +230,7 @@ def split_quoted (s): ...@@ -227,6 +230,7 @@ def split_quoted (s):
# This is a nice algorithm for splitting up a single string, since it # This is a nice algorithm for splitting up a single string, since it
# doesn't require character-by-character examination. It was a little # doesn't require character-by-character examination. It was a little
# bit of a brain-bender to get it working right, though... # bit of a brain-bender to get it working right, though...
if _wordchars_re is None: _init_regex()
s = string.strip(s) s = string.strip(s)
words = [] words = []
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment