plan9port/man/man3/regexp.3

213 lines
3.5 KiB
Groff
Raw Normal View History

2004-04-10 18:53:55 +00:00
.TH REGEXP 3
2003-09-30 17:47:41 +00:00
.SH NAME
2004-04-10 18:53:55 +00:00
regcomp, regcomplit, regcompnl, regexec, regsub, rregexec, rregsub, regerror \- regular expression
2003-09-30 17:47:41 +00:00
.SH SYNOPSIS
2004-04-10 18:53:55 +00:00
.B #include <u.h>
.br
.B #include <libc.h>
.br
.B #include <regexp.h>
2003-09-30 17:47:41 +00:00
.PP
.ta \w'\fLRegprog 'u
.B
Reprog *regcomp(char *exp)
.PP
.B
Reprog *regcomplit(char *exp)
.PP
.B
Reprog *regcompnl(char *exp)
.PP
.nf
.B
int regexec(Reprog *prog, char *string, Resub *match, int msize)
.PP
.nf
.B
void regsub(char *source, char *dest, int dlen, Resub *match, int msize)
.PP
.nf
.B
int rregexec(Reprog *prog, Rune *string, Resub *match, int msize)
.PP
.nf
.B
void rregsub(Rune *source, Rune *dest, int dlen, Resub *match, int msize)
.PP
.B
void regerror(char *msg)
.SH DESCRIPTION
.I Regcomp
compiles a
regular expression and returns
a pointer to the generated description.
The space is allocated by
.IR malloc (3)
2003-09-30 17:47:41 +00:00
and may be released by
.IR free .
Regular expressions are exactly as in
2004-04-10 18:53:55 +00:00
.IR regexp (6).
2003-09-30 17:47:41 +00:00
.PP
.I Regcomplit
is like
.I regcomp
except that all characters are treated literally.
.I Regcompnl
is like
.I regcomp
except that the
.B .
metacharacter matches all characters, including newlines.
.PP
.I Regexec
matches a null-terminated
.I string
against the compiled regular expression in
.IR prog .
If it matches,
.I regexec
returns
.B 1
and fills in the array
.I match
with character pointers to the substrings of
.I string
that correspond to the
parenthesized subexpressions of
.IR exp :
.BI match[ i ].sp
points to the beginning and
.BI match[ i ].ep
points just beyond
the end of the
.IR i th
substring.
(Subexpression
.I i
begins at the
.IR i th
left parenthesis, counting from 1.)
Pointers in
.B match[0]
pick out the substring that corresponds to
the whole regular expression.
Unused elements of
.I match
are filled with zeros.
Matches involving
.LR * ,
.LR + ,
and
.L ?
are extended as far as possible.
The number of array elements in
.I match
is given by
.IR msize .
The structure of elements of
.I match
is:
.IP
.EX
typedef struct {
union {
char *sp;
Rune *rsp;
2004-04-10 18:53:55 +00:00
};
2003-09-30 17:47:41 +00:00
union {
char *ep;
Rune *rep;
2004-04-10 18:53:55 +00:00
};
2003-09-30 17:47:41 +00:00
} Resub;
.EE
.LP
If
2004-04-10 18:53:55 +00:00
.B match[0].sp
2003-09-30 17:47:41 +00:00
is nonzero on entry,
.I regexec
starts matching at that point within
.IR string .
If
2004-04-10 18:53:55 +00:00
.B match[0].ep
2003-09-30 17:47:41 +00:00
is nonzero on entry,
the last character matched is the one
preceding that point.
.PP
.I Regsub
places in
.I dest
a substitution instance of
.I source
in the context of the last
.I regexec
performed using
.IR match .
Each instance of
.BI \e n\f1,
where
.I n
is a digit, is replaced by the
string delimited by
2004-04-10 18:53:55 +00:00
.BI match[ n ].sp
2003-09-30 17:47:41 +00:00
and
2004-04-10 18:53:55 +00:00
.BI match[ n ].ep\f1.
2003-09-30 17:47:41 +00:00
Each instance of
.L &
is replaced by the string delimited by
2004-04-10 18:53:55 +00:00
.B match[0].sp
2003-09-30 17:47:41 +00:00
and
2004-04-10 18:53:55 +00:00
.BR match[0].ep .
2003-09-30 17:47:41 +00:00
The substitution will always be null terminated and
trimmed to fit into dlen bytes.
.PP
.IR Regerror ,
called whenever an error is detected in
.IR regcomp ,
writes the string
.I msg
on the standard error file and exits.
.I Regerror
can be replaced to perform
special error processing.
If the user supplied
.I regerror
returns rather than exits,
.I regcomp
will return 0.
.PP
.I Rregexec
and
.I rregsub
are variants of
.I regexec
and
.I regsub
that use strings of
.B Runes
instead of strings of
.BR chars .
With these routines, the
.I rsp
and
.I rep
fields of the
.I match
array elements should be used.
2004-04-10 18:53:55 +00:00
.SH SOURCE
2004-04-19 19:22:56 +00:00
.B /usr/local/plan9/src/libregexp
2003-09-30 17:47:41 +00:00
.SH "SEE ALSO"
2004-04-10 18:53:55 +00:00
.IR grep (1)
2003-09-30 17:47:41 +00:00
.SH DIAGNOSTICS
.I Regcomp
returns
.B 0
for an illegal expression
or other failure.
.I Regexec
returns 0
if
.I string
is not matched.
.SH BUGS
There is no way to specify or match a NUL character; NULs terminate patterns and strings.