xref: /aosp_15_r20/external/pcre/src/pcre2_pattern_info.c (revision 22dc650d8ae982c6770746019a6f94af92b0f024)
1*22dc650dSSadaf Ebrahimi /*************************************************
2*22dc650dSSadaf Ebrahimi *      Perl-Compatible Regular Expressions       *
3*22dc650dSSadaf Ebrahimi *************************************************/
4*22dc650dSSadaf Ebrahimi 
5*22dc650dSSadaf Ebrahimi /* PCRE is a library of functions to support regular expressions whose syntax
6*22dc650dSSadaf Ebrahimi and semantics are as close as possible to those of the Perl 5 language.
7*22dc650dSSadaf Ebrahimi 
8*22dc650dSSadaf Ebrahimi                        Written by Philip Hazel
9*22dc650dSSadaf Ebrahimi      Original API code Copyright (c) 1997-2012 University of Cambridge
10*22dc650dSSadaf Ebrahimi           New API code Copyright (c) 2016-2018 University of Cambridge
11*22dc650dSSadaf Ebrahimi 
12*22dc650dSSadaf Ebrahimi -----------------------------------------------------------------------------
13*22dc650dSSadaf Ebrahimi Redistribution and use in source and binary forms, with or without
14*22dc650dSSadaf Ebrahimi modification, are permitted provided that the following conditions are met:
15*22dc650dSSadaf Ebrahimi 
16*22dc650dSSadaf Ebrahimi     * Redistributions of source code must retain the above copyright notice,
17*22dc650dSSadaf Ebrahimi       this list of conditions and the following disclaimer.
18*22dc650dSSadaf Ebrahimi 
19*22dc650dSSadaf Ebrahimi     * Redistributions in binary form must reproduce the above copyright
20*22dc650dSSadaf Ebrahimi       notice, this list of conditions and the following disclaimer in the
21*22dc650dSSadaf Ebrahimi       documentation and/or other materials provided with the distribution.
22*22dc650dSSadaf Ebrahimi 
23*22dc650dSSadaf Ebrahimi     * Neither the name of the University of Cambridge nor the names of its
24*22dc650dSSadaf Ebrahimi       contributors may be used to endorse or promote products derived from
25*22dc650dSSadaf Ebrahimi       this software without specific prior written permission.
26*22dc650dSSadaf Ebrahimi 
27*22dc650dSSadaf Ebrahimi THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
28*22dc650dSSadaf Ebrahimi AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
29*22dc650dSSadaf Ebrahimi IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
30*22dc650dSSadaf Ebrahimi ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
31*22dc650dSSadaf Ebrahimi LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
32*22dc650dSSadaf Ebrahimi CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
33*22dc650dSSadaf Ebrahimi SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
34*22dc650dSSadaf Ebrahimi INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
35*22dc650dSSadaf Ebrahimi CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
36*22dc650dSSadaf Ebrahimi ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
37*22dc650dSSadaf Ebrahimi POSSIBILITY OF SUCH DAMAGE.
38*22dc650dSSadaf Ebrahimi -----------------------------------------------------------------------------
39*22dc650dSSadaf Ebrahimi */
40*22dc650dSSadaf Ebrahimi 
41*22dc650dSSadaf Ebrahimi 
42*22dc650dSSadaf Ebrahimi #ifdef HAVE_CONFIG_H
43*22dc650dSSadaf Ebrahimi #include "config.h"
44*22dc650dSSadaf Ebrahimi #endif
45*22dc650dSSadaf Ebrahimi 
46*22dc650dSSadaf Ebrahimi #include "pcre2_internal.h"
47*22dc650dSSadaf Ebrahimi 
48*22dc650dSSadaf Ebrahimi 
49*22dc650dSSadaf Ebrahimi /*************************************************
50*22dc650dSSadaf Ebrahimi *        Return info about compiled pattern      *
51*22dc650dSSadaf Ebrahimi *************************************************/
52*22dc650dSSadaf Ebrahimi 
53*22dc650dSSadaf Ebrahimi /*
54*22dc650dSSadaf Ebrahimi Arguments:
55*22dc650dSSadaf Ebrahimi   code          points to compiled code
56*22dc650dSSadaf Ebrahimi   what          what information is required
57*22dc650dSSadaf Ebrahimi   where         where to put the information; if NULL, return length
58*22dc650dSSadaf Ebrahimi 
59*22dc650dSSadaf Ebrahimi Returns:        0 when data returned
60*22dc650dSSadaf Ebrahimi                 > 0 when length requested
61*22dc650dSSadaf Ebrahimi                 < 0 on error or unset value
62*22dc650dSSadaf Ebrahimi */
63*22dc650dSSadaf Ebrahimi 
64*22dc650dSSadaf Ebrahimi PCRE2_EXP_DEFN int PCRE2_CALL_CONVENTION
pcre2_pattern_info(const pcre2_code * code,uint32_t what,void * where)65*22dc650dSSadaf Ebrahimi pcre2_pattern_info(const pcre2_code *code, uint32_t what, void *where)
66*22dc650dSSadaf Ebrahimi {
67*22dc650dSSadaf Ebrahimi const pcre2_real_code *re = (pcre2_real_code *)code;
68*22dc650dSSadaf Ebrahimi 
69*22dc650dSSadaf Ebrahimi if (where == NULL)   /* Requests field length */
70*22dc650dSSadaf Ebrahimi   {
71*22dc650dSSadaf Ebrahimi   switch(what)
72*22dc650dSSadaf Ebrahimi     {
73*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_ALLOPTIONS:
74*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_ARGOPTIONS:
75*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_BACKREFMAX:
76*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_BSR:
77*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_CAPTURECOUNT:
78*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_DEPTHLIMIT:
79*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_EXTRAOPTIONS:
80*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_FIRSTCODETYPE:
81*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_FIRSTCODEUNIT:
82*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_HASBACKSLASHC:
83*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_HASCRORLF:
84*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_HEAPLIMIT:
85*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_JCHANGED:
86*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_LASTCODETYPE:
87*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_LASTCODEUNIT:
88*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_MATCHEMPTY:
89*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_MATCHLIMIT:
90*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_MAXLOOKBEHIND:
91*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_MINLENGTH:
92*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_NAMEENTRYSIZE:
93*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_NAMECOUNT:
94*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_NEWLINE:
95*22dc650dSSadaf Ebrahimi     return sizeof(uint32_t);
96*22dc650dSSadaf Ebrahimi 
97*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_FIRSTBITMAP:
98*22dc650dSSadaf Ebrahimi     return sizeof(const uint8_t *);
99*22dc650dSSadaf Ebrahimi 
100*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_JITSIZE:
101*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_SIZE:
102*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_FRAMESIZE:
103*22dc650dSSadaf Ebrahimi     return sizeof(size_t);
104*22dc650dSSadaf Ebrahimi 
105*22dc650dSSadaf Ebrahimi     case PCRE2_INFO_NAMETABLE:
106*22dc650dSSadaf Ebrahimi     return sizeof(PCRE2_SPTR);
107*22dc650dSSadaf Ebrahimi     }
108*22dc650dSSadaf Ebrahimi   }
109*22dc650dSSadaf Ebrahimi 
110*22dc650dSSadaf Ebrahimi if (re == NULL) return PCRE2_ERROR_NULL;
111*22dc650dSSadaf Ebrahimi 
112*22dc650dSSadaf Ebrahimi /* Check that the first field in the block is the magic number. If it is not,
113*22dc650dSSadaf Ebrahimi return with PCRE2_ERROR_BADMAGIC. */
114*22dc650dSSadaf Ebrahimi 
115*22dc650dSSadaf Ebrahimi if (re->magic_number != MAGIC_NUMBER) return PCRE2_ERROR_BADMAGIC;
116*22dc650dSSadaf Ebrahimi 
117*22dc650dSSadaf Ebrahimi /* Check that this pattern was compiled in the correct bit mode */
118*22dc650dSSadaf Ebrahimi 
119*22dc650dSSadaf Ebrahimi if ((re->flags & (PCRE2_CODE_UNIT_WIDTH/8)) == 0) return PCRE2_ERROR_BADMODE;
120*22dc650dSSadaf Ebrahimi 
121*22dc650dSSadaf Ebrahimi switch(what)
122*22dc650dSSadaf Ebrahimi   {
123*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_ALLOPTIONS:
124*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->overall_options;
125*22dc650dSSadaf Ebrahimi   break;
126*22dc650dSSadaf Ebrahimi 
127*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_ARGOPTIONS:
128*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->compile_options;
129*22dc650dSSadaf Ebrahimi   break;
130*22dc650dSSadaf Ebrahimi 
131*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_BACKREFMAX:
132*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->top_backref;
133*22dc650dSSadaf Ebrahimi   break;
134*22dc650dSSadaf Ebrahimi 
135*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_BSR:
136*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->bsr_convention;
137*22dc650dSSadaf Ebrahimi   break;
138*22dc650dSSadaf Ebrahimi 
139*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_CAPTURECOUNT:
140*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->top_bracket;
141*22dc650dSSadaf Ebrahimi   break;
142*22dc650dSSadaf Ebrahimi 
143*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_DEPTHLIMIT:
144*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->limit_depth;
145*22dc650dSSadaf Ebrahimi   if (re->limit_depth == UINT32_MAX) return PCRE2_ERROR_UNSET;
146*22dc650dSSadaf Ebrahimi   break;
147*22dc650dSSadaf Ebrahimi 
148*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_EXTRAOPTIONS:
149*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->extra_options;
150*22dc650dSSadaf Ebrahimi   break;
151*22dc650dSSadaf Ebrahimi 
152*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_FIRSTCODETYPE:
153*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = ((re->flags & PCRE2_FIRSTSET) != 0)? 1 :
154*22dc650dSSadaf Ebrahimi                          ((re->flags & PCRE2_STARTLINE) != 0)? 2 : 0;
155*22dc650dSSadaf Ebrahimi   break;
156*22dc650dSSadaf Ebrahimi 
157*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_FIRSTCODEUNIT:
158*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = ((re->flags & PCRE2_FIRSTSET) != 0)?
159*22dc650dSSadaf Ebrahimi     re->first_codeunit : 0;
160*22dc650dSSadaf Ebrahimi   break;
161*22dc650dSSadaf Ebrahimi 
162*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_FIRSTBITMAP:
163*22dc650dSSadaf Ebrahimi   *((const uint8_t **)where) = ((re->flags & PCRE2_FIRSTMAPSET) != 0)?
164*22dc650dSSadaf Ebrahimi     &(re->start_bitmap[0]) : NULL;
165*22dc650dSSadaf Ebrahimi   break;
166*22dc650dSSadaf Ebrahimi 
167*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_FRAMESIZE:
168*22dc650dSSadaf Ebrahimi   *((size_t *)where) = offsetof(heapframe, ovector) +
169*22dc650dSSadaf Ebrahimi     re->top_bracket * 2 * sizeof(PCRE2_SIZE);
170*22dc650dSSadaf Ebrahimi   break;
171*22dc650dSSadaf Ebrahimi 
172*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_HASBACKSLASHC:
173*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = (re->flags & PCRE2_HASBKC) != 0;
174*22dc650dSSadaf Ebrahimi   break;
175*22dc650dSSadaf Ebrahimi 
176*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_HASCRORLF:
177*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = (re->flags & PCRE2_HASCRORLF) != 0;
178*22dc650dSSadaf Ebrahimi   break;
179*22dc650dSSadaf Ebrahimi 
180*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_HEAPLIMIT:
181*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->limit_heap;
182*22dc650dSSadaf Ebrahimi   if (re->limit_heap == UINT32_MAX) return PCRE2_ERROR_UNSET;
183*22dc650dSSadaf Ebrahimi   break;
184*22dc650dSSadaf Ebrahimi 
185*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_JCHANGED:
186*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = (re->flags & PCRE2_JCHANGED) != 0;
187*22dc650dSSadaf Ebrahimi   break;
188*22dc650dSSadaf Ebrahimi 
189*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_JITSIZE:
190*22dc650dSSadaf Ebrahimi #ifdef SUPPORT_JIT
191*22dc650dSSadaf Ebrahimi   *((size_t *)where) = (re->executable_jit != NULL)?
192*22dc650dSSadaf Ebrahimi     PRIV(jit_get_size)(re->executable_jit) : 0;
193*22dc650dSSadaf Ebrahimi #else
194*22dc650dSSadaf Ebrahimi   *((size_t *)where) = 0;
195*22dc650dSSadaf Ebrahimi #endif
196*22dc650dSSadaf Ebrahimi   break;
197*22dc650dSSadaf Ebrahimi 
198*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_LASTCODETYPE:
199*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = ((re->flags & PCRE2_LASTSET) != 0)? 1 : 0;
200*22dc650dSSadaf Ebrahimi   break;
201*22dc650dSSadaf Ebrahimi 
202*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_LASTCODEUNIT:
203*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = ((re->flags & PCRE2_LASTSET) != 0)?
204*22dc650dSSadaf Ebrahimi     re->last_codeunit : 0;
205*22dc650dSSadaf Ebrahimi   break;
206*22dc650dSSadaf Ebrahimi 
207*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_MATCHEMPTY:
208*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = (re->flags & PCRE2_MATCH_EMPTY) != 0;
209*22dc650dSSadaf Ebrahimi   break;
210*22dc650dSSadaf Ebrahimi 
211*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_MATCHLIMIT:
212*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->limit_match;
213*22dc650dSSadaf Ebrahimi   if (re->limit_match == UINT32_MAX) return PCRE2_ERROR_UNSET;
214*22dc650dSSadaf Ebrahimi   break;
215*22dc650dSSadaf Ebrahimi 
216*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_MAXLOOKBEHIND:
217*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->max_lookbehind;
218*22dc650dSSadaf Ebrahimi   break;
219*22dc650dSSadaf Ebrahimi 
220*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_MINLENGTH:
221*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->minlength;
222*22dc650dSSadaf Ebrahimi   break;
223*22dc650dSSadaf Ebrahimi 
224*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_NAMEENTRYSIZE:
225*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->name_entry_size;
226*22dc650dSSadaf Ebrahimi   break;
227*22dc650dSSadaf Ebrahimi 
228*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_NAMECOUNT:
229*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->name_count;
230*22dc650dSSadaf Ebrahimi   break;
231*22dc650dSSadaf Ebrahimi 
232*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_NAMETABLE:
233*22dc650dSSadaf Ebrahimi   *((PCRE2_SPTR *)where) = (PCRE2_SPTR)((char *)re + sizeof(pcre2_real_code));
234*22dc650dSSadaf Ebrahimi   break;
235*22dc650dSSadaf Ebrahimi 
236*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_NEWLINE:
237*22dc650dSSadaf Ebrahimi   *((uint32_t *)where) = re->newline_convention;
238*22dc650dSSadaf Ebrahimi   break;
239*22dc650dSSadaf Ebrahimi 
240*22dc650dSSadaf Ebrahimi   case PCRE2_INFO_SIZE:
241*22dc650dSSadaf Ebrahimi   *((size_t *)where) = re->blocksize;
242*22dc650dSSadaf Ebrahimi   break;
243*22dc650dSSadaf Ebrahimi 
244*22dc650dSSadaf Ebrahimi   default: return PCRE2_ERROR_BADOPTION;
245*22dc650dSSadaf Ebrahimi   }
246*22dc650dSSadaf Ebrahimi 
247*22dc650dSSadaf Ebrahimi return 0;
248*22dc650dSSadaf Ebrahimi }
249*22dc650dSSadaf Ebrahimi 
250*22dc650dSSadaf Ebrahimi 
251*22dc650dSSadaf Ebrahimi 
252*22dc650dSSadaf Ebrahimi /*************************************************
253*22dc650dSSadaf Ebrahimi *              Callout enumerator                *
254*22dc650dSSadaf Ebrahimi *************************************************/
255*22dc650dSSadaf Ebrahimi 
256*22dc650dSSadaf Ebrahimi /*
257*22dc650dSSadaf Ebrahimi Arguments:
258*22dc650dSSadaf Ebrahimi   code          points to compiled code
259*22dc650dSSadaf Ebrahimi   callback      function called for each callout block
260*22dc650dSSadaf Ebrahimi   callout_data  user data passed to the callback
261*22dc650dSSadaf Ebrahimi 
262*22dc650dSSadaf Ebrahimi Returns:        0 when successfully completed
263*22dc650dSSadaf Ebrahimi                 < 0 on local error
264*22dc650dSSadaf Ebrahimi                != 0 for callback error
265*22dc650dSSadaf Ebrahimi */
266*22dc650dSSadaf Ebrahimi 
267*22dc650dSSadaf Ebrahimi PCRE2_EXP_DEFN int PCRE2_CALL_CONVENTION
pcre2_callout_enumerate(const pcre2_code * code,int (* callback)(pcre2_callout_enumerate_block *,void *),void * callout_data)268*22dc650dSSadaf Ebrahimi pcre2_callout_enumerate(const pcre2_code *code,
269*22dc650dSSadaf Ebrahimi   int (*callback)(pcre2_callout_enumerate_block *, void *), void *callout_data)
270*22dc650dSSadaf Ebrahimi {
271*22dc650dSSadaf Ebrahimi pcre2_real_code *re = (pcre2_real_code *)code;
272*22dc650dSSadaf Ebrahimi pcre2_callout_enumerate_block cb;
273*22dc650dSSadaf Ebrahimi PCRE2_SPTR cc;
274*22dc650dSSadaf Ebrahimi #ifdef SUPPORT_UNICODE
275*22dc650dSSadaf Ebrahimi BOOL utf;
276*22dc650dSSadaf Ebrahimi #endif
277*22dc650dSSadaf Ebrahimi 
278*22dc650dSSadaf Ebrahimi if (re == NULL) return PCRE2_ERROR_NULL;
279*22dc650dSSadaf Ebrahimi 
280*22dc650dSSadaf Ebrahimi #ifdef SUPPORT_UNICODE
281*22dc650dSSadaf Ebrahimi utf = (re->overall_options & PCRE2_UTF) != 0;
282*22dc650dSSadaf Ebrahimi #endif
283*22dc650dSSadaf Ebrahimi 
284*22dc650dSSadaf Ebrahimi /* Check that the first field in the block is the magic number. If it is not,
285*22dc650dSSadaf Ebrahimi return with PCRE2_ERROR_BADMAGIC. */
286*22dc650dSSadaf Ebrahimi 
287*22dc650dSSadaf Ebrahimi if (re->magic_number != MAGIC_NUMBER) return PCRE2_ERROR_BADMAGIC;
288*22dc650dSSadaf Ebrahimi 
289*22dc650dSSadaf Ebrahimi /* Check that this pattern was compiled in the correct bit mode */
290*22dc650dSSadaf Ebrahimi 
291*22dc650dSSadaf Ebrahimi if ((re->flags & (PCRE2_CODE_UNIT_WIDTH/8)) == 0) return PCRE2_ERROR_BADMODE;
292*22dc650dSSadaf Ebrahimi 
293*22dc650dSSadaf Ebrahimi cb.version = 0;
294*22dc650dSSadaf Ebrahimi cc = (PCRE2_SPTR)((uint8_t *)re + sizeof(pcre2_real_code))
295*22dc650dSSadaf Ebrahimi      + re->name_count * re->name_entry_size;
296*22dc650dSSadaf Ebrahimi 
297*22dc650dSSadaf Ebrahimi while (TRUE)
298*22dc650dSSadaf Ebrahimi   {
299*22dc650dSSadaf Ebrahimi   int rc;
300*22dc650dSSadaf Ebrahimi   switch (*cc)
301*22dc650dSSadaf Ebrahimi     {
302*22dc650dSSadaf Ebrahimi     case OP_END:
303*22dc650dSSadaf Ebrahimi     return 0;
304*22dc650dSSadaf Ebrahimi 
305*22dc650dSSadaf Ebrahimi     case OP_CHAR:
306*22dc650dSSadaf Ebrahimi     case OP_CHARI:
307*22dc650dSSadaf Ebrahimi     case OP_NOT:
308*22dc650dSSadaf Ebrahimi     case OP_NOTI:
309*22dc650dSSadaf Ebrahimi     case OP_STAR:
310*22dc650dSSadaf Ebrahimi     case OP_MINSTAR:
311*22dc650dSSadaf Ebrahimi     case OP_PLUS:
312*22dc650dSSadaf Ebrahimi     case OP_MINPLUS:
313*22dc650dSSadaf Ebrahimi     case OP_QUERY:
314*22dc650dSSadaf Ebrahimi     case OP_MINQUERY:
315*22dc650dSSadaf Ebrahimi     case OP_UPTO:
316*22dc650dSSadaf Ebrahimi     case OP_MINUPTO:
317*22dc650dSSadaf Ebrahimi     case OP_EXACT:
318*22dc650dSSadaf Ebrahimi     case OP_POSSTAR:
319*22dc650dSSadaf Ebrahimi     case OP_POSPLUS:
320*22dc650dSSadaf Ebrahimi     case OP_POSQUERY:
321*22dc650dSSadaf Ebrahimi     case OP_POSUPTO:
322*22dc650dSSadaf Ebrahimi     case OP_STARI:
323*22dc650dSSadaf Ebrahimi     case OP_MINSTARI:
324*22dc650dSSadaf Ebrahimi     case OP_PLUSI:
325*22dc650dSSadaf Ebrahimi     case OP_MINPLUSI:
326*22dc650dSSadaf Ebrahimi     case OP_QUERYI:
327*22dc650dSSadaf Ebrahimi     case OP_MINQUERYI:
328*22dc650dSSadaf Ebrahimi     case OP_UPTOI:
329*22dc650dSSadaf Ebrahimi     case OP_MINUPTOI:
330*22dc650dSSadaf Ebrahimi     case OP_EXACTI:
331*22dc650dSSadaf Ebrahimi     case OP_POSSTARI:
332*22dc650dSSadaf Ebrahimi     case OP_POSPLUSI:
333*22dc650dSSadaf Ebrahimi     case OP_POSQUERYI:
334*22dc650dSSadaf Ebrahimi     case OP_POSUPTOI:
335*22dc650dSSadaf Ebrahimi     case OP_NOTSTAR:
336*22dc650dSSadaf Ebrahimi     case OP_NOTMINSTAR:
337*22dc650dSSadaf Ebrahimi     case OP_NOTPLUS:
338*22dc650dSSadaf Ebrahimi     case OP_NOTMINPLUS:
339*22dc650dSSadaf Ebrahimi     case OP_NOTQUERY:
340*22dc650dSSadaf Ebrahimi     case OP_NOTMINQUERY:
341*22dc650dSSadaf Ebrahimi     case OP_NOTUPTO:
342*22dc650dSSadaf Ebrahimi     case OP_NOTMINUPTO:
343*22dc650dSSadaf Ebrahimi     case OP_NOTEXACT:
344*22dc650dSSadaf Ebrahimi     case OP_NOTPOSSTAR:
345*22dc650dSSadaf Ebrahimi     case OP_NOTPOSPLUS:
346*22dc650dSSadaf Ebrahimi     case OP_NOTPOSQUERY:
347*22dc650dSSadaf Ebrahimi     case OP_NOTPOSUPTO:
348*22dc650dSSadaf Ebrahimi     case OP_NOTSTARI:
349*22dc650dSSadaf Ebrahimi     case OP_NOTMINSTARI:
350*22dc650dSSadaf Ebrahimi     case OP_NOTPLUSI:
351*22dc650dSSadaf Ebrahimi     case OP_NOTMINPLUSI:
352*22dc650dSSadaf Ebrahimi     case OP_NOTQUERYI:
353*22dc650dSSadaf Ebrahimi     case OP_NOTMINQUERYI:
354*22dc650dSSadaf Ebrahimi     case OP_NOTUPTOI:
355*22dc650dSSadaf Ebrahimi     case OP_NOTMINUPTOI:
356*22dc650dSSadaf Ebrahimi     case OP_NOTEXACTI:
357*22dc650dSSadaf Ebrahimi     case OP_NOTPOSSTARI:
358*22dc650dSSadaf Ebrahimi     case OP_NOTPOSPLUSI:
359*22dc650dSSadaf Ebrahimi     case OP_NOTPOSQUERYI:
360*22dc650dSSadaf Ebrahimi     case OP_NOTPOSUPTOI:
361*22dc650dSSadaf Ebrahimi     cc += PRIV(OP_lengths)[*cc];
362*22dc650dSSadaf Ebrahimi #ifdef SUPPORT_UNICODE
363*22dc650dSSadaf Ebrahimi     if (utf && HAS_EXTRALEN(cc[-1])) cc += GET_EXTRALEN(cc[-1]);
364*22dc650dSSadaf Ebrahimi #endif
365*22dc650dSSadaf Ebrahimi     break;
366*22dc650dSSadaf Ebrahimi 
367*22dc650dSSadaf Ebrahimi     case OP_TYPESTAR:
368*22dc650dSSadaf Ebrahimi     case OP_TYPEMINSTAR:
369*22dc650dSSadaf Ebrahimi     case OP_TYPEPLUS:
370*22dc650dSSadaf Ebrahimi     case OP_TYPEMINPLUS:
371*22dc650dSSadaf Ebrahimi     case OP_TYPEQUERY:
372*22dc650dSSadaf Ebrahimi     case OP_TYPEMINQUERY:
373*22dc650dSSadaf Ebrahimi     case OP_TYPEUPTO:
374*22dc650dSSadaf Ebrahimi     case OP_TYPEMINUPTO:
375*22dc650dSSadaf Ebrahimi     case OP_TYPEEXACT:
376*22dc650dSSadaf Ebrahimi     case OP_TYPEPOSSTAR:
377*22dc650dSSadaf Ebrahimi     case OP_TYPEPOSPLUS:
378*22dc650dSSadaf Ebrahimi     case OP_TYPEPOSQUERY:
379*22dc650dSSadaf Ebrahimi     case OP_TYPEPOSUPTO:
380*22dc650dSSadaf Ebrahimi     cc += PRIV(OP_lengths)[*cc];
381*22dc650dSSadaf Ebrahimi #ifdef SUPPORT_UNICODE
382*22dc650dSSadaf Ebrahimi     if (cc[-1] == OP_PROP || cc[-1] == OP_NOTPROP) cc += 2;
383*22dc650dSSadaf Ebrahimi #endif
384*22dc650dSSadaf Ebrahimi     break;
385*22dc650dSSadaf Ebrahimi 
386*22dc650dSSadaf Ebrahimi #if defined SUPPORT_UNICODE || PCRE2_CODE_UNIT_WIDTH != 8
387*22dc650dSSadaf Ebrahimi     case OP_XCLASS:
388*22dc650dSSadaf Ebrahimi     cc += GET(cc, 1);
389*22dc650dSSadaf Ebrahimi     break;
390*22dc650dSSadaf Ebrahimi #endif
391*22dc650dSSadaf Ebrahimi 
392*22dc650dSSadaf Ebrahimi     case OP_MARK:
393*22dc650dSSadaf Ebrahimi     case OP_COMMIT_ARG:
394*22dc650dSSadaf Ebrahimi     case OP_PRUNE_ARG:
395*22dc650dSSadaf Ebrahimi     case OP_SKIP_ARG:
396*22dc650dSSadaf Ebrahimi     case OP_THEN_ARG:
397*22dc650dSSadaf Ebrahimi     cc += PRIV(OP_lengths)[*cc] + cc[1];
398*22dc650dSSadaf Ebrahimi     break;
399*22dc650dSSadaf Ebrahimi 
400*22dc650dSSadaf Ebrahimi     case OP_CALLOUT:
401*22dc650dSSadaf Ebrahimi     cb.pattern_position = GET(cc, 1);
402*22dc650dSSadaf Ebrahimi     cb.next_item_length = GET(cc, 1 + LINK_SIZE);
403*22dc650dSSadaf Ebrahimi     cb.callout_number = cc[1 + 2*LINK_SIZE];
404*22dc650dSSadaf Ebrahimi     cb.callout_string_offset = 0;
405*22dc650dSSadaf Ebrahimi     cb.callout_string_length = 0;
406*22dc650dSSadaf Ebrahimi     cb.callout_string = NULL;
407*22dc650dSSadaf Ebrahimi     rc = callback(&cb, callout_data);
408*22dc650dSSadaf Ebrahimi     if (rc != 0) return rc;
409*22dc650dSSadaf Ebrahimi     cc += PRIV(OP_lengths)[*cc];
410*22dc650dSSadaf Ebrahimi     break;
411*22dc650dSSadaf Ebrahimi 
412*22dc650dSSadaf Ebrahimi     case OP_CALLOUT_STR:
413*22dc650dSSadaf Ebrahimi     cb.pattern_position = GET(cc, 1);
414*22dc650dSSadaf Ebrahimi     cb.next_item_length = GET(cc, 1 + LINK_SIZE);
415*22dc650dSSadaf Ebrahimi     cb.callout_number = 0;
416*22dc650dSSadaf Ebrahimi     cb.callout_string_offset = GET(cc, 1 + 3*LINK_SIZE);
417*22dc650dSSadaf Ebrahimi     cb.callout_string_length =
418*22dc650dSSadaf Ebrahimi       GET(cc, 1 + 2*LINK_SIZE) - (1 + 4*LINK_SIZE) - 2;
419*22dc650dSSadaf Ebrahimi     cb.callout_string = cc + (1 + 4*LINK_SIZE) + 1;
420*22dc650dSSadaf Ebrahimi     rc = callback(&cb, callout_data);
421*22dc650dSSadaf Ebrahimi     if (rc != 0) return rc;
422*22dc650dSSadaf Ebrahimi     cc += GET(cc, 1 + 2*LINK_SIZE);
423*22dc650dSSadaf Ebrahimi     break;
424*22dc650dSSadaf Ebrahimi 
425*22dc650dSSadaf Ebrahimi     default:
426*22dc650dSSadaf Ebrahimi     cc += PRIV(OP_lengths)[*cc];
427*22dc650dSSadaf Ebrahimi     break;
428*22dc650dSSadaf Ebrahimi     }
429*22dc650dSSadaf Ebrahimi   }
430*22dc650dSSadaf Ebrahimi }
431*22dc650dSSadaf Ebrahimi 
432*22dc650dSSadaf Ebrahimi /* End of pcre2_pattern_info.c */
433