X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fzserver.c;h=87dab70fe5014b1cc51c1937dccbbf4e4a432456;hb=dc030e8fbc67937e0fa1812f6ce4a8ab728d092c;hp=f230f54e19ad32a0ea64203b17b1d5021f4f5104;hpb=8add234f71c852fd95ca3aef168e3563265c93b9;p=idzebra-moved-to-github.git diff --git a/index/zserver.c b/index/zserver.c index f230f54..87dab70 100644 --- a/index/zserver.c +++ b/index/zserver.c @@ -1,4 +1,4 @@ -/* $Id: zserver.c,v 1.128 2005-01-16 23:14:57 adam Exp $ +/* $Id: zserver.c,v 1.131 2005-04-15 10:47:49 adam Exp $ Copyright (C) 1995-2005 Index Data ApS @@ -262,6 +262,8 @@ static void search_terms (ZebraHandle zh, bend_search_rr *r) int bend_search (void *handle, bend_search_rr *r) { ZebraHandle zh = (ZebraHandle) handle; + zint zhits = 0; + ZEBRA_RES res; r->hits = 0; r->errcode = 0; @@ -277,11 +279,18 @@ int bend_search (void *handle, bend_search_rr *r) switch (r->query->which) { case Z_Query_type_1: case Z_Query_type_101: - zebra_search_RPN (zh, r->stream, r->query->u.type_1, - r->setname, &r->hits); - zebra_result (zh, &r->errcode, &r->errstring); - if (!r->errcode) + res = zebra_search_RPN (zh, r->stream, r->query->u.type_1, + r->setname, &zhits); + if (zebra_errCode(zh) == 0) + { + if (zhits > 2147483646) + r->hits = 2147483647; + else + r->hits = (int) zhits; search_terms (zh, r); + } + else + zebra_result (zh, &r->errcode, &r->errstring); break; case Z_Query_type_2: r->errcode = 107; @@ -382,7 +391,7 @@ int bend_delete (void *handle, bend_delete_rr *rr) { ZebraHandle zh = (ZebraHandle) handle; - rr->delete_status = zebra_deleleResultSet(zh, rr->function, + rr->delete_status = zebra_deleteResultSet(zh, rr->function, rr->num_setnames, rr->setnames, rr->statuses); return 0; @@ -638,7 +647,7 @@ int bend_esrequest (void *handle, bend_esrequest_rr *rr) } else { - int r = -1; + ZEBRA_RES r = ZEBRA_FAIL; switch(action) { case 1: r = zebra_insert_record( @@ -650,7 +659,7 @@ int bend_esrequest (void *handle, bend_esrequest_rr *rr) rec->u.octet_aligned->buf, rec->u.octet_aligned->len, 0); - if (r) + if (r == ZEBRA_FAIL) { rr->errcode = 224; rr->errstring = "insert_record failed"; @@ -667,7 +676,7 @@ int bend_esrequest (void *handle, bend_esrequest_rr *rr) rec->u.octet_aligned->buf, rec->u.octet_aligned->len, 1); - if (r) + if (r == ZEBRA_FAIL) { rr->errcode = 224; rr->errstring = "update_record failed"; @@ -683,7 +692,7 @@ int bend_esrequest (void *handle, bend_esrequest_rr *rr) rec->u.octet_aligned->buf, rec->u.octet_aligned->len, 0); - if (r) + if (r == ZEBRA_FAIL) { rr->errcode = 224; rr->errstring = "delete_record failed";