X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=dfa%2Fdfa.c;h=f909f2e9eab5670e8617fcb20425b0a99090bc88;hb=4f8e7cf65d950e97389d046b255ff3b09e1d9bb5;hp=58962de6aa0f06ffcfdae18c922411fead93f42d;hpb=ca8c7208a371bcfb79c846dfec9cd7cb42ecaf92;p=idzebra-moved-to-github.git diff --git a/dfa/dfa.c b/dfa/dfa.c index 58962de..f909f2e 100644 --- a/dfa/dfa.c +++ b/dfa/dfa.c @@ -1,5 +1,5 @@ -/* $Id: dfa.c,v 1.39 2006-10-12 12:27:28 adam Exp $ - Copyright (C) 1995-2006 +/* $Id: dfa.c,v 1.40 2007-01-15 15:10:15 adam Exp $ + Copyright (C) 1995-2007 Index Data ApS This file is part of the Zebra server. @@ -1032,9 +1032,12 @@ static struct DFA_parse *dfa_parse_init (void) parse_info->rule = 0; parse_info->root = NULL; + /* initialize the anyset which by default does not include \n */ parse_info->anyset = mk_BSet (&parse_info->charset); res_BSet (parse_info->charset, parse_info->anyset); + add_BSet (parse_info->charset, parse_info->anyset, '\n'); com_BSet (parse_info->charset, parse_info->anyset); + parse_info->use_Tnode = parse_info->max_Tnode = 0; parse_info->start = parse_info->end = NULL; parse_info->charMap = NULL; @@ -1096,6 +1099,11 @@ struct DFA *dfa_init (void) return dfa; } +void dfa_anyset_includes_nl(struct DFA *dfa) +{ + add_BSet (dfa->parse_info->charset, dfa->parse_info->anyset, '\n'); +} + void dfa_set_cmap (struct DFA *dfa, void *vp, const char **(*cmap)(void *vp, const char **from, int len)) { @@ -1117,12 +1125,6 @@ int dfa_parse (struct DFA *dfa, const char **pattern) assert (dfa->parse_info); parse_info = dfa->parse_info; - if (!parse_info->cmap) - { - res_BSet (parse_info->charset, parse_info->anyset); - add_BSet (parse_info->charset, parse_info->anyset, '\n'); - com_BSet (parse_info->charset, parse_info->anyset); - } do_parse (parse_info, pattern, &top); if (parse_info->err_code) return parse_info->err_code;