1991-12-31 00:03:05 +08:00
|
|
|
# Provide backward compatibility for module "regexp" using "regex".
|
|
|
|
|
|
|
|
import regex
|
|
|
|
from regex_syntax import *
|
|
|
|
|
|
|
|
class Prog:
|
|
|
|
def init(self, pat):
|
|
|
|
save_syntax = regex.set_syntax(RE_SYNTAX_AWK)
|
|
|
|
try:
|
|
|
|
self.prog = regex.compile(pat)
|
|
|
|
finally:
|
|
|
|
xxx = regex.set_syntax(save_syntax)
|
|
|
|
return self
|
1993-01-04 17:16:51 +08:00
|
|
|
def match(self, *args):
|
|
|
|
if len(args) == 2:
|
1991-12-31 00:03:05 +08:00
|
|
|
str, offset = args
|
1993-01-04 17:16:51 +08:00
|
|
|
elif len(args) == 1:
|
|
|
|
str, offset = args[0], 0
|
1991-12-31 00:03:05 +08:00
|
|
|
else:
|
1993-01-04 17:16:51 +08:00
|
|
|
raise TypeError, 'wrong argument count'
|
1991-12-31 00:03:05 +08:00
|
|
|
if self.prog.search(str, offset) < 0:
|
|
|
|
return ()
|
1992-01-02 03:33:02 +08:00
|
|
|
regs = self.prog.regs
|
1991-12-31 00:03:05 +08:00
|
|
|
i = len(regs)
|
1992-01-02 03:33:02 +08:00
|
|
|
while i > 0 and regs[i-1] == (-1, -1):
|
1991-12-31 00:03:05 +08:00
|
|
|
i = i-1
|
|
|
|
return regs[:i]
|
|
|
|
|
|
|
|
def compile(pat):
|
|
|
|
return Prog().init(pat)
|
|
|
|
|
|
|
|
cache_pat = None
|
|
|
|
cache_prog = None
|
|
|
|
|
|
|
|
def match(pat, str):
|
|
|
|
global cache_pat, cache_prog
|
|
|
|
if pat <> cache_pat:
|
|
|
|
cache_pat, cache_prog = pat, compile(pat)
|
|
|
|
return cache_prog.match(str)
|