Kaydet (Commit) 55a4f4a5 authored tarafından Fredrik Lundh's avatar Fredrik Lundh

- fixed code generation error in multiline mode

- fixed parser flag propagation (of all stupid bugs...)
üst 361b583e
......@@ -118,7 +118,7 @@ def _compile(code, pattern, flags):
elif op is AT:
emit(OPCODES[op])
if flags & SRE_FLAG_MULTILINE:
emit(ATCODES[AT_MULTILINE[av]])
emit(ATCODES[AT_MULTILINE.get(av, av)])
else:
emit(ATCODES[av])
elif op is BRANCH:
......@@ -203,7 +203,7 @@ def compile(p, flags=0):
if type(p) in (type(""), type(u"")):
import sre_parse
pattern = p
p = sre_parse.parse(p)
p = sre_parse.parse(p, flags)
else:
pattern = None
......
......@@ -31,7 +31,7 @@ DIGITS = tuple(string.digits)
OCTDIGITS = tuple("01234567")
HEXDIGITS = tuple("0123456789abcdefABCDEF")
WHITESPACE = string.whitespace
WHITESPACE = tuple(string.whitespace)
ESCAPES = {
r"\a": (LITERAL, 7),
......@@ -296,7 +296,7 @@ def _branch(pattern, items):
subpattern.append((BRANCH, (None, items)))
return subpattern
def _parse(source, state, flags=0):
def _parse(source, state):
# parse regular expression pattern into an operator list.
......@@ -468,7 +468,7 @@ def _parse(source, state, flags=0):
char = source.get()
b = []
while 1:
p = _parse(source, state, flags)
p = _parse(source, state)
if source.next == ")":
if b:
b.append(p)
......@@ -495,7 +495,7 @@ def _parse(source, state, flags=0):
else:
group = state.getgroup(name)
while 1:
p = _parse(source, state, flags)
p = _parse(source, state)
if source.match(")"):
if b:
b.append(p)
......@@ -532,9 +532,10 @@ def parse(pattern, flags=0):
# parse 're' pattern into list of (opcode, argument) tuples
source = Tokenizer(pattern)
state = State()
state.flags = flags
b = []
while 1:
p = _parse(source, state, flags)
p = _parse(source, state)
tail = source.get()
if tail == "|":
b.append(p)
......
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