Compare a string with a compiled regular expression
#include <regex.h> int regexec( const regex_t * preg, const char * string, size_t nmatch, regmatch_t * pmatch, int eflags );
libc
Use the -l c option to qcc to link against this library. This library is usually included automatically.
This function is in libc.a, but not in libc.so (in order to save space). |
The regexec() function compares string against the compiled regular expression preg. If regexec() finds a match it returns zero; otherwise, it returns nonzero.
The preg argument represents a compiled form of either a Basic Regular Expression or Extended Regular Expression. These classes are rigorously defined in IEEE P1003.2, Regular Expression Notation, and are summarized in the documentation for regcomp().
The regexec() function records the matches in the pmatch array, with nmatch specifying the maximum number of matches to record. The regmatch_t structure is defined as:
typedef struct { regoff_t rm_so; regoff_t rm_eo; } regmatch_t;
The members are:
The offsets in pmatch[0] identify the substring corresponding to the entire expression, while those in pmatch[1...nmatch] identify up to the first nmatch subexpressions. Unused elements of the pmatch array are set to -1.
You can disable the recording of substrings by either specifying REG_NOSUB in regcomp(), or by setting nmatch to zero. |
See regcomp().
Safety: | |
---|---|
Cancellation point | No |
Interrupt handler | No |
Signal handler | No |
Thread | Yes |
Henry Spencer. For license information, see the Third Party License Terms List at http://licensing.qnx.com/third-party-terms/.
regcomp(), regerror(), regfree()