the usual
This commit is contained in:
parent
880066a9cb
commit
c08cb04c29
|
@ -39,7 +39,7 @@ def _compile(code, pattern, flags):
|
|||
return _sre.getlower(literal, flags)
|
||||
else:
|
||||
emit(OPCODES[op])
|
||||
fixup = lambda x: x
|
||||
fixup = lambda x: x
|
||||
skip = len(code); emit(0)
|
||||
for op, av in av:
|
||||
emit(OPCODES[op])
|
||||
|
@ -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
|
||||
|
||||
|
|
|
@ -19,8 +19,9 @@ from sre_constants import *
|
|||
# FIXME: should be 65535, but the arraymodule is still broken
|
||||
MAXREPEAT = 32767
|
||||
|
||||
# FIXME: same here
|
||||
CHARMASK = 0x7fff
|
||||
# FIXME: might change in 2.0 final. but for now, this seems
|
||||
# to be the best way to be compatible with 1.5.2
|
||||
CHARMASK = 0xff
|
||||
|
||||
SPECIAL_CHARS = ".\\[{()*+?^$|"
|
||||
REPEAT_CHARS = "*+?{"
|
||||
|
@ -30,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),
|
||||
|
@ -295,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.
|
||||
|
||||
|
@ -467,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)
|
||||
|
@ -494,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)
|
||||
|
@ -531,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)
|
||||
|
@ -616,9 +618,9 @@ def expand_template(template, match):
|
|||
a = p.append
|
||||
sep = match.string[:0]
|
||||
if type(sep) is type(""):
|
||||
char = chr
|
||||
char = chr
|
||||
else:
|
||||
char = unichr
|
||||
char = unichr
|
||||
for c, s in template:
|
||||
if c is LITERAL:
|
||||
a(char(s))
|
||||
|
|
Loading…
Reference in New Issue