123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- /*
- * This file is part of the UCB release of Plan 9. It is subject to the license
- * terms in the LICENSE file found in the top-level directory of this
- * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
- * part of the UCB release of Plan 9, including this file, may be copied,
- * modified, propagated, or distributed except according to the terms contained
- * in the LICENSE file.
- */
- #pragma src "/sys/src/lib/regexp"
- #pragma lib "libregexp.a"
- typedef struct Resub Resub;
- typedef struct Reclass Reclass;
- typedef struct Reinst Reinst;
- typedef struct Reprog Reprog;
- /*
- * Sub expression matches
- */
- struct Resub{
- union
- {
- char *sp;
- Rune *rsp;
- };
- union
- {
- char *ep;
- Rune *rep;
- };
- };
- /*
- * character class, each pair of rune's defines a range
- */
- struct Reclass{
- Rune *end;
- Rune spans[64];
- };
- /*
- * Machine instructions
- */
- struct Reinst{
- int type;
- union {
- Reclass *cp; /* class pointer */
- Rune r; /* character */
- int subid; /* sub-expression id for RBRA and LBRA */
- Reinst *right; /* right child of OR */
- };
- union { /* regexp relies on these two being in the same union */
- Reinst *left; /* left child of OR */
- Reinst *next; /* next instruction for CAT & LBRA */
- };
- };
- /*
- * Reprogram definition
- */
- struct Reprog{
- Reinst *startinst; /* start pc */
- Reclass class[16]; /* .data */
- Reinst firstinst[5]; /* .text */
- };
- extern Reprog *regcomp(char*);
- extern Reprog *regcomplit(char*);
- extern Reprog *regcompnl(char*);
- extern void regerror(char*);
- extern int regexec(Reprog*, char*, Resub*, int);
- extern void regsub(char*, char*, int, Resub*, int);
- extern int rregexec(Reprog*, Rune*, Resub*, int);
- extern void rregsub(Rune*, Rune*, int, Resub*, int);
|