X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=ccl%2Fcclfind.c;h=ba12079846fb8b2047839f74bddd24c9df630336;hb=9d746417d51ee7eedd3cedf78b734d498cc49521;hp=a4d0ba1b06386c57163a2cf16617b6763b6cc86e;hpb=f8bd96fa2d6164cec530daa8cec05bec21b1854e;p=yaz-moved-to-github.git diff --git a/ccl/cclfind.c b/ccl/cclfind.c index a4d0ba1..ba12079 100644 --- a/ccl/cclfind.c +++ b/ccl/cclfind.c @@ -45,7 +45,14 @@ * Europagate, 1995 * * $Log: cclfind.c,v $ - * Revision 1.15 2000-02-24 23:49:13 adam + * Revision 1.17 2000-05-01 09:36:50 adam + * Range operator only treated in ordered ranges so that minus (-) can be + * used for, say, the and-not operator. + * + * Revision 1.16 2000/03/14 09:06:11 adam + * Added POSIX threads support for frontend server. + * + * Revision 1.15 2000/02/24 23:49:13 adam * Fixed memory allocation problem. * * Revision 1.14 2000/01/31 13:15:21 adam @@ -133,7 +140,6 @@ * */ -#include #include #include @@ -577,7 +583,8 @@ static struct ccl_rpn_node *qualifiers (CCL_parser cclp, struct ccl_token *la, ADVANCE; /* skip relation */ if (KIND == CCL_TOK_TERM && - cclp->look_token->next->kind == CCL_TOK_MINUS) + cclp->look_token->next->len == 1 && + cclp->look_token->next->name[0] == '-') { struct ccl_rpn_node *p1; if (!(p1 = search_term (cclp, ap))) @@ -611,7 +618,8 @@ static struct ccl_rpn_node *qualifiers (CCL_parser cclp, struct ccl_token *la, return p1; } } - else if (KIND == CCL_TOK_MINUS) /* = - term ? */ + else if (cclp->look_token->len == 1 && + cclp->look_token->name[0] == '"') /* = - term ? */ { ADVANCE; if (!(p = search_term (cclp, ap))) @@ -669,8 +677,7 @@ static struct ccl_rpn_node *search_terms (CCL_parser cclp, struct ccl_rpn_attr **qa) { static int list[] = { - CCL_TOK_TERM, CCL_TOK_COMMA,CCL_TOK_EQ, - CCL_TOK_REL, CCL_TOK_MINUS, -1}; + CCL_TOK_TERM, CCL_TOK_COMMA,CCL_TOK_EQ, CCL_TOK_REL, -1}; struct ccl_rpn_node *p1, *p2, *pn; p1 = search_term_x (cclp, qa, list); if (!p1)