Mercurial > hg > Applications > Grep
view regexParser/regexParser.h @ 215:63e9224c7b2b
try to fix asterisk
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 29 Dec 2015 19:01:23 +0900 |
parents | a94f57af1600 |
children | 4dc8d327cc7d |
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; typedef struct scValue { StatePtr stateTop; StatePtr stateEnd; StatePtr *stateArray; 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; #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);