X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fccltoken.c;h=6d201f4cc6242e029ce27e4d391ba883c5b5790b;hp=f1f7708ad966a6aa26c612d4746980205a413068;hb=6d59a642cb7cd71df249fc4ecf5928ea79c7038c;hpb=379504a233e3e2cc85bca1e7b6d864f1395aec7c diff --git a/src/ccltoken.c b/src/ccltoken.c index f1f7708..6d201f4 100644 --- a/src/ccltoken.c +++ b/src/ccltoken.c @@ -1,16 +1,18 @@ /* This file is part of the YAZ toolkit. - * Copyright (C) 1995-2009 Index Data + * Copyright (C) 1995-2013 Index Data * See the file LICENSE for details. */ -/** +/** * \file ccltoken.c * \brief Implements CCL lexical analyzer (scanner) */ +#if HAVE_CONFIG_H +#include +#endif #include #include -#include - +#include #include "cclp.h" /* @@ -101,7 +103,7 @@ struct ccl_token *ccl_parser_tokenize(CCL_parser cclp, const char *command) case '%': case '!': last->kind = CCL_TOK_PROX; - while (isdigit(*cp)) + while (yaz_isdigit(*cp)) { ++ last->len; cp++; @@ -121,29 +123,39 @@ struct ccl_token *ccl_parser_tokenize(CCL_parser cclp, const char *command) else last->kind = CCL_TOK_REL; break; - case '\"': + default: + --cp; + --last->len; + last->kind = CCL_TOK_TERM; last->name = (const char *) cp; - last->len = 0; - while (*cp && *cp != '\"') + while (*cp && !strchr("(),%!><= \t\n\r", *cp)) { - cp++; - ++ last->len; - } - if (*cp == '\"') - cp++; - break; - default: - if (!strchr("(),%!><= \t\n\r", cp[-1])) - { - while (*cp && !strchr("(),%!><= \t\n\r", *cp)) + if (*cp == '\\' && cp[1]) { cp++; ++ last->len; } + else if (*cp == '"') + { + while (*cp) + { + cp++; + ++ last->len; + if (*cp == '\\' && cp[1]) + { + cp++; + ++ last->len; + } + else if (*cp == '"') + break; + } + } + if (!*cp) + break; + cp++; + ++ last->len; } - last->kind = CCL_TOK_TERM; - aliases = ccl_qual_search_special(cclp->bibset, "and"); if (!aliases) aliases = cclp->ccl_token_and; @@ -190,7 +202,7 @@ struct ccl_token *ccl_token_add(struct ccl_token *at) n->ws_prefix_len = 0; return n; } - + /* * ccl_token_del: delete CCL tokens */ @@ -198,7 +210,7 @@ void ccl_token_del(struct ccl_token *list) { struct ccl_token *list1; - while (list) + while (list) { list1 = list->next; xfree(list);