Mercurial > hg > Applications > Grep
view regexParser/regexParser.h @ 232:1a34e702776a
add fileread.cc
author | Masataka Kohagura <kohagura@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 19 Jan 2016 13:16:35 +0900 |
parents | 4dc8d327cc7d |
children | f5931151d70c |
line wrap: on
line source
#define NEW(type) (type*)malloc(sizeof(type)) #ifndef INCLUDED_STRUCT #define INCLUDED_STRUCT #define BITBLOCK 64 typedef struct bitVector { unsigned long bitContainer; } BitVector,*BitVectorPtr; typedef struct word { unsigned char *word; int length; } Word, *WordPtr; typedef struct utf8Range { unsigned long begin; unsigned long end; struct utf8Range *next; // only used in the parser. } RangeList , *RangeListPtr; typedef struct condition { RangeList range; Word w; } Condition, *ConditionList; typedef struct charClass { unsigned char type; struct charClass *left; struct charClass *right; Condition cond; int stateNum; BitVector nextState; } CharClass, *CharClassPtr; struct node; typedef struct state { int stateNum; BitVector bitState; CharClassPtr cc; struct node *node; struct state *next; } State, *StatePtr; typedef struct node { unsigned char tokenType; CharClassPtr cc; int stateNum; int nextStateNum; StatePtr state; StatePtr nextState; struct node *left; struct node *right; } Node, *NodePtr; typedef struct stateStack { BitVector state; struct stateStack *next; } StateStack, *StateStackPtr; typedef struct transitionGenerator { long totalStateCount; StateStackPtr stack; StatePtr *stateArray; StatePtr stateList; } TransitionGenerator, *TransitionGeneratorPtr; // Value Container is passed directly in functions // Don't use it's pointer typedef struct scValue { StatePtr stateTop; StatePtr stateEnd; TransitionGeneratorPtr tg; } SCValue, *SCValuePtr; typedef struct tgValue { StatePtr asterisk; // last * state of the expression StatePtr startState; StatePtr endState; TransitionGeneratorPtr tg; } TGValue, *TGValuePtr; enum charClassStackState { LEFT, SELF, RIGHT }; typedef struct charClassStack { charClassStackState turn; CharClassPtr cc; struct charClassStack *next; } CharClassStack, *CharClassStackPtr; typedef struct charClassWalker { CharClassStackPtr stack; charClassStackState turn; CharClassPtr next; } CharClassWalker, *CharClassWalkerPtr; typedef struct regexInfo { unsigned char *ptr; unsigned char tokenType; unsigned char *tokenValue; int stateNumber; } RegexInfo, *RegexInfoPtr; typedef struct buffer { unsigned char *buff; unsigned char *buffptr; unsigned char *buffend; unsigned char *matchBegin; } Buffer, *BufferPtr; typedef struct { unsigned char* file_mmap; off_t size; } st_mmap_t; #endif extern NodePtr createNode(RegexInfoPtr ri,unsigned char type,CharClassPtr cc, NodePtr left, NodePtr right); extern CharClassPtr createCharClassRange(unsigned long begin, unsigned long end,unsigned long state, CharClassPtr left, CharClassPtr right); extern NodePtr regex(RegexInfoPtr);