.TH PCRE2_COMPILE 3 "23 March 2017" "PCRE2 10.30" .SH NAME PCRE2 - Perl-compatible regular expressions (revised API) .SH SYNOPSIS .rs .sp .B #include <pcre2.h> .PP .nf .B int pcre2_callout_enumerate(const pcre2_code *\fIcode\fP, .B " int (*\fIcallback\fP)(pcre2_callout_enumerate_block *, void *)," .B " void *\fIcallout_data\fP);" .fi . .SH DESCRIPTION .rs .sp This function scans a compiled regular expression and calls the \fIcallback()\fP function for each callout within the pattern. The yield of the function is zero for success and non-zero otherwise. The arguments are: .sp \fIcode\fP Points to the compiled pattern \fIcallback\fP The callback function \fIcallout_data\fP User data that is passed to the callback .sp The \fIcallback()\fP function is passed a pointer to a data block containing the following fields (not necessarily in this order): .sp uint32_t \fIversion\fP Block version number uint32_t \fIcallout_number\fP Number for numbered callouts PCRE2_SIZE \fIpattern_position\fP Offset to next item in pattern PCRE2_SIZE \fInext_item_length\fP Length of next item in pattern PCRE2_SIZE \fIcallout_string_offset\fP Offset to string within pattern PCRE2_SIZE \fIcallout_string_length\fP Length of callout string PCRE2_SPTR \fIcallout_string\fP Points to callout string or is NULL .sp The second argument passed to the \fBcallback()\fP function is the callout data that was passed to \fBpcre2_callout_enumerate()\fP. The \fBcallback()\fP function must return zero for success. Any other value causes the pattern scan to stop, with the value being passed back as the result of \fBpcre2_callout_enumerate()\fP. .P There is a complete description of the PCRE2 native API in the .\" HREF \fBpcre2api\fP .\" page and a description of the POSIX API in the .\" HREF \fBpcre2posix\fP .\" page.