GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages


Manual Reference Pages  -  REGEXP (3)

NAME

regcomp, regcomplit, regcompnl, regexec, regsub, rregexec, rregsub, regerror - regular expression

CONTENTS

Synopsis
Description
Source
Diagnostics
Bugs

SYNOPSIS

#include <u.h>
#include <libc.h>
#include <regexp.h>

Reprog *regcomp(char *exp)

Reprog *regcomplit(char *exp)

Reprog *regcompnl(char *exp)


 
int  regexec(Reprog *prog, char *string, Resub *match, int msize)

void regsub(char *source, char *dest, int dlen, Resub *match, int msize)

int rregexec(Reprog *prog, Rune *string, Resub *match, int msize)

void rregsub(Rune *source, Rune *dest, int dlen, Resub *match, int msize)

void regerror(char *msg)

DESCRIPTION

Regcomp compiles a regular expression and returns a pointer to the generated description. The space is allocated by malloc(3) and may be released by free. Regular expressions are exactly as in regexp(7).

Regcomplit is like regcomp except that all characters are treated literally. Regcompnl is like regcomp except that the . metacharacter matches all characters, including newlines.

Regexec matches a null-terminated string against the compiled regular expression in prog. If it matches, regexec returns 1 and fills in the array match with character pointers to the substrings of string that correspond to the parenthesized subexpressions of exp: match[i].sp points to the beginning and match[i].ep points just beyond the end of the ith substring. (Subexpression i begins at the ith left parenthesis, counting from 1.) Pointers in match[0] pick out the substring that corresponds to the whole regular expression. Unused elements of match are filled with zeros. Matches involving and are extended as far as possible. The number of array elements in match is given by msize. The structure of elements of match is:
typedef struct {
       union {
        char *sp;
        Rune *rsp;
       } s;
       union {
        char *ep;
        Rune *rep;
       } e; } Resub;
If match[0].s.sp is nonzero on entry, regexec starts matching at that point within string. If match[0].e.ep is nonzero on entry, the last character matched is the one preceding that point.

Regsub places in dest a substitution instance of source in the context of the last regexec performed using match. Each instance of \n, where n is a digit, is replaced by the string delimited by match[n].sp and match[n].ep. Each instance of is replaced by the string delimited by match[0].sp and match[0].ep. The substitution will always be null terminated and trimmed to fit into dlen bytes.

Regerror, called whenever an error is detected in regcomp, writes the string msg on the standard error file and exits. Regerror can be replaced to perform special error processing. If the user supplied regerror returns rather than exits, regcomp will return 0.

Rregexec and rregsub are variants of regexec and regsub that use strings of Runes instead of strings of chars. With these routines, the rsp and rep fields of the match array elements should be used.

SOURCE

/usr/local/plan9/src/libregexp

SEE ALSO

grep(1)

DIAGNOSTICS

Regcomp returns 0 for an illegal expression or other failure. Regexec returns 0 if string is not matched.

BUGS

There is no way to specify or match a NUL character; NULs terminate patterns and strings.
Search for    or go to Top of page |  Section 3 |  Main Index


REGEXP (3) -->

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with manServer 1.07.