Mercurial > hg > Members > masakoha > testcode
view regexParser/test/ccMerge.cc @ 324:879dc5d1cb6a default tip
fix
author | mir3636 |
---|---|
date | Fri, 27 May 2016 21:21:09 +0900 |
parents | df27e6cab846 |
children |
line wrap: on
line source
#include <stdio.h> #include <stdlib.h> #include <string.h> #include "regexParser.h" #include "node.h" #include "CharClass.h" #include "subsetConstruction.h" void printCCTree(CharClassPtr cc) { if (cc->left != NULL) { printCCTree(cc->left); } printf("range : [%c-%c] NextState : %lu\n",(unsigned char)cc->cond.range.begin,(unsigned char)cc->cond.range.end, cc->nextState.bitContainer); if (cc->right != NULL) { printCCTree(cc->right); } } int main(int argc, char **argv) { RegexInfo ri; NodePtr n = NULL; StatePtr s = NULL; TGValue tgv = createTGValue(); State dummy; tgv.tg->stateEnd = &dummy; for (int i = 1; i < argc; i++) { if (strcmp(argv[i],"-regex") == 0) { ri.ptr = (unsigned char*)argv[i+1]; i++; printf("regex : %s\n",ri.ptr); NodePtr nMerge = regex(&ri); StatePtr sMerge = createState(tgv,nMerge); setState(sMerge->cc,sMerge->bitState); if (s == NULL) { s = sMerge; n = nMerge; printCCTree(s->cc); continue; } CharClassPtr cc = mergeTransition(s,sMerge->cc); s->cc = cc; printCCTree(s->cc); } } return 0; }