#include <u.h> #include <libc.h> #include <bio.h> #ifndef EXTERN #define EXTERN extern #endif typedef struct Re Re; typedef struct Re2 Re2; typedef struct State State; struct State { int count; int match; Re** re; State* linkleft; State* linkright; State* next[256]; }; struct Re2 { Re* beg; Re* end; }; struct Re { uchar type; ushort gen; union { Re* alt; /* Talt */ Re** cases; /* case */ struct /* class */ { Rune lo; Rune hi; } x; Rune val; /* char */ } u; Re* next; }; enum { Talt = 1, Tbegin, Tcase, Tclass, Tend, Tor, Caselim = 7, Nhunk = 1<<16, Cbegin = 0x10000, Flshcnt = (1<<9)-1, Cflag = 1<<0, Hflag = 1<<1, Iflag = 1<<2, Llflag = 1<<3, LLflag = 1<<4, Nflag = 1<<5, Sflag = 1<<6, Vflag = 1<<7, Bflag = 1<<8 }; EXTERN union { char string[16*1024]; struct { /* * if a line requires multiple reads, we keep shifting * buf down into pre and then do another read into * buf. so you'll get the last 16-32k of the matching line. * if h were smaller than buf you'd get a suffix of the * line with a hole cut out. */ uchar pre[16*1024]; /* to save to previous '\n' */ uchar buf[16*1024]; /* input buffer */ } u; } u; EXTERN char *filename; EXTERN Biobuf bout; EXTERN char flags[256]; EXTERN Re** follow; EXTERN ushort gen; EXTERN char* input; EXTERN long lineno; EXTERN int literal; EXTERN int matched; EXTERN long maxfollow; EXTERN long nfollow; EXTERN int peekc; EXTERN Biobuf* rein; EXTERN State* state0; EXTERN Re2 topre; extern Re* addcase(Re*); extern void appendnext(Re*, Re*); extern void error(char*); extern int fcmp(const void*, const void*); /* (Re**, Re**) */ extern void fol1(Re*, int); extern int getrec(void); extern void increment(State*, int); #define initstate grepinitstate extern State* initstate(Re*); extern void* mal(int); extern void patchnext(Re*, Re*); extern Re* ral(int); extern Re2 re2cat(Re2, Re2); extern Re2 re2class(char*); extern Re2 re2or(Re2, Re2); extern Re2 re2char(int, int); extern Re2 re2star(Re2); extern State* sal(int); extern int search(char*, int); extern void str2top(char*); extern int yyparse(void); extern void reprint(char*, Re*); extern void yyerror(char*, ...);