blob: f24f6819ef7653ee996e8ed64102bbfcb3eb9542 [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
Victor Stinner7fa767e2014-03-20 09:16:38 +010013import _sre
Christian Heimes5e696852008-04-09 08:37:03 +000014import sre_parse
Guido van Rossum7627c0d2000-03-31 14:58:54 +000015from sre_constants import *
Serhiy Storchaka70ca0212013-02-16 16:47:47 +020016from _sre import MAXREPEAT
Guido van Rossum7627c0d2000-03-31 14:58:54 +000017
Fredrik Lundhb35ffc02001-01-15 12:46:09 +000018assert _sre.MAGIC == MAGIC, "SRE module mismatch"
19
Martin v. Löwis78e2f062003-04-19 12:56:08 +000020if _sre.CODESIZE == 2:
21 MAXCODE = 65535
22else:
Guido van Rossume2a383d2007-01-15 16:59:06 +000023 MAXCODE = 0xFFFFFFFF
Fredrik Lundh3562f112000-07-02 12:00:07 +000024
Raymond Hettinger049ade22005-02-28 19:27:52 +000025_LITERAL_CODES = set([LITERAL, NOT_LITERAL])
26_REPEATING_CODES = set([REPEAT, MIN_REPEAT, MAX_REPEAT])
27_SUCCESS_CODES = set([SUCCESS, FAILURE])
28_ASSERT_CODES = set([ASSERT, ASSERT_NOT])
29
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000030def _compile(code, pattern, flags):
31 # internal: compile a (sub)pattern
32 emit = code.append
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000033 _len = len
Raymond Hettinger049ade22005-02-28 19:27:52 +000034 LITERAL_CODES = _LITERAL_CODES
35 REPEATING_CODES = _REPEATING_CODES
36 SUCCESS_CODES = _SUCCESS_CODES
37 ASSERT_CODES = _ASSERT_CODES
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000038 for op, av in pattern:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000039 if op in LITERAL_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000040 if flags & SRE_FLAG_IGNORECASE:
41 emit(OPCODES[OP_IGNORE[op]])
Fredrik Lundh2e240442001-01-15 18:28:14 +000042 emit(_sre.getlower(av, flags))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000043 else:
44 emit(OPCODES[op])
Fredrik Lundh2e240442001-01-15 18:28:14 +000045 emit(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000046 elif op is IN:
47 if flags & SRE_FLAG_IGNORECASE:
48 emit(OPCODES[OP_IGNORE[op]])
49 def fixup(literal, flags=flags):
50 return _sre.getlower(literal, flags)
51 else:
52 emit(OPCODES[op])
Serhiy Storchakab1847e72014-10-31 12:37:50 +020053 fixup = None
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000054 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000055 _compile_charset(av, flags, code, fixup)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000056 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000057 elif op is ANY:
58 if flags & SRE_FLAG_DOTALL:
59 emit(OPCODES[ANY_ALL])
60 else:
61 emit(OPCODES[ANY])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000062 elif op in REPEATING_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000063 if flags & SRE_FLAG_TEMPLATE:
Collin Winterce36ad82007-08-30 01:19:48 +000064 raise error("internal: unsupported template operator")
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000065 elif _simple(av) and op is not REPEAT:
66 if op is MAX_REPEAT:
Guido van Rossum41c99e72003-04-14 17:59:34 +000067 emit(OPCODES[REPEAT_ONE])
68 else:
69 emit(OPCODES[MIN_REPEAT_ONE])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000070 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000071 emit(av[0])
72 emit(av[1])
73 _compile(code, av[2], flags)
74 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000075 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000076 else:
77 emit(OPCODES[REPEAT])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000078 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000079 emit(av[0])
80 emit(av[1])
81 _compile(code, av[2], flags)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000082 code[skip] = _len(code) - skip
83 if op is MAX_REPEAT:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000084 emit(OPCODES[MAX_UNTIL])
85 else:
86 emit(OPCODES[MIN_UNTIL])
87 elif op is SUBPATTERN:
88 if av[0]:
89 emit(OPCODES[MARK])
90 emit((av[0]-1)*2)
91 # _compile_info(code, av[1], flags)
92 _compile(code, av[1], flags)
93 if av[0]:
94 emit(OPCODES[MARK])
95 emit((av[0]-1)*2+1)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000096 elif op in SUCCESS_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000097 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000098 elif op in ASSERT_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000099 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000100 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000101 if av[0] >= 0:
102 emit(0) # look ahead
103 else:
104 lo, hi = av[1].getwidth()
105 if lo != hi:
Collin Winterce36ad82007-08-30 01:19:48 +0000106 raise error("look-behind requires fixed-width pattern")
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000107 emit(lo) # look behind
108 _compile(code, av[1], flags)
109 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000110 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000111 elif op is CALL:
112 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000113 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000114 _compile(code, av, flags)
115 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000116 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000117 elif op is AT:
118 emit(OPCODES[op])
119 if flags & SRE_FLAG_MULTILINE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000120 av = AT_MULTILINE.get(av, av)
121 if flags & SRE_FLAG_LOCALE:
122 av = AT_LOCALE.get(av, av)
123 elif flags & SRE_FLAG_UNICODE:
124 av = AT_UNICODE.get(av, av)
125 emit(ATCODES[av])
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000126 elif op is BRANCH:
127 emit(OPCODES[op])
128 tail = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000129 tailappend = tail.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000130 for av in av[1]:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000131 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000132 # _compile_info(code, av, flags)
133 _compile(code, av, flags)
134 emit(OPCODES[JUMP])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000135 tailappend(_len(code)); emit(0)
136 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000137 emit(0) # end of branch
138 for tail in tail:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000139 code[tail] = _len(code) - tail
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000140 elif op is CATEGORY:
141 emit(OPCODES[op])
142 if flags & SRE_FLAG_LOCALE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000143 av = CH_LOCALE[av]
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000144 elif flags & SRE_FLAG_UNICODE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000145 av = CH_UNICODE[av]
146 emit(CHCODES[av])
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000147 elif op is GROUPREF:
148 if flags & SRE_FLAG_IGNORECASE:
149 emit(OPCODES[OP_IGNORE[op]])
150 else:
151 emit(OPCODES[op])
152 emit(av-1)
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000153 elif op is GROUPREF_EXISTS:
154 emit(OPCODES[op])
Andrew M. Kuchlingc30faa82005-06-02 13:35:52 +0000155 emit(av[0]-1)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000156 skipyes = _len(code); emit(0)
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000157 _compile(code, av[1], flags)
158 if av[2]:
159 emit(OPCODES[JUMP])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000160 skipno = _len(code); emit(0)
161 code[skipyes] = _len(code) - skipyes + 1
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000162 _compile(code, av[2], flags)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000163 code[skipno] = _len(code) - skipno
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000164 else:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000165 code[skipyes] = _len(code) - skipyes + 1
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000166 else:
Collin Winterce36ad82007-08-30 01:19:48 +0000167 raise ValueError("unsupported operand type", op)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000168
169def _compile_charset(charset, flags, code, fixup=None):
170 # compile charset subprogram
171 emit = code.append
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200172 for op, av in _optimize_charset(charset, fixup, flags & SRE_FLAG_UNICODE):
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000173 emit(OPCODES[op])
174 if op is NEGATE:
175 pass
176 elif op is LITERAL:
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200177 emit(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000178 elif op is RANGE:
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200179 emit(av[0])
180 emit(av[1])
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000181 elif op is CHARSET:
182 code.extend(av)
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000183 elif op is BIGCHARSET:
184 code.extend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000185 elif op is CATEGORY:
186 if flags & SRE_FLAG_LOCALE:
187 emit(CHCODES[CH_LOCALE[av]])
188 elif flags & SRE_FLAG_UNICODE:
189 emit(CHCODES[CH_UNICODE[av]])
190 else:
191 emit(CHCODES[av])
192 else:
Collin Winterce36ad82007-08-30 01:19:48 +0000193 raise error("internal: unsupported set operator")
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000194 emit(OPCODES[FAILURE])
195
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200196def _optimize_charset(charset, fixup, isunicode):
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000197 # internal: optimize character set
Fredrik Lundh3562f112000-07-02 12:00:07 +0000198 out = []
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200199 tail = []
200 charmap = bytearray(256)
201 for op, av in charset:
202 while True:
203 try:
204 if op is LITERAL:
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200205 i = av
206 if fixup:
207 i = fixup(i)
208 charmap[i] = 1
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200209 elif op is RANGE:
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200210 r = range(av[0], av[1]+1)
211 if fixup:
212 r = map(fixup, r)
213 for i in r:
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200214 charmap[i] = 1
215 elif op is NEGATE:
216 out.append((op, av))
217 else:
218 tail.append((op, av))
219 except IndexError:
220 if len(charmap) == 256:
221 # character set contains non-UCS1 character codes
222 charmap += b'\0' * 0xff00
223 continue
224 # character set contains non-BMP character codes
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200225 if fixup and isunicode and op is RANGE:
226 lo, hi = av
227 ranges = [av]
228 # There are only two ranges of cased astral characters:
229 # 10400-1044F (Deseret) and 118A0-118DF (Warang Citi).
230 _fixup_range(max(0x10000, lo), min(0x11fff, hi),
231 ranges, fixup)
232 for lo, hi in ranges:
233 if lo == hi:
234 tail.append((LITERAL, hi))
235 else:
236 tail.append((RANGE, (lo, hi)))
237 else:
238 tail.append((op, av))
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200239 break
240
Fredrik Lundh3562f112000-07-02 12:00:07 +0000241 # compress character map
Fredrik Lundh3562f112000-07-02 12:00:07 +0000242 runs = []
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200243 q = 0
244 while True:
245 p = charmap.find(1, q)
246 if p < 0:
247 break
248 if len(runs) >= 2:
249 runs = None
250 break
251 q = charmap.find(0, p)
252 if q < 0:
253 runs.append((p, len(charmap)))
254 break
255 runs.append((p, q))
256 if runs is not None:
Fredrik Lundh3562f112000-07-02 12:00:07 +0000257 # use literal/range
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200258 for p, q in runs:
259 if q - p == 1:
260 out.append((LITERAL, p))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000261 else:
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200262 out.append((RANGE, (p, q - 1)))
263 out += tail
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200264 # if the case was changed or new representation is more compact
265 if fixup or len(out) < len(charset):
Fredrik Lundh3562f112000-07-02 12:00:07 +0000266 return out
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200267 # else original character set is good enough
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200268 return charset
269
270 # use bitmap
271 if len(charmap) == 256:
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000272 data = _mk_bitmap(charmap)
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200273 out.append((CHARSET, data))
274 out += tail
Fredrik Lundh3562f112000-07-02 12:00:07 +0000275 return out
Fredrik Lundh3562f112000-07-02 12:00:07 +0000276
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200277 # To represent a big charset, first a bitmap of all characters in the
278 # set is constructed. Then, this bitmap is sliced into chunks of 256
279 # characters, duplicate chunks are eliminated, and each chunk is
280 # given a number. In the compiled expression, the charset is
281 # represented by a 32-bit word sequence, consisting of one word for
282 # the number of different chunks, a sequence of 256 bytes (64 words)
283 # of chunk numbers indexed by their original chunk position, and a
284 # sequence of 256-bit chunks (8 words each).
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000285
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200286 # Compression is normally good: in a typical charset, large ranges of
287 # Unicode will be either completely excluded (e.g. if only cyrillic
288 # letters are to be matched), or completely included (e.g. if large
289 # subranges of Kanji match). These ranges will be represented by
290 # chunks of all one-bits or all zero-bits.
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000291
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200292 # Matching can be also done efficiently: the more significant byte of
293 # the Unicode character is an index into the chunk number, and the
294 # less significant byte is a bit index in the chunk (just like the
295 # CHARSET matching).
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000296
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200297 charmap = bytes(charmap) # should be hashable
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000298 comps = {}
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200299 mapping = bytearray(256)
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000300 block = 0
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200301 data = bytearray()
302 for i in range(0, 65536, 256):
303 chunk = charmap[i: i + 256]
304 if chunk in comps:
305 mapping[i // 256] = comps[chunk]
306 else:
307 mapping[i // 256] = comps[chunk] = block
308 block += 1
309 data += chunk
310 data = _mk_bitmap(data)
311 data[0:0] = [block] + _bytes_to_codes(mapping)
312 out.append((BIGCHARSET, data))
313 out += tail
314 return out
315
Serhiy Storchakab1847e72014-10-31 12:37:50 +0200316def _fixup_range(lo, hi, ranges, fixup):
317 for i in map(fixup, range(lo, hi+1)):
318 for k, (lo, hi) in enumerate(ranges):
319 if i < lo:
320 if l == lo - 1:
321 ranges[k] = (i, hi)
322 else:
323 ranges.insert(k, (i, i))
324 break
325 elif i > hi:
326 if i == hi + 1:
327 ranges[k] = (lo, i)
328 break
329 else:
330 break
331 else:
332 ranges.append((i, i))
333
Serhiy Storchaka68457be2013-10-27 08:20:29 +0200334_CODEBITS = _sre.CODESIZE * 8
335_BITS_TRANS = b'0' + b'1' * 255
336def _mk_bitmap(bits, _CODEBITS=_CODEBITS, _int=int):
337 s = bits.translate(_BITS_TRANS)[::-1]
338 return [_int(s[i - _CODEBITS: i], 2)
339 for i in range(len(s), 0, -_CODEBITS)]
340
341def _bytes_to_codes(b):
342 # Convert block indices to word array
343 import array
344 a = array.array('I', b)
345 assert a.itemsize == _sre.CODESIZE
346 assert len(a) * a.itemsize == len(b)
347 return a.tolist()
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000348
Fredrik Lundhe1869832000-08-01 22:47:49 +0000349def _simple(av):
350 # check if av is a "simple" operator
351 lo, hi = av[2].getwidth()
Fredrik Lundhe1869832000-08-01 22:47:49 +0000352 return lo == hi == 1 and av[2][0][0] != SUBPATTERN
353
Antoine Pitrou79aa68d2013-10-25 21:36:10 +0200354def _generate_overlap_table(prefix):
355 """
356 Generate an overlap table for the following prefix.
357 An overlap table is a table of the same size as the prefix which
358 informs about the potential self-overlap for each index in the prefix:
359 - if overlap[i] == 0, prefix[i:] can't overlap prefix[0:...]
360 - if overlap[i] == k with 0 < k <= i, prefix[i-k+1:i+1] overlaps with
361 prefix[0:k]
362 """
363 table = [0] * len(prefix)
364 for i in range(1, len(prefix)):
365 idx = table[i - 1]
366 while prefix[i] != prefix[idx]:
367 if idx == 0:
368 table[i] = 0
369 break
370 idx = table[idx - 1]
371 else:
372 table[i] = idx + 1
373 return table
374
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000375def _compile_info(code, pattern, flags):
376 # internal: compile an info block. in the current version,
Fredrik Lundh3562f112000-07-02 12:00:07 +0000377 # this contains min/max pattern width, and an optional literal
378 # prefix or a character map
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000379 lo, hi = pattern.getwidth()
380 if lo == 0:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000381 return # not worth it
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000382 # look for a literal prefix
383 prefix = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000384 prefixappend = prefix.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000385 prefix_skip = 0
Fredrik Lundh3562f112000-07-02 12:00:07 +0000386 charset = [] # not used
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000387 charsetappend = charset.append
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000388 if not (flags & SRE_FLAG_IGNORECASE):
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000389 # look for literal prefix
Fredrik Lundh90a07912000-06-30 07:50:59 +0000390 for op, av in pattern.data:
391 if op is LITERAL:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000392 if len(prefix) == prefix_skip:
393 prefix_skip = prefix_skip + 1
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000394 prefixappend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000395 elif op is SUBPATTERN and len(av[1]) == 1:
396 op, av = av[1][0]
397 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000398 prefixappend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000399 else:
400 break
Fredrik Lundh90a07912000-06-30 07:50:59 +0000401 else:
402 break
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000403 # if no prefix, look for charset prefix
404 if not prefix and pattern.data:
405 op, av = pattern.data[0]
406 if op is SUBPATTERN and av[1]:
407 op, av = av[1][0]
408 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000409 charsetappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000410 elif op is BRANCH:
411 c = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000412 cappend = c.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000413 for p in av[1]:
414 if not p:
415 break
416 op, av = p[0]
417 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000418 cappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000419 else:
420 break
421 else:
422 charset = c
423 elif op is BRANCH:
424 c = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000425 cappend = c.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000426 for p in av[1]:
427 if not p:
428 break
429 op, av = p[0]
430 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000431 cappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000432 else:
433 break
434 else:
435 charset = c
436 elif op is IN:
437 charset = av
438## if prefix:
439## print "*** PREFIX", prefix, prefix_skip
440## if charset:
441## print "*** CHARSET", charset
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000442 # add an info block
443 emit = code.append
444 emit(OPCODES[INFO])
445 skip = len(code); emit(0)
446 # literal flag
447 mask = 0
Fredrik Lundh3562f112000-07-02 12:00:07 +0000448 if prefix:
449 mask = SRE_INFO_PREFIX
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000450 if len(prefix) == prefix_skip == len(pattern.data):
Fredrik Lundh3562f112000-07-02 12:00:07 +0000451 mask = mask + SRE_INFO_LITERAL
452 elif charset:
453 mask = mask + SRE_INFO_CHARSET
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000454 emit(mask)
455 # pattern length
Fredrik Lundh3562f112000-07-02 12:00:07 +0000456 if lo < MAXCODE:
457 emit(lo)
458 else:
459 emit(MAXCODE)
460 prefix = prefix[:MAXCODE]
461 if hi < MAXCODE:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000462 emit(hi)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000463 else:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000464 emit(0)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000465 # add literal prefix
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000466 if prefix:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000467 emit(len(prefix)) # length
468 emit(prefix_skip) # skip
469 code.extend(prefix)
470 # generate overlap table
Antoine Pitrou79aa68d2013-10-25 21:36:10 +0200471 code.extend(_generate_overlap_table(prefix))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000472 elif charset:
Guido van Rossum577fb5a2003-02-24 01:18:35 +0000473 _compile_charset(charset, flags, code)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000474 code[skip] = len(code) - skip
475
Just van Rossum74902502003-07-02 21:37:16 +0000476def isstring(obj):
Thomas Wouters40a088d2008-03-18 20:19:54 +0000477 return isinstance(obj, (str, bytes))
Just van Rossum74902502003-07-02 21:37:16 +0000478
Fredrik Lundh2f2c67d2000-08-01 21:05:41 +0000479def _code(p, flags):
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000480
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000481 flags = p.pattern.flags | flags
Fredrik Lundhbe2211e2000-06-29 16:57:40 +0000482 code = []
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000483
484 # compile info block
485 _compile_info(code, p, flags)
486
487 # compile the pattern
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000488 _compile(code, p.data, flags)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000489
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000490 code.append(OPCODES[SUCCESS])
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000491
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000492 return code
493
494def compile(p, flags=0):
495 # internal: convert pattern list to internal format
496
Just van Rossum74902502003-07-02 21:37:16 +0000497 if isstring(p):
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000498 pattern = p
499 p = sre_parse.parse(p, flags)
500 else:
501 pattern = None
502
Fredrik Lundh2f2c67d2000-08-01 21:05:41 +0000503 code = _code(p, flags)
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000504
Fredrik Lundh8a3ebf82000-07-23 21:46:17 +0000505 # print code
506
Fredrik Lundh770617b2001-01-14 15:06:11 +0000507 # XXX: <fl> get rid of this limitation!
Fredrik Lundh5e7d51b2004-10-15 06:15:08 +0000508 if p.pattern.groups > 100:
509 raise AssertionError(
510 "sorry, but this version only supports 100 named groups"
511 )
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000512
Fredrik Lundhc2301732000-07-02 22:25:39 +0000513 # map in either direction
514 groupindex = p.pattern.groupdict
515 indexgroup = [None] * p.pattern.groups
516 for k, i in groupindex.items():
517 indexgroup[i] = k
518
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000519 return _sre.compile(
Christian Heimes072c0f12008-01-03 23:01:04 +0000520 pattern, flags | p.pattern.flags, code,
Fredrik Lundh6f013982000-07-03 18:44:21 +0000521 p.pattern.groups-1,
522 groupindex, indexgroup
Fredrik Lundh90a07912000-06-30 07:50:59 +0000523 )