- if (!(bsrt = bend_search(&bsrq)))
- return -1;
- else if (bsrt->errcode)
- resp.records = diagrec(bsrt->errcode, bsrt->errstring);
+ if (!(oent = oid_getentbyoid(q->attributeSetId)) ||
+ oent->class != CLASS_ATTSET ||
+ oent->value != VAL_BIB1)
+ resp.records = diagrec(assoc->proto, 121, 0);
+ }
+ if (!resp.records)
+ {
+ bsrq.setname = req->resultSetName;
+ bsrq.replace_set = *req->replaceIndicator;
+ bsrq.num_bases = req->num_databaseNames;
+ bsrq.basenames = req->databaseNames;
+ bsrq.query = req->query;
+
+ if (!(bsrt = bend_search(&bsrq)))
+ return -1;
+ else if (bsrt->errcode)
+ resp.records = diagrec(assoc->proto, bsrt->errcode, bsrt->errstring);
+ else
+ resp.records = 0;
+
+ resp.resultCount = &bsrt->hits;
+ resp.numberOfRecordsReturned = &nulint;
+ nrp = bsrt->hits ? 1 : 0;
+ resp.nextResultSetPosition = &nrp;
+ resp.searchStatus = &sr;
+ resp.resultSetStatus = &sr;
+ resp.presentStatus = 0;
+ }