blob: 90e3a25f1abef55ad3c2908a433fedb01a54bc6d [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
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 Hettinger01c9f8c2004-03-26 11:16:55 +000025def _identityfunction(x):
26 return x
27
Raymond Hettinger049ade22005-02-28 19:27:52 +000028_LITERAL_CODES = set([LITERAL, NOT_LITERAL])
29_REPEATING_CODES = set([REPEAT, MIN_REPEAT, MAX_REPEAT])
30_SUCCESS_CODES = set([SUCCESS, FAILURE])
31_ASSERT_CODES = set([ASSERT, ASSERT_NOT])
32
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000033def _compile(code, pattern, flags):
34 # internal: compile a (sub)pattern
35 emit = code.append
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000036 _len = len
Raymond Hettinger049ade22005-02-28 19:27:52 +000037 LITERAL_CODES = _LITERAL_CODES
38 REPEATING_CODES = _REPEATING_CODES
39 SUCCESS_CODES = _SUCCESS_CODES
40 ASSERT_CODES = _ASSERT_CODES
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000041 for op, av in pattern:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000042 if op in LITERAL_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000043 if flags & SRE_FLAG_IGNORECASE:
44 emit(OPCODES[OP_IGNORE[op]])
Fredrik Lundh2e240442001-01-15 18:28:14 +000045 emit(_sre.getlower(av, flags))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000046 else:
47 emit(OPCODES[op])
Fredrik Lundh2e240442001-01-15 18:28:14 +000048 emit(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000049 elif op is IN:
50 if flags & SRE_FLAG_IGNORECASE:
51 emit(OPCODES[OP_IGNORE[op]])
52 def fixup(literal, flags=flags):
53 return _sre.getlower(literal, flags)
54 else:
55 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000056 fixup = _identityfunction
57 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000058 _compile_charset(av, flags, code, fixup)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000059 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000060 elif op is ANY:
61 if flags & SRE_FLAG_DOTALL:
62 emit(OPCODES[ANY_ALL])
63 else:
64 emit(OPCODES[ANY])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000065 elif op in REPEATING_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000066 if flags & SRE_FLAG_TEMPLATE:
Collin Winterce36ad82007-08-30 01:19:48 +000067 raise error("internal: unsupported template operator")
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000068 emit(OPCODES[REPEAT])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000069 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000070 emit(av[0])
71 emit(av[1])
72 _compile(code, av[2], flags)
73 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000074 code[skip] = _len(code) - skip
75 elif _simple(av) and op is not REPEAT:
76 if op is MAX_REPEAT:
Guido van Rossum41c99e72003-04-14 17:59:34 +000077 emit(OPCODES[REPEAT_ONE])
78 else:
79 emit(OPCODES[MIN_REPEAT_ONE])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000080 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000081 emit(av[0])
82 emit(av[1])
83 _compile(code, av[2], flags)
84 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000085 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000086 else:
87 emit(OPCODES[REPEAT])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000088 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000089 emit(av[0])
90 emit(av[1])
91 _compile(code, av[2], flags)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +000092 code[skip] = _len(code) - skip
93 if op is MAX_REPEAT:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +000094 emit(OPCODES[MAX_UNTIL])
95 else:
96 emit(OPCODES[MIN_UNTIL])
97 elif op is SUBPATTERN:
98 if av[0]:
99 emit(OPCODES[MARK])
100 emit((av[0]-1)*2)
101 # _compile_info(code, av[1], flags)
102 _compile(code, av[1], flags)
103 if av[0]:
104 emit(OPCODES[MARK])
105 emit((av[0]-1)*2+1)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000106 elif op in SUCCESS_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000107 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000108 elif op in ASSERT_CODES:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000109 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000110 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000111 if av[0] >= 0:
112 emit(0) # look ahead
113 else:
114 lo, hi = av[1].getwidth()
115 if lo != hi:
Collin Winterce36ad82007-08-30 01:19:48 +0000116 raise error("look-behind requires fixed-width pattern")
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000117 emit(lo) # look behind
118 _compile(code, av[1], flags)
119 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000120 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000121 elif op is CALL:
122 emit(OPCODES[op])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000123 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000124 _compile(code, av, flags)
125 emit(OPCODES[SUCCESS])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000126 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000127 elif op is AT:
128 emit(OPCODES[op])
129 if flags & SRE_FLAG_MULTILINE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000130 av = AT_MULTILINE.get(av, av)
131 if flags & SRE_FLAG_LOCALE:
132 av = AT_LOCALE.get(av, av)
133 elif flags & SRE_FLAG_UNICODE:
134 av = AT_UNICODE.get(av, av)
135 emit(ATCODES[av])
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000136 elif op is BRANCH:
137 emit(OPCODES[op])
138 tail = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000139 tailappend = tail.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000140 for av in av[1]:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000141 skip = _len(code); emit(0)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000142 # _compile_info(code, av, flags)
143 _compile(code, av, flags)
144 emit(OPCODES[JUMP])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000145 tailappend(_len(code)); emit(0)
146 code[skip] = _len(code) - skip
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000147 emit(0) # end of branch
148 for tail in tail:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000149 code[tail] = _len(code) - tail
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000150 elif op is CATEGORY:
151 emit(OPCODES[op])
152 if flags & SRE_FLAG_LOCALE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000153 av = CH_LOCALE[av]
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000154 elif flags & SRE_FLAG_UNICODE:
Fredrik Lundhb25e1ad2001-03-22 15:50:10 +0000155 av = CH_UNICODE[av]
156 emit(CHCODES[av])
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000157 elif op is GROUPREF:
158 if flags & SRE_FLAG_IGNORECASE:
159 emit(OPCODES[OP_IGNORE[op]])
160 else:
161 emit(OPCODES[op])
162 emit(av-1)
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000163 elif op is GROUPREF_EXISTS:
164 emit(OPCODES[op])
Andrew M. Kuchlingc30faa82005-06-02 13:35:52 +0000165 emit(av[0]-1)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000166 skipyes = _len(code); emit(0)
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000167 _compile(code, av[1], flags)
168 if av[2]:
169 emit(OPCODES[JUMP])
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000170 skipno = _len(code); emit(0)
171 code[skipyes] = _len(code) - skipyes + 1
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000172 _compile(code, av[2], flags)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000173 code[skipno] = _len(code) - skipno
Gustavo Niemeyerad3fc442003-10-17 22:13:16 +0000174 else:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000175 code[skipyes] = _len(code) - skipyes + 1
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000176 else:
Collin Winterce36ad82007-08-30 01:19:48 +0000177 raise ValueError("unsupported operand type", op)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000178
179def _compile_charset(charset, flags, code, fixup=None):
180 # compile charset subprogram
181 emit = code.append
Raymond Hettingerf13eb552002-06-02 00:40:05 +0000182 if fixup is None:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000183 fixup = _identityfunction
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000184 for op, av in _optimize_charset(charset, fixup):
185 emit(OPCODES[op])
186 if op is NEGATE:
187 pass
188 elif op is LITERAL:
189 emit(fixup(av))
190 elif op is RANGE:
191 emit(fixup(av[0]))
192 emit(fixup(av[1]))
193 elif op is CHARSET:
194 code.extend(av)
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000195 elif op is BIGCHARSET:
196 code.extend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000197 elif op is CATEGORY:
198 if flags & SRE_FLAG_LOCALE:
199 emit(CHCODES[CH_LOCALE[av]])
200 elif flags & SRE_FLAG_UNICODE:
201 emit(CHCODES[CH_UNICODE[av]])
202 else:
203 emit(CHCODES[av])
204 else:
Collin Winterce36ad82007-08-30 01:19:48 +0000205 raise error("internal: unsupported set operator")
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000206 emit(OPCODES[FAILURE])
207
208def _optimize_charset(charset, fixup):
209 # internal: optimize character set
Fredrik Lundh3562f112000-07-02 12:00:07 +0000210 out = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000211 outappend = out.append
Raymond Hettingerd732c952004-03-27 09:24:36 +0000212 charmap = [0]*256
Fredrik Lundh3562f112000-07-02 12:00:07 +0000213 try:
214 for op, av in charset:
215 if op is NEGATE:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000216 outappend((op, av))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000217 elif op is LITERAL:
Raymond Hettingerd732c952004-03-27 09:24:36 +0000218 charmap[fixup(av)] = 1
Fredrik Lundh3562f112000-07-02 12:00:07 +0000219 elif op is RANGE:
220 for i in range(fixup(av[0]), fixup(av[1])+1):
Raymond Hettingerd732c952004-03-27 09:24:36 +0000221 charmap[i] = 1
Fredrik Lundh3562f112000-07-02 12:00:07 +0000222 elif op is CATEGORY:
Fredrik Lundh770617b2001-01-14 15:06:11 +0000223 # XXX: could append to charmap tail
Fredrik Lundh3562f112000-07-02 12:00:07 +0000224 return charset # cannot compress
225 except IndexError:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000226 # character set contains unicode characters
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000227 return _optimize_unicode(charset, fixup)
Fredrik Lundh3562f112000-07-02 12:00:07 +0000228 # compress character map
229 i = p = n = 0
230 runs = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000231 runsappend = runs.append
Fredrik Lundh3562f112000-07-02 12:00:07 +0000232 for c in charmap:
233 if c:
234 if n == 0:
235 p = i
236 n = n + 1
237 elif n:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000238 runsappend((p, n))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000239 n = 0
240 i = i + 1
241 if n:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000242 runsappend((p, n))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000243 if len(runs) <= 2:
244 # use literal/range
245 for p, n in runs:
246 if n == 1:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000247 outappend((LITERAL, p))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000248 else:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000249 outappend((RANGE, (p, p+n-1)))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000250 if len(out) < len(charset):
251 return out
252 else:
253 # use bitmap
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000254 data = _mk_bitmap(charmap)
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000255 outappend((CHARSET, data))
Fredrik Lundh3562f112000-07-02 12:00:07 +0000256 return out
257 return charset
258
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000259def _mk_bitmap(bits):
260 data = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000261 dataappend = data.append
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000262 if _sre.CODESIZE == 2:
263 start = (1, 0)
264 else:
Guido van Rossume2a383d2007-01-15 16:59:06 +0000265 start = (1, 0)
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000266 m, v = start
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000267 for c in bits:
268 if c:
269 v = v + m
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000270 m = m + m
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000271 if m > MAXCODE:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000272 dataappend(v)
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000273 m, v = start
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000274 return data
275
276# To represent a big charset, first a bitmap of all characters in the
277# set is constructed. Then, this bitmap is sliced into chunks of 256
Guido van Rossum992d4a32007-07-11 13:09:30 +0000278# characters, duplicate chunks are eliminated, and each chunk is
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000279# given a number. In the compiled expression, the charset is
280# represented by a 16-bit word sequence, consisting of one word for
281# the number of different chunks, a sequence of 256 bytes (128 words)
282# of chunk numbers indexed by their original chunk position, and a
283# sequence of chunks (16 words each).
284
285# Compression is normally good: in a typical charset, large ranges of
286# Unicode will be either completely excluded (e.g. if only cyrillic
287# letters are to be matched), or completely included (e.g. if large
288# subranges of Kanji match). These ranges will be represented by
289# chunks of all one-bits or all zero-bits.
290
291# Matching can be also done efficiently: the more significant byte of
292# the Unicode character is an index into the chunk number, and the
293# less significant byte is a bit index in the chunk (just like the
294# CHARSET matching).
295
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000296# In UCS-4 mode, the BIGCHARSET opcode still supports only subsets
297# of the basic multilingual plane; an efficient representation
298# for all of UTF-16 has not yet been developed. This means,
299# in particular, that negated charsets cannot be represented as
300# bigcharsets.
301
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000302def _optimize_unicode(charset, fixup):
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000303 try:
304 import array
305 except ImportError:
306 return charset
Raymond Hettingerd732c952004-03-27 09:24:36 +0000307 charmap = [0]*65536
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000308 negate = 0
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000309 try:
310 for op, av in charset:
311 if op is NEGATE:
312 negate = 1
313 elif op is LITERAL:
Raymond Hettingerd732c952004-03-27 09:24:36 +0000314 charmap[fixup(av)] = 1
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000315 elif op is RANGE:
Guido van Rossum805365e2007-05-07 22:24:25 +0000316 for i in range(fixup(av[0]), fixup(av[1])+1):
Raymond Hettingerd732c952004-03-27 09:24:36 +0000317 charmap[i] = 1
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000318 elif op is CATEGORY:
319 # XXX: could expand category
320 return charset # cannot compress
321 except IndexError:
Ezio Melottia9860ae2011-10-04 19:06:00 +0300322 # non-BMP characters; XXX now they should work
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000323 return charset
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000324 if negate:
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000325 if sys.maxunicode != 65535:
326 # XXX: negation does not work with big charsets
Ezio Melottia9860ae2011-10-04 19:06:00 +0300327 # XXX2: now they should work, but removing this will make the
328 # charmap 17 times bigger
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000329 return charset
Guido van Rossum805365e2007-05-07 22:24:25 +0000330 for i in range(65536):
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000331 charmap[i] = not charmap[i]
332 comps = {}
333 mapping = [0]*256
334 block = 0
335 data = []
Guido van Rossum805365e2007-05-07 22:24:25 +0000336 for i in range(256):
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000337 chunk = tuple(charmap[i*256:(i+1)*256])
338 new = comps.setdefault(chunk, block)
339 mapping[i] = new
340 if new == block:
Fredrik Lundh4fb70272002-06-27 20:08:25 +0000341 block = block + 1
342 data = data + _mk_bitmap(chunk)
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000343 header = [block]
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000344 if _sre.CODESIZE == 2:
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000345 code = 'H'
346 else:
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000347 code = 'I'
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000348 # Convert block indices to byte array of 256 bytes
Antoine Pitrou1ce3eb52010-09-01 20:29:34 +0000349 mapping = array.array('b', mapping).tobytes()
Martin v. Löwis78e2f062003-04-19 12:56:08 +0000350 # Convert byte array to word array
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000351 mapping = array.array(code, mapping)
352 assert mapping.itemsize == _sre.CODESIZE
Guido van Rossum6b826ab2007-07-03 16:22:09 +0000353 assert len(mapping) * mapping.itemsize == 256
Martin v. Löwis7d9c6c72004-05-07 07:18:13 +0000354 header = header + mapping.tolist()
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000355 data[0:0] = header
Tim Peters87cc0c32001-07-21 01:41:30 +0000356 return [(BIGCHARSET, data)]
Fredrik Lundh19af43d2001-07-02 16:58:38 +0000357
Fredrik Lundhe1869832000-08-01 22:47:49 +0000358def _simple(av):
359 # check if av is a "simple" operator
360 lo, hi = av[2].getwidth()
Fredrik Lundh13ac9922000-10-07 17:38:23 +0000361 if lo == 0 and hi == MAXREPEAT:
Collin Winterce36ad82007-08-30 01:19:48 +0000362 raise error("nothing to repeat")
Fredrik Lundhe1869832000-08-01 22:47:49 +0000363 return lo == hi == 1 and av[2][0][0] != SUBPATTERN
364
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000365def _compile_info(code, pattern, flags):
366 # internal: compile an info block. in the current version,
Fredrik Lundh3562f112000-07-02 12:00:07 +0000367 # this contains min/max pattern width, and an optional literal
368 # prefix or a character map
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000369 lo, hi = pattern.getwidth()
370 if lo == 0:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000371 return # not worth it
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000372 # look for a literal prefix
373 prefix = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000374 prefixappend = prefix.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000375 prefix_skip = 0
Fredrik Lundh3562f112000-07-02 12:00:07 +0000376 charset = [] # not used
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000377 charsetappend = charset.append
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000378 if not (flags & SRE_FLAG_IGNORECASE):
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000379 # look for literal prefix
Fredrik Lundh90a07912000-06-30 07:50:59 +0000380 for op, av in pattern.data:
381 if op is LITERAL:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000382 if len(prefix) == prefix_skip:
383 prefix_skip = prefix_skip + 1
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000384 prefixappend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000385 elif op is SUBPATTERN and len(av[1]) == 1:
386 op, av = av[1][0]
387 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000388 prefixappend(av)
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000389 else:
390 break
Fredrik Lundh90a07912000-06-30 07:50:59 +0000391 else:
392 break
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000393 # if no prefix, look for charset prefix
394 if not prefix and pattern.data:
395 op, av = pattern.data[0]
396 if op is SUBPATTERN and av[1]:
397 op, av = av[1][0]
398 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000399 charsetappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000400 elif op is BRANCH:
401 c = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000402 cappend = c.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000403 for p in av[1]:
404 if not p:
405 break
406 op, av = p[0]
407 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000408 cappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000409 else:
410 break
411 else:
412 charset = c
413 elif op is BRANCH:
414 c = []
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000415 cappend = c.append
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000416 for p in av[1]:
417 if not p:
418 break
419 op, av = p[0]
420 if op is LITERAL:
Raymond Hettinger01c9f8c2004-03-26 11:16:55 +0000421 cappend((op, av))
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000422 else:
423 break
424 else:
425 charset = c
426 elif op is IN:
427 charset = av
428## if prefix:
429## print "*** PREFIX", prefix, prefix_skip
430## if charset:
431## print "*** CHARSET", charset
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000432 # add an info block
433 emit = code.append
434 emit(OPCODES[INFO])
435 skip = len(code); emit(0)
436 # literal flag
437 mask = 0
Fredrik Lundh3562f112000-07-02 12:00:07 +0000438 if prefix:
439 mask = SRE_INFO_PREFIX
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000440 if len(prefix) == prefix_skip == len(pattern.data):
Fredrik Lundh3562f112000-07-02 12:00:07 +0000441 mask = mask + SRE_INFO_LITERAL
442 elif charset:
443 mask = mask + SRE_INFO_CHARSET
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000444 emit(mask)
445 # pattern length
Fredrik Lundh3562f112000-07-02 12:00:07 +0000446 if lo < MAXCODE:
447 emit(lo)
448 else:
449 emit(MAXCODE)
450 prefix = prefix[:MAXCODE]
451 if hi < MAXCODE:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000452 emit(hi)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000453 else:
Fredrik Lundh90a07912000-06-30 07:50:59 +0000454 emit(0)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000455 # add literal prefix
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000456 if prefix:
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000457 emit(len(prefix)) # length
458 emit(prefix_skip) # skip
459 code.extend(prefix)
460 # generate overlap table
461 table = [-1] + ([0]*len(prefix))
Guido van Rossum805365e2007-05-07 22:24:25 +0000462 for i in range(len(prefix)):
Fredrik Lundh7898c3e2000-08-07 20:59:04 +0000463 table[i+1] = table[i]+1
464 while table[i+1] > 0 and prefix[i] != prefix[table[i+1]-1]:
465 table[i+1] = table[table[i+1]-1]+1
466 code.extend(table[1:]) # don't store first entry
Fredrik Lundh3562f112000-07-02 12:00:07 +0000467 elif charset:
Guido van Rossum577fb5a2003-02-24 01:18:35 +0000468 _compile_charset(charset, flags, code)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000469 code[skip] = len(code) - skip
470
Just van Rossum74902502003-07-02 21:37:16 +0000471def isstring(obj):
Thomas Wouters40a088d2008-03-18 20:19:54 +0000472 return isinstance(obj, (str, bytes))
Just van Rossum74902502003-07-02 21:37:16 +0000473
Fredrik Lundh2f2c67d2000-08-01 21:05:41 +0000474def _code(p, flags):
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000475
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000476 flags = p.pattern.flags | flags
Fredrik Lundhbe2211e2000-06-29 16:57:40 +0000477 code = []
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000478
479 # compile info block
480 _compile_info(code, p, flags)
481
482 # compile the pattern
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000483 _compile(code, p.data, flags)
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000484
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000485 code.append(OPCODES[SUCCESS])
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000486
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000487 return code
488
489def compile(p, flags=0):
490 # internal: convert pattern list to internal format
491
Just van Rossum74902502003-07-02 21:37:16 +0000492 if isstring(p):
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000493 pattern = p
494 p = sre_parse.parse(p, flags)
495 else:
496 pattern = None
497
Fredrik Lundh2f2c67d2000-08-01 21:05:41 +0000498 code = _code(p, flags)
Fredrik Lundh29c4ba92000-08-01 18:20:07 +0000499
Fredrik Lundh8a3ebf82000-07-23 21:46:17 +0000500 # print code
501
Fredrik Lundh770617b2001-01-14 15:06:11 +0000502 # XXX: <fl> get rid of this limitation!
Fredrik Lundh5e7d51b2004-10-15 06:15:08 +0000503 if p.pattern.groups > 100:
504 raise AssertionError(
505 "sorry, but this version only supports 100 named groups"
506 )
Fredrik Lundh29c08be2000-06-29 23:33:12 +0000507
Fredrik Lundhc2301732000-07-02 22:25:39 +0000508 # map in either direction
509 groupindex = p.pattern.groupdict
510 indexgroup = [None] * p.pattern.groups
511 for k, i in groupindex.items():
512 indexgroup[i] = k
513
Jeremy Hyltonb1aa1952000-06-01 17:39:12 +0000514 return _sre.compile(
Christian Heimes072c0f12008-01-03 23:01:04 +0000515 pattern, flags | p.pattern.flags, code,
Fredrik Lundh6f013982000-07-03 18:44:21 +0000516 p.pattern.groups-1,
517 groupindex, indexgroup
Fredrik Lundh90a07912000-06-30 07:50:59 +0000518 )