Mercurial > hg > Applications > Grep
changeset 288:f2491681914e
special state for start search
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 01 Feb 2016 01:35:12 +0900 (2016-01-31) |
parents | 2f3e7bba038e |
children | 20ed7536784f |
files | regexParser/cerium/CeriumMain.cc regexParser/cerium/ppe/Exec.cc regexParser/generateSequentialSearch.cc regexParser/regexParser.h regexParser/threadedSearch.cc |
diffstat | 5 files changed, 18 insertions(+), 9 deletions(-) [+] |
line wrap: on
line diff
--- a/regexParser/cerium/CeriumMain.cc Sun Jan 31 22:59:59 2016 +0900 +++ b/regexParser/cerium/CeriumMain.cc Mon Feb 01 01:35:12 2016 +0900 @@ -29,7 +29,7 @@ static TSValue stateSkip(TSValue tsv) { - tsv.current = tsv.tg->stateList->tState; + tsv.current = tsv.tg->stateStart->tState; tsv.buff.matchBegin = tsv.buff.buffptr; return tsv; } @@ -43,7 +43,6 @@ *tsv.resultEnd = r; r->next = NULL; tsv.resultEnd = &r->next; - tsv.current = tsv.tg->stateList->tState; tsv.buff.buffptr--; tsv = stateSkip(tsv); return tsv; @@ -63,7 +62,8 @@ return prev; } -void ceriumCreateAnyState(TransitionGeneratorPtr tg) { +void +ceriumCreateAnyState(TransitionGeneratorPtr tg) { tg->stateSkip = stateSkip; tg->stateMatch = stateMatch; tg->stateNothing = stateNothing; @@ -71,6 +71,10 @@ generateTState(tg->anyState,tg); // generateTState for startState. It is used in stateMatch. generateTState(tg->stateList,tg); + tg->stateStart = NEW(State); + *tg->stateStart = *tg->stateList; + tg->stateStart->accept = false; // Start state never accept + generateTState(tg->stateStart,tg); } int
--- a/regexParser/cerium/ppe/Exec.cc Sun Jan 31 22:59:59 2016 +0900 +++ b/regexParser/cerium/ppe/Exec.cc Mon Feb 01 01:35:12 2016 +0900 @@ -15,7 +15,7 @@ tsv.buff = buff; tsv.tg = tg; if (task_spawned == 0) { - tsv.current = tg->stateList->tState; + tsv.current = tg->stateStart->tState; } else { tsv.current = tg->anyState->tState; }
--- a/regexParser/generateSequentialSearch.cc Sun Jan 31 22:59:59 2016 +0900 +++ b/regexParser/generateSequentialSearch.cc Mon Feb 01 01:35:12 2016 +0900 @@ -39,7 +39,7 @@ if (begin == end) { fprintf(fp,"if (c=='%c') state%lx(buff);\n",(unsigned char)begin, bi.bitContainer); } else { - if (state->bitState.bitContainer & 2) { + if (state->accept) { fprintf(fp,"if (c<'%c') stateMatch(buff);\n",(unsigned char)begin); } else { fprintf(fp,"if (c<'%c') stateSkip(buff);\n",(unsigned char)begin);
--- a/regexParser/regexParser.h Sun Jan 31 22:59:59 2016 +0900 +++ b/regexParser/regexParser.h Mon Feb 01 01:35:12 2016 +0900 @@ -94,6 +94,7 @@ long totalBasicState; StateStackPtr stack; StatePtr stateEnd; + StatePtr stateStart; // start state without accept flag StatePtr *stateArray; StatePtr stateList; StatePtr anyState; @@ -121,7 +122,7 @@ typedef struct tgValue { StatePtr asterisk; // last * state of the expression - StatePtr startState; + StatePtr startState; // startState of the expression StatePtr endState; TransitionGeneratorPtr tg; } TGValue, *TGValuePtr;
--- a/regexParser/threadedSearch.cc Sun Jan 31 22:59:59 2016 +0900 +++ b/regexParser/threadedSearch.cc Mon Feb 01 01:35:12 2016 +0900 @@ -12,7 +12,7 @@ static TSValue stateSkip(TSValue tsv) { - tsv.current = tsv.tg->stateList->tState; + tsv.current = tsv.tg->stateStart->tState; tsv.buff.matchBegin = tsv.buff.buffptr; return tsv; } @@ -21,7 +21,6 @@ TSValue stateMatch(TSValue tsv) { fwrite(tsv.buff.matchBegin,tsv.buff.buffptr-tsv.buff.matchBegin-1,1,stdout); puts(""); - tsv.current = tsv.tg->stateList->tState; tsv.buff.buffptr--; tsv = stateSkip(tsv); return tsv; @@ -37,7 +36,7 @@ ccvSize++; } tState->ccvSize = ccvSize; - if (state->accept) { + if (state->accept && state != tg->stateList ) { tState->stateSkip = tg->stateMatch; tState->stateContinue = tg->stateNothing; } else { @@ -123,5 +122,10 @@ tsv.tg->stateMatch = stateMatch; tsv.tg->stateNothing = stateNothing; tsv.current = generateTState(tg->stateList,tg); + tg->stateStart = NEW(State); + *tg->stateStart = *tg->stateList; + tg->stateStart->accept = false; // Start state never accept + generateTState(tg->stateStart,tg); + tSearch(tsv); }