blob: 3c9035fcc681193deec802ada3f53188e8fcd1cd [file] [log] [blame]
Guido van Rossum7627c0d2000-03-31 14:58:54 +00001#
2# Secret Labs' Regular Expression Engine
Guido van Rossum7627c0d2000-03-31 14:58:54 +00003#
4# convert template to internal format
5#
Fredrik Lundh770617b2001-01-14 15:06:11 +00006# Copyright (c) 1997-2001 by Secret Labs AB. All rights reserved.
Guido van Rossum7627c0d2000-03-31 14:58:54 +00007#
Fredrik Lundh29c4ba92000-08-01 18:20:07 +00008# See the sre.py file for information on usage and redistribution.
Guido van Rossum7627c0d2000-03-31 14:58:54 +00009#
10
Fred Drakeb8f22742001-09-04 19:10:20 +000011"""Internal support module for sre"""
12
Fredrik Lundh4fb70272002-06-27 20:08:25 +000013import _sre, sys
Guido van Rossum7627c0d2000-03-31 14:58:54 +000014
15from sre_constants import *
16
Fredrik Lundhb35ffc02001-01-15 12:46:09 +000017assert _sre.MAGIC == MAGIC, "SRE module mismatch"
18
Martin v. Löwis78e2f062003-04-19 12:56:08 +000019if _sre.CODESIZE == 2:
20 MAXCODE = 65535
21else:
Guido van Rossume2a383d2007-01-15 16:59:06 +000022 MAXCODE = 0xFFFFFFFF
Fredrik Lundh3562f112000-07-02 12:00:07 +000023
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000024def _identityfunction(x):
25 return x
26
Raymond Hettinger049ade22005-02-28 19:27:52 +000027def set(seq):
28 s = {}
29 for elem in seq:
30 s[elem] = 1
31 return s
32
33_LITERAL_CODES = set([LITERAL, NOT_LITERAL])
34_REPEATING_CODES = set([REPEAT, MIN_REPEAT, MAX_REPEAT])
35_SUCCESS_CODES = set([SUCCESS, FAILURE])
36_ASSERT_CODES = set([ASSERT, ASSERT_NOT])
37
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000038def _compile(code, pattern, flags):
39 # internal: compile a (sub)pattern
40 emit = code.append
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000041 _len = len
Raymond Hettinger049ade22005-02-28 19:27:52 +000042 LITERAL_CODES = _LITERAL_CODES
43 REPEATING_CODES = _REPEATING_CODES
44 SUCCESS_CODES = _SUCCESS_CODES
45 ASSERT_CODES = _ASSERT_CODES
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000046 for op, av in pattern:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000047 if op in LITERAL_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000048 if flags & SRE_FLAG_IGNORECASE:
49 emit(OPCODES[OP_IGNORE[op]])
Fredrik Lundh2e240442001-01-15 18:28:14 +000050 emit(_sre.getlower(av, flags))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000051 else:
52 emit(OPCODES[op])
Fredrik Lundh2e240442001-01-15 18:28:14 +000053 emit(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000054 elif op is IN:
55 if flags & SRE_FLAG_IGNORECASE:
56 emit(OPCODES[OP_IGNORE[op]])
57 def fixup(literal, flags=flags):
58 return _sre.getlower(literal, flags)
59 else:
60 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000061 fixup = _identityfunction
62 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000063 _compile_charset(av, flags, code, fixup)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000064 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000065 elif op is ANY:
66 if flags & SRE_FLAG_DOTALL:
67 emit(OPCODES[ANY_ALL])
68 else:
69 emit(OPCODES[ANY])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000070 elif op in REPEATING_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000071 if flags & SRE_FLAG_TEMPLATE:
72 raise error, "internal: unsupported template operator"
73 emit(OPCODES[REPEAT])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000074 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000075 emit(av[0])
76 emit(av[1])
77 _compile(code, av[2], flags)
78 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000079 code[skip] = _len(code) - skip
80 elif _simple(av) and op is not REPEAT:
81 if op is MAX_REPEAT:
Guido van Rossum41c99e72003-04-14 17:59:34 +000082 emit(OPCODES[REPEAT_ONE])
83 else:
84 emit(OPCODES[MIN_REPEAT_ONE])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000085 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000086 emit(av[0])
87 emit(av[1])
88 _compile(code, av[2], flags)
89 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000090 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000091 else:
92 emit(OPCODES[REPEAT])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000093 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000094 emit(av[0])
95 emit(av[1])
96 _compile(code, av[2], flags)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000097 code[skip] = _len(code) - skip
98 if op is MAX_REPEAT:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000099 emit(OPCODES[MAX_UNTIL])
100 else:
101 emit(OPCODES[MIN_UNTIL])
102 elif op is SUBPATTERN:
103 if av[0]:
104 emit(OPCODES[MARK])
105 emit((av[0]-1)*2)
106 # _compile_info(code, av[1], flags)
107 _compile(code, av[1], flags)
108 if av[0]:
109 emit(OPCODES[MARK])
110 emit((av[0]-1)*2+1)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000111 elif op in SUCCESS_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000112 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000113 elif op in ASSERT_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000114 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000115 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000116 if av[0] >= 0:
117 emit(0) # look ahead
118 else:
119 lo, hi = av[1].getwidth()
120 if lo != hi:
121 raise error, "look-behind requires fixed-width pattern"
122 emit(lo) # look behind
123 _compile(code, av[1], flags)
124 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000125 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000126 elif op is CALL:
127 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000128 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000129 _compile(code, av, flags)
130 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000131 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000132 elif op is AT:
133 emit(OPCODES[op])
134 if flags & SRE_FLAG_MULTILINE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000135 av = AT_MULTILINE.get(av, av)
136 if flags & SRE_FLAG_LOCALE:
137 av = AT_LOCALE.get(av, av)
138 elif flags & SRE_FLAG_UNICODE:
139 av = AT_UNICODE.get(av, av)
140 emit(ATCODES[av])
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000141 elif op is BRANCH:
142 emit(OPCODES[op])
143 tail = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000144 tailappend = tail.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000145 for av in av[1]:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000146 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000147 # _compile_info(code, av, flags)
148 _compile(code, av, flags)
149 emit(OPCODES[JUMP])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000150 tailappend(_len(code)); emit(0)
151 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000152 emit(0) # end of branch
153 for tail in tail:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000154 code[tail] = _len(code) - tail
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000155 elif op is CATEGORY:
156 emit(OPCODES[op])
157 if flags & SRE_FLAG_LOCALE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000158 av = CH_LOCALE[av]
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000159 elif flags & SRE_FLAG_UNICODE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000160 av = CH_UNICODE[av]
161 emit(CHCODES[av])
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000162 elif op is GROUPREF:
163 if flags & SRE_FLAG_IGNORECASE:
164 emit(OPCODES[OP_IGNORE[op]])
165 else:
166 emit(OPCODES[op])
167 emit(av-1)
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000168 elif op is GROUPREF_EXISTS:
169 emit(OPCODES[op])
Andrew M. Kuchlingc30faa82005-06-02 13:35:52 +0000170 emit(av[0]-1)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000171 skipyes = _len(code); emit(0)
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000172 _compile(code, av[1], flags)
173 if av[2]:
174 emit(OPCODES[JUMP])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000175 skipno = _len(code); emit(0)
176 code[skipyes] = _len(code) - skipyes + 1
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000177 _compile(code, av[2], flags)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000178 code[skipno] = _len(code) - skipno
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000179 else:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000180 code[skipyes] = _len(code) - skipyes + 1
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000181 else:
182 raise ValueError, ("unsupported operand type", op)
183
184def _compile_charset(charset, flags, code, fixup=None):
185 # compile charset subprogram
186 emit = code.append
Raymond Hettingerf13eb552002-06-02 00:40:05 +0000187 if fixup is None:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000188 fixup = _identityfunction
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000189 for op, av in _optimize_charset(charset, fixup):
190 emit(OPCODES[op])
191 if op is NEGATE:
192 pass
193 elif op is LITERAL:
194 emit(fixup(av))
195 elif op is RANGE:
196 emit(fixup(av[0]))
197 emit(fixup(av[1]))
198 elif op is CHARSET:
199 code.extend(av)
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000200 elif op is BIGCHARSET:
201 code.extend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000202 elif op is CATEGORY:
203 if flags & SRE_FLAG_LOCALE:
204 emit(CHCODES[CH_LOCALE[av]])
205 elif flags & SRE_FLAG_UNICODE:
206 emit(CHCODES[CH_UNICODE[av]])
207 else:
208 emit(CHCODES[av])
209 else:
210 raise error, "internal: unsupported set operator"
211 emit(OPCODES[FAILURE])
212
213def _optimize_charset(charset, fixup):
214 # internal: optimize character set
Fredrik Lundh3562f112000-07-02 12:00:07 +0000215 out = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000216 outappend = out.append
Raymond Hettingerd732c952004-03-27 09:24:36 +0000217 charmap = [0]*256
Fredrik Lundh3562f112000-07-02 12:00:07 +0000218 try:
219 for op, av in charset:
220 if op is NEGATE:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000221 outappend((op, av))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000222 elif op is LITERAL:
Raymond Hettingerd732c952004-03-27 09:24:36 +0000223 charmap[fixup(av)] = 1
Fredrik Lundh3562f112000-07-02 12:00:07 +0000224 elif op is RANGE:
225 for i in range(fixup(av[0]), fixup(av[1])+1):
Raymond Hettingerd732c952004-03-27 09:24:36 +0000226 charmap[i] = 1
Fredrik Lundh3562f112000-07-02 12:00:07 +0000227 elif op is CATEGORY:
Fredrik Lundh770617b2001-01-14 15:06:11 +0000228 # XXX: could append to charmap tail
Fredrik Lundh3562f112000-07-02 12:00:07 +0000229 return charset # cannot compress
230 except IndexError:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000231 # character set contains unicode characters
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000232 return _optimize_unicode(charset, fixup)
Fredrik Lundh3562f112000-07-02 12:00:07 +0000233 # compress character map
234 i = p = n = 0
235 runs = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000236 runsappend = runs.append
Fredrik Lundh3562f112000-07-02 12:00:07 +0000237 for c in charmap:
238 if c:
239 if n == 0:
240 p = i
241 n = n + 1
242 elif n:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000243 runsappend((p, n))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000244 n = 0
245 i = i + 1
246 if n:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000247 runsappend((p, n))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000248 if len(runs) <= 2:
249 # use literal/range
250 for p, n in runs:
251 if n == 1:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000252 outappend((LITERAL, p))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000253 else:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000254 outappend((RANGE, (p, p+n-1)))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000255 if len(out) < len(charset):
256 return out
257 else:
258 # use bitmap
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000259 data = _mk_bitmap(charmap)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000260 outappend((CHARSET, data))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000261 return out
262 return charset
263
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000264def _mk_bitmap(bits):
265 data = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000266 dataappend = data.append
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000267 if _sre.CODESIZE == 2:
268 start = (1, 0)
269 else:
Guido van Rossume2a383d2007-01-15 16:59:06 +0000270 start = (1, 0)
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000271 m, v = start
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000272 for c in bits:
273 if c:
274 v = v + m
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000275 m = m + m
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000276 if m > MAXCODE:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000277 dataappend(v)
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000278 m, v = start
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000279 return data
280
281# To represent a big charset, first a bitmap of all characters in the
282# set is constructed. Then, this bitmap is sliced into chunks of 256
Guido van Rossum992d4a32007-07-11 13:09:30 +0000283# characters, duplicate chunks are eliminated, and each chunk is
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000284# given a number. In the compiled expression, the charset is
285# represented by a 16-bit word sequence, consisting of one word for
286# the number of different chunks, a sequence of 256 bytes (128 words)
287# of chunk numbers indexed by their original chunk position, and a
288# sequence of chunks (16 words each).
289
290# Compression is normally good: in a typical charset, large ranges of
291# Unicode will be either completely excluded (e.g. if only cyrillic
292# letters are to be matched), or completely included (e.g. if large
293# subranges of Kanji match). These ranges will be represented by
294# chunks of all one-bits or all zero-bits.
295
296# Matching can be also done efficiently: the more significant byte of
297# the Unicode character is an index into the chunk number, and the
298# less significant byte is a bit index in the chunk (just like the
299# CHARSET matching).
300
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000301# In UCS-4 mode, the BIGCHARSET opcode still supports only subsets
302# of the basic multilingual plane; an efficient representation
303# for all of UTF-16 has not yet been developed. This means,
304# in particular, that negated charsets cannot be represented as
305# bigcharsets.
306
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000307def _optimize_unicode(charset, fixup):
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000308 try:
309 import array
310 except ImportError:
311 return charset
Raymond Hettingerd732c952004-03-27 09:24:36 +0000312 charmap = [0]*65536
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000313 negate = 0
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000314 try:
315 for op, av in charset:
316 if op is NEGATE:
317 negate = 1
318 elif op is LITERAL:
Raymond Hettingerd732c952004-03-27 09:24:36 +0000319 charmap[fixup(av)] = 1
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000320 elif op is RANGE:
Guido van Rossum805365e2007-05-07 22:24:25 +0000321 for i in range(fixup(av[0]), fixup(av[1])+1):
Raymond Hettingerd732c952004-03-27 09:24:36 +0000322 charmap[i] = 1
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000323 elif op is CATEGORY:
324 # XXX: could expand category
325 return charset # cannot compress
326 except IndexError:
327 # non-BMP characters
328 return charset
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000329 if negate:
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000330 if sys.maxunicode != 65535:
331 # XXX: negation does not work with big charsets
332 return charset
Guido van Rossum805365e2007-05-07 22:24:25 +0000333 for i in range(65536):
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000334 charmap[i] = not charmap[i]
335 comps = {}
336 mapping = [0]*256
337 block = 0
338 data = []
Guido van Rossum805365e2007-05-07 22:24:25 +0000339 for i in range(256):
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000340 chunk = tuple(charmap[i*256:(i+1)*256])
341 new = comps.setdefault(chunk, block)
342 mapping[i] = new
343 if new == block:
Fredrik Lundh4fb70272002-06-27 20:08:25 +0000344 block = block + 1
345 data = data + _mk_bitmap(chunk)
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000346 header = [block]
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000347 if _sre.CODESIZE == 2:
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000348 code = 'H'
349 else:
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000350 code = 'I'
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000351 # Convert block indices to byte array of 256 bytes
352 mapping = array.array('b', mapping).tostring()
353 # Convert byte array to word array
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000354 mapping = array.array(code, mapping)
355 assert mapping.itemsize == _sre.CODESIZE
Guido van Rossum6b826ab2007-07-03 16:22:09 +0000356 assert len(mapping) * mapping.itemsize == 256
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000357 header = header + mapping.tolist()
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000358 data[0:0] = header
Tim Peters87cc0c32001-07-21 01:41:30 +0000359 return [(BIGCHARSET, data)]
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000360
Fredrik Lundhe1869832000-08-01 22:47:49 +0000361def _simple(av):
362 # check if av is a "simple" operator
363 lo, hi = av[2].getwidth()
Fredrik Lundh13ac9922000-10-07 17:38:23 +0000364 if lo == 0 and hi == MAXREPEAT:
Fredrik Lundhe1869832000-08-01 22:47:49 +0000365 raise error, "nothing to repeat"
366 return lo == hi == 1 and av[2][0][0] != SUBPATTERN
367
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000368def _compile_info(code, pattern, flags):
369 # internal: compile an info block. in the current version,
Fredrik Lundh3562f112000-07-02 12:00:07 +0000370 # this contains min/max pattern width, and an optional literal
371 # prefix or a character map
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000372 lo, hi = pattern.getwidth()
373 if lo == 0:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000374 return # not worth it
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000375 # look for a literal prefix
376 prefix = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000377 prefixappend = prefix.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000378 prefix_skip = 0
Fredrik Lundh3562f112000-07-02 12:00:07 +0000379 charset = [] # not used
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000380 charsetappend = charset.append
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000381 if not (flags & SRE_FLAG_IGNORECASE):
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000382 # look for literal prefix
Fredrik Lundh90a07912000-06-30 07:50:59 +0000383 for op, av in pattern.data:
384 if op is LITERAL:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000385 if len(prefix) == prefix_skip:
386 prefix_skip = prefix_skip + 1
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000387 prefixappend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000388 elif op is SUBPATTERN and len(av[1]) == 1:
389 op, av = av[1][0]
390 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000391 prefixappend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000392 else:
393 break
Fredrik Lundh90a07912000-06-30 07:50:59 +0000394 else:
395 break
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000396 # if no prefix, look for charset prefix
397 if not prefix and pattern.data:
398 op, av = pattern.data[0]
399 if op is SUBPATTERN and av[1]:
400 op, av = av[1][0]
401 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000402 charsetappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000403 elif op is BRANCH:
404 c = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000405 cappend = c.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000406 for p in av[1]:
407 if not p:
408 break
409 op, av = p[0]
410 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000411 cappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000412 else:
413 break
414 else:
415 charset = c
416 elif op is BRANCH:
417 c = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000418 cappend = c.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000419 for p in av[1]:
420 if not p:
421 break
422 op, av = p[0]
423 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000424 cappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000425 else:
426 break
427 else:
428 charset = c
429 elif op is IN:
430 charset = av
431## if prefix:
432## print "*** PREFIX", prefix, prefix_skip
433## if charset:
434## print "*** CHARSET", charset
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000435 # add an info block
436 emit = code.append
437 emit(OPCODES[INFO])
438 skip = len(code); emit(0)
439 # literal flag
440 mask = 0
Fredrik Lundh3562f112000-07-02 12:00:07 +0000441 if prefix:
442 mask = SRE_INFO_PREFIX
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000443 if len(prefix) == prefix_skip == len(pattern.data):
Fredrik Lundh3562f112000-07-02 12:00:07 +0000444 mask = mask + SRE_INFO_LITERAL
445 elif charset:
446 mask = mask + SRE_INFO_CHARSET
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000447 emit(mask)
448 # pattern length
Fredrik Lundh3562f112000-07-02 12:00:07 +0000449 if lo < MAXCODE:
450 emit(lo)
451 else:
452 emit(MAXCODE)
453 prefix = prefix[:MAXCODE]
454 if hi < MAXCODE:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000455 emit(hi)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000456 else:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000457 emit(0)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000458 # add literal prefix
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000459 if prefix:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000460 emit(len(prefix)) # length
461 emit(prefix_skip) # skip
462 code.extend(prefix)
463 # generate overlap table
464 table = [-1] + ([0]*len(prefix))
Guido van Rossum805365e2007-05-07 22:24:25 +0000465 for i in range(len(prefix)):
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000466 table[i+1] = table[i]+1
467 while table[i+1] > 0 and prefix[i] != prefix[table[i+1]-1]:
468 table[i+1] = table[table[i+1]-1]+1
469 code.extend(table[1:]) # don't store first entry
Fredrik Lundh3562f112000-07-02 12:00:07 +0000470 elif charset:
Guido van Rossum577fb5a2003-02-24 01:18:35 +0000471 _compile_charset(charset, flags, code)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000472 code[skip] = len(code) - skip
473
Just van Rossum74902502003-07-02 21:37:16 +0000474def isstring(obj):
Guido van Rossum572dbf82007-04-27 23:53:51 +0000475 return isinstance(obj, basestring)
Just van Rossum74902502003-07-02 21:37:16 +0000476
Fredrik Lundh2f2c67d2000-08-01 21:05:41 +0000477def _code(p, flags):
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000478
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000479 flags = p.pattern.flags | flags
Fredrik Lundhbe2211e2000-06-29 16:57:40 +0000480 code = []
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000481
482 # compile info block
483 _compile_info(code, p, flags)
484
485 # compile the pattern
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000486 _compile(code, p.data, flags)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000487
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000488 code.append(OPCODES[SUCCESS])
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000489
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000490 return code
491
492def compile(p, flags=0):
493 # internal: convert pattern list to internal format
494
Just van Rossum74902502003-07-02 21:37:16 +0000495 if isstring(p):
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000496 import sre_parse
497 pattern = p
498 p = sre_parse.parse(p, flags)
499 else:
500 pattern = None
501
Fredrik Lundh2f2c67d2000-08-01 21:05:41 +0000502 code = _code(p, flags)
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000503
Fredrik Lundh8a3ebf82000-07-23 21:46:17 +0000504 # print code
505
Fredrik Lundh770617b2001-01-14 15:06:11 +0000506 # XXX: <fl> get rid of this limitation!
Fredrik Lundh5e7d51b2004-10-15 06:15:08 +0000507 if p.pattern.groups > 100:
508 raise AssertionError(
509 "sorry, but this version only supports 100 named groups"
510 )
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000511
Fredrik Lundhc2301732000-07-02 22:25:39 +0000512 # map in either direction
513 groupindex = p.pattern.groupdict
514 indexgroup = [None] * p.pattern.groups
515 for k, i in groupindex.items():
516 indexgroup[i] = k
517
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000518 return _sre.compile(
Fredrik Lundh6f013982000-07-03 18:44:21 +0000519 pattern, flags, code,
520 p.pattern.groups-1,
521 groupindex, indexgroup
Fredrik Lundh90a07912000-06-30 07:50:59 +0000522 )